react-magma-dom 3.8.0 → 3.9.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.
@@ -885,7 +885,7 @@ var magma = {
885
885
  },
886
886
  iterableColors: ['#0085CC', '#E0004D', '#FA6600', '#48A200', '#B12FAD', '#00A393', '#00507A', '#8F0033', '#B84900', '#255200', '#711E6E', '#005249'],
887
887
  chartColors: ['#009AF3', '#E0004D', '#1EA746', '#FA6600', '#B12FAD', '#00A393', '#005F96', '#8F0033', '#136A2D', '#B84900', '#711E6E', '#005249'],
888
- chartColorsInverse: ['#1FB0FF', '#FF337A', '#65E000', '#FF9147', '#D45ED0', '#00E0CA', '#85D4FF', '#FF99BD', '#FFB685', '#C7FF99', '#E9AFE7', '#99FFF5'],
888
+ chartColorsInverse: ['#1FB0FF', '#FF337A', '#65E000', '#FF9147', '#D45ED0', '#00E0CA', '#85D4FF', '#FF99BD', '#C7FF99', '#FFB685', '#E9AFE7', '#99FFF5'],
889
889
  tabs: {
890
890
  approxTabSize: {
891
891
  horizontal: 120,
@@ -1605,6 +1605,11 @@ var defaultI18n = {
1605
1605
  spinner: {
1606
1606
  ariaLabel: 'Loading'
1607
1607
  },
1608
+ stepper: {
1609
+ completionLabel: 'All steps completed',
1610
+ stepLabel: 'Step',
1611
+ stepOfLabel: 'of'
1612
+ },
1608
1613
  table: {
1609
1614
  pagination: {
1610
1615
  ofLabel: 'of',
@@ -2984,23 +2989,52 @@ var Breadcrumb = /*#__PURE__*/React.forwardRef(function (props, ref) {
2984
2989
  }, children)));
2985
2990
  });
2986
2991
 
2987
- var _excluded$b = ["children", "to", "styledAs", "testId"];
2992
+ var _excluded$b = ["children", "to", "styledAs", "testId", "hasUnderline", "icon", "iconPosition"];
2993
+ (function (HyperlinkIconPosition) {
2994
+ HyperlinkIconPosition["left"] = "left";
2995
+ HyperlinkIconPosition["right"] = "right";
2996
+ HyperlinkIconPosition["both"] = "both";
2997
+ })(exports.HyperlinkIconPosition || (exports.HyperlinkIconPosition = {}));
2988
2998
  var linkStyles = function linkStyles(props) {
2989
- return /*#__PURE__*/core.css("color:", props.isInverse ? props.theme.colors.tertiary : props.theme.colors.primary, ";text-decoration:underline;font-family:", props.theme.bodyFont, ";&:not([disabled]){&:hover,&:focus{color:", props.isInverse ? props.theme.colors.primary100 : props.theme.colors.primary400, ";}&:focus{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:2px;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPZ0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGNzcywgQ2xhc3NOYW1lcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBvbWl0IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCYXNlU3R5bGVkQnV0dG9uLCBidXR0b25TdHlsZXMgfSBmcm9tICcuLi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuY29uc3QgbGlua1N0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnlcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICAmOm5vdChbZGlzYWJsZWRdKSB7XG4gICAgJjpob3ZlcixcbiAgICAmOmZvY3VzIHtcbiAgICAgIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTQwMH07XG4gICAgfVxuICAgICY6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgIG91dGxpbmUtb2Zmc2V0OiAycHg7XG4gICAgfVxuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkLmEgYFxuICAke2xpbmtTdHlsZXN9XG5gO1xyXG5leHBvcnQgY29uc3QgSHlwZXJsaW5rID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdG8sIHN0eWxlZEFzLCB0ZXN0SWQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3Qgb3RoZXIgPSBvbWl0KFsncG9zaXRpb25Ub3AnLCAncG9zaXRpb25MZWZ0JywgJ3R5cGUnXSwgcmVzdCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShwcm9wcy5pc0ludmVyc2UpO1xyXG4gICAgaWYgKHR5cGVvZiBjaGlsZHJlbiA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgIGNvbnN0IGNvbXBvc2VkU3R5bGUgPSBzdHlsZWRBcyA9PT0gJ0J1dHRvbidcclxuICAgICAgICAgICAgPyBidXR0b25TdHlsZXMoeyAuLi5wcm9wcywgdGhlbWUgfSlcclxuICAgICAgICAgICAgOiBsaW5rU3R5bGVzKHsgLi4ucHJvcHMsIHRoZW1lIH0pO1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDbGFzc05hbWVzLCBudWxsLCAoeyBjc3M6IGNvbXBvc2VkQ3NzIH0pID0+IHtcclxuICAgICAgICAgICAgY29uc3QgY2xhc3NOYW1lID0gY29tcG9zZWRDc3MoY29tcG9zZWRTdHlsZSk7XHJcbiAgICAgICAgICAgIHJldHVybiBjaGlsZHJlbih7XHJcbiAgICAgICAgICAgICAgICB0byxcclxuICAgICAgICAgICAgICAgIGNsYXNzTmFtZSxcclxuICAgICAgICAgICAgICAgIGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgY29uc3QgTGlua1N0eWxlZEFzQnV0dG9uID0gQmFzZVN0eWxlZEJ1dHRvbi53aXRoQ29tcG9uZW50KCdhJyk7XHJcbiAgICAgICAgY29uc3QgSHlwZXJsaW5rQ29tcG9uZW50ID0gc3R5bGVkQXMgPT09ICdCdXR0b24nID8gTGlua1N0eWxlZEFzQnV0dG9uIDogU3R5bGVkTGluaztcclxuICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSHlwZXJsaW5rQ29tcG9uZW50LCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyByZWY6IHJlZiwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhyZWY6IHRvLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0pLCBjaGlsZHJlbikpO1xyXG4gICAgfVxyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
2999
+ return /*#__PURE__*/core.css("color:", props.isInverse ? props.theme.colors.tertiary : props.theme.colors.primary, ";text-decoration:", props.hasUnderline ? 'underline' : 'none', ";font-family:", props.theme.bodyFont, ";display:inline-flex;align-items:center;&:not([disabled]){&:hover,&:focus{color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.primary700, ";text-decoration:underline;}&:focus{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:2px;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhZ0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGNzcywgQ2xhc3NOYW1lcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBvbWl0IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCYXNlU3R5bGVkQnV0dG9uLCBidXR0b25TdHlsZXMgfSBmcm9tICcuLi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuZXhwb3J0IHZhciBIeXBlcmxpbmtJY29uUG9zaXRpb247XHJcbihmdW5jdGlvbiAoSHlwZXJsaW5rSWNvblBvc2l0aW9uKSB7XHJcbiAgICBIeXBlcmxpbmtJY29uUG9zaXRpb25bXCJsZWZ0XCJdID0gXCJsZWZ0XCI7XHJcbiAgICBIeXBlcmxpbmtJY29uUG9zaXRpb25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxuICAgIEh5cGVybGlua0ljb25Qb3NpdGlvbltcImJvdGhcIl0gPSBcImJvdGhcIjtcclxufSkoSHlwZXJsaW5rSWNvblBvc2l0aW9uIHx8IChIeXBlcmxpbmtJY29uUG9zaXRpb24gPSB7fSkpO1xyXG5jb25zdCBsaW5rU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgY29sb3I6ICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy50ZXJ0aWFyeVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gIHRleHQtZGVjb3JhdGlvbjogJHtwcm9wcy5oYXNVbmRlcmxpbmUgPyAndW5kZXJsaW5lJyA6ICdub25lJ307XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICY6bm90KFtkaXNhYmxlZF0pIHtcbiAgICAmOmhvdmVyLFxuICAgICY6Zm9jdXMge1xuICAgICAgY29sb3I6ICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NzAwfTtcbiAgICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuICAgIH1cbiAgICAmOmZvY3VzIHtcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkTGluayA9IHN0eWxlZC5hIGBcbiAgJHtsaW5rU3R5bGVzfVxuYDtcclxuZnVuY3Rpb24gZ2V0SWNvblBhZGRpbmcocHJvcHMpIHtcclxuICAgIHN3aXRjaCAocHJvcHMuc2l6ZSkge1xyXG4gICAgICAgIGNhc2UgJ2xhcmdlJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1O1xyXG4gICAgICAgIGNhc2UgJ3NtYWxsJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyO1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMztcclxuICAgIH1cclxufVxyXG5jb25zdCBJY29uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgcGFkZGluZy1sZWZ0OiAke3Byb3BzID0+IChwcm9wcy5wb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLnJpZ2h0IHx8XHJcbiAgICBwcm9wcy5wb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmJvdGgpICYmXHJcbiAgICBnZXRJY29uUGFkZGluZyhwcm9wcyl9O1xuICBwYWRkaW5nLXJpZ2h0OiAke3Byb3BzID0+IChwcm9wcy5wb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmxlZnQgfHxcclxuICAgIHByb3BzLnBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24uYm90aCkgJiZcclxuICAgIGdldEljb25QYWRkaW5nKHByb3BzKX07XG5gO1xyXG5leHBvcnQgY29uc3QgSHlwZXJsaW5rID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdG8sIHN0eWxlZEFzLCB0ZXN0SWQsIGhhc1VuZGVybGluZSA9IHRydWUsIGljb24sIGljb25Qb3NpdGlvbiA9IG51bGwsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3Qgb3RoZXIgPSBvbWl0KFsncG9zaXRpb25Ub3AnLCAncG9zaXRpb25MZWZ0JywgJ3R5cGUnXSwgcmVzdCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShwcm9wcy5pc0ludmVyc2UpO1xyXG4gICAgY29uc3QgaGFzTXVsdGlJY29ucyA9IGljb24gJiYgaWNvbiBpbnN0YW5jZW9mIEFycmF5ICYmIGljb24/Lmxlbmd0aCA+IDA7XHJcbiAgICBpZiAodHlwZW9mIGNoaWxkcmVuID09PSAnZnVuY3Rpb24nKSB7XHJcbiAgICAgICAgY29uc3QgY29tcG9zZWRTdHlsZSA9IHN0eWxlZEFzID09PSAnQnV0dG9uJ1xyXG4gICAgICAgICAgICA/IGJ1dHRvblN0eWxlcyh7IC4uLnByb3BzLCB0aGVtZSB9KVxyXG4gICAgICAgICAgICA6IGxpbmtTdHlsZXMoeyAuLi5wcm9wcywgdGhlbWUgfSk7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENsYXNzTmFtZXMsIG51bGwsICh7IGNzczogY29tcG9zZWRDc3MgfSkgPT4ge1xyXG4gICAgICAgICAgICBjb25zdCBjbGFzc05hbWUgPSBjb21wb3NlZENzcyhjb21wb3NlZFN0eWxlKTtcclxuICAgICAgICAgICAgcmV0dXJuIGNoaWxkcmVuKHtcclxuICAgICAgICAgICAgICAgIHRvLFxyXG4gICAgICAgICAgICAgICAgY2xhc3NOYW1lLFxyXG4gICAgICAgICAgICAgICAgaXNJbnZlcnNlLFxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9KSk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICBjb25zdCBMaW5rU3R5bGVkQXNCdXR0b24gPSBCYXNlU3R5bGVkQnV0dG9uLndpdGhDb21wb25lbnQoJ2EnKTtcclxuICAgICAgICBjb25zdCBIeXBlcmxpbmtDb21wb25lbnQgPSBzdHlsZWRBcyA9PT0gJ0J1dHRvbicgPyBMaW5rU3R5bGVkQXNCdXR0b24gOiBTdHlsZWRMaW5rO1xyXG4gICAgICAgIGlmIChpY29uICYmIGljb25Qb3NpdGlvbiAhPT0gbnVsbCkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSHlwZXJsaW5rQ29tcG9uZW50LCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzVW5kZXJsaW5lOiBoYXNVbmRlcmxpbmUsIGljb246IGljb24sIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBocmVmOiB0bywgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgICAgICBpY29uUG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5yaWdodCAmJiBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25XcmFwcGVyLCB7IHRoZW1lOiB0aGVtZSwgc2l6ZTogcHJvcHMuc2l6ZSwgcG9zaXRpb246IGljb25Qb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmJvdGhcclxuICAgICAgICAgICAgICAgICAgICAgICAgPyBIeXBlcmxpbmtJY29uUG9zaXRpb24ubGVmdFxyXG4gICAgICAgICAgICAgICAgICAgICAgICA6IGljb25Qb3NpdGlvbiB9LCBoYXNNdWx0aUljb25zID8gaWNvblswXSA6IGljb24pLFxyXG4gICAgICAgICAgICAgICAgaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24ubGVmdCAmJiBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgICAgICBpY29uUG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoICYmIGhhc011bHRpSWNvbnMgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgICAgICAgICAgY2hpbGRyZW4sXHJcbiAgICAgICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUsIHNpemU6IHByb3BzLnNpemUsIHBvc2l0aW9uOiBpY29uUG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA/IEh5cGVybGlua0ljb25Qb3NpdGlvbi5yaWdodFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgOiBpY29uUG9zaXRpb24gfSwgaWNvblsxXSkpKSkpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEh5cGVybGlua0NvbXBvbmVudCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc1VuZGVybGluZTogaGFzVW5kZXJsaW5lLCBocmVmOiB0bywgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSksIGNoaWxkcmVuKSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
2990
3000
  };
2991
3001
  var StyledLink = /*#__PURE__*/_styled$1("a", {
2992
3002
  target: "e1v66uiy0",
2993
3003
  label: "StyledLink"
2994
- })(linkStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QjRCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBjc3MsIENsYXNzTmFtZXMgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgb21pdCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQmFzZVN0eWxlZEJ1dHRvbiwgYnV0dG9uU3R5bGVzIH0gZnJvbSAnLi4vU3R5bGVkQnV0dG9uJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmNvbnN0IGxpbmtTdHlsZXMgPSBwcm9wcyA9PiBjc3MgYFxuICBjb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5XHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5fTtcbiAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgJjpub3QoW2Rpc2FibGVkXSkge1xuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBjb2xvcjogJHtwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnkxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk0MDB9O1xuICAgIH1cbiAgICAmOmZvY3VzIHtcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgIH1cbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkTGluayA9IHN0eWxlZC5hIGBcbiAgJHtsaW5rU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IEh5cGVybGluayA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIHRvLCBzdHlsZWRBcywgdGVzdElkLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IG90aGVyID0gb21pdChbJ3Bvc2l0aW9uVG9wJywgJ3Bvc2l0aW9uTGVmdCcsICd0eXBlJ10sIHJlc3QpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocHJvcHMuaXNJbnZlcnNlKTtcclxuICAgIGlmICh0eXBlb2YgY2hpbGRyZW4gPT09ICdmdW5jdGlvbicpIHtcclxuICAgICAgICBjb25zdCBjb21wb3NlZFN0eWxlID0gc3R5bGVkQXMgPT09ICdCdXR0b24nXHJcbiAgICAgICAgICAgID8gYnV0dG9uU3R5bGVzKHsgLi4ucHJvcHMsIHRoZW1lIH0pXHJcbiAgICAgICAgICAgIDogbGlua1N0eWxlcyh7IC4uLnByb3BzLCB0aGVtZSB9KTtcclxuICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2xhc3NOYW1lcywgbnVsbCwgKHsgY3NzOiBjb21wb3NlZENzcyB9KSA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGNsYXNzTmFtZSA9IGNvbXBvc2VkQ3NzKGNvbXBvc2VkU3R5bGUpO1xyXG4gICAgICAgICAgICByZXR1cm4gY2hpbGRyZW4oe1xyXG4gICAgICAgICAgICAgICAgdG8sXHJcbiAgICAgICAgICAgICAgICBjbGFzc05hbWUsXHJcbiAgICAgICAgICAgICAgICBpc0ludmVyc2UsXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0pKTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGNvbnN0IExpbmtTdHlsZWRBc0J1dHRvbiA9IEJhc2VTdHlsZWRCdXR0b24ud2l0aENvbXBvbmVudCgnYScpO1xyXG4gICAgICAgIGNvbnN0IEh5cGVybGlua0NvbXBvbmVudCA9IHN0eWxlZEFzID09PSAnQnV0dG9uJyA/IExpbmtTdHlsZWRBc0J1dHRvbiA6IFN0eWxlZExpbms7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEh5cGVybGlua0NvbXBvbmVudCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBocmVmOiB0bywgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9KSwgY2hpbGRyZW4pKTtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */");
3004
+ })(linkStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQzRCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBjc3MsIENsYXNzTmFtZXMgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgb21pdCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQmFzZVN0eWxlZEJ1dHRvbiwgYnV0dG9uU3R5bGVzIH0gZnJvbSAnLi4vU3R5bGVkQnV0dG9uJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmV4cG9ydCB2YXIgSHlwZXJsaW5rSWNvblBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKEh5cGVybGlua0ljb25Qb3NpdGlvbikge1xyXG4gICAgSHlwZXJsaW5rSWNvblBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgSHlwZXJsaW5rSWNvblBvc2l0aW9uW1wicmlnaHRcIl0gPSBcInJpZ2h0XCI7XHJcbiAgICBIeXBlcmxpbmtJY29uUG9zaXRpb25bXCJib3RoXCJdID0gXCJib3RoXCI7XHJcbn0pKEh5cGVybGlua0ljb25Qb3NpdGlvbiB8fCAoSHlwZXJsaW5rSWNvblBvc2l0aW9uID0ge30pKTtcclxuY29uc3QgbGlua1N0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnlcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB0ZXh0LWRlY29yYXRpb246ICR7cHJvcHMuaGFzVW5kZXJsaW5lID8gJ3VuZGVybGluZScgOiAnbm9uZSd9O1xuICBmb250LWZhbWlseTogJHtwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAmOm5vdChbZGlzYWJsZWRdKSB7XG4gICAgJjpob3ZlcixcbiAgICAmOmZvY3VzIHtcbiAgICAgIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJjpmb2N1cyB7XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICB9XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYSBgXG4gICR7bGlua1N0eWxlc31cbmA7XHJcbmZ1bmN0aW9uIGdldEljb25QYWRkaW5nKHByb3BzKSB7XHJcbiAgICBzd2l0Y2ggKHByb3BzLnNpemUpIHtcclxuICAgICAgICBjYXNlICdsYXJnZSc6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgICAgICBjYXNlICdzbWFsbCc6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMjtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDM7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiAocHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5yaWdodCB8fFxyXG4gICAgcHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoKSAmJlxyXG4gICAgZ2V0SWNvblBhZGRpbmcocHJvcHMpfTtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiAocHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICBwcm9wcy5wb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmJvdGgpICYmXHJcbiAgICBnZXRJY29uUGFkZGluZyhwcm9wcyl9O1xuYDtcclxuZXhwb3J0IGNvbnN0IEh5cGVybGluayA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIHRvLCBzdHlsZWRBcywgdGVzdElkLCBoYXNVbmRlcmxpbmUgPSB0cnVlLCBpY29uLCBpY29uUG9zaXRpb24gPSBudWxsLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IG90aGVyID0gb21pdChbJ3Bvc2l0aW9uVG9wJywgJ3Bvc2l0aW9uTGVmdCcsICd0eXBlJ10sIHJlc3QpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocHJvcHMuaXNJbnZlcnNlKTtcclxuICAgIGNvbnN0IGhhc011bHRpSWNvbnMgPSBpY29uICYmIGljb24gaW5zdGFuY2VvZiBBcnJheSAmJiBpY29uPy5sZW5ndGggPiAwO1xyXG4gICAgaWYgKHR5cGVvZiBjaGlsZHJlbiA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgIGNvbnN0IGNvbXBvc2VkU3R5bGUgPSBzdHlsZWRBcyA9PT0gJ0J1dHRvbidcclxuICAgICAgICAgICAgPyBidXR0b25TdHlsZXMoeyAuLi5wcm9wcywgdGhlbWUgfSlcclxuICAgICAgICAgICAgOiBsaW5rU3R5bGVzKHsgLi4ucHJvcHMsIHRoZW1lIH0pO1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDbGFzc05hbWVzLCBudWxsLCAoeyBjc3M6IGNvbXBvc2VkQ3NzIH0pID0+IHtcclxuICAgICAgICAgICAgY29uc3QgY2xhc3NOYW1lID0gY29tcG9zZWRDc3MoY29tcG9zZWRTdHlsZSk7XHJcbiAgICAgICAgICAgIHJldHVybiBjaGlsZHJlbih7XHJcbiAgICAgICAgICAgICAgICB0byxcclxuICAgICAgICAgICAgICAgIGNsYXNzTmFtZSxcclxuICAgICAgICAgICAgICAgIGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgY29uc3QgTGlua1N0eWxlZEFzQnV0dG9uID0gQmFzZVN0eWxlZEJ1dHRvbi53aXRoQ29tcG9uZW50KCdhJyk7XHJcbiAgICAgICAgY29uc3QgSHlwZXJsaW5rQ29tcG9uZW50ID0gc3R5bGVkQXMgPT09ICdCdXR0b24nID8gTGlua1N0eWxlZEFzQnV0dG9uIDogU3R5bGVkTGluaztcclxuICAgICAgICBpZiAoaWNvbiAmJiBpY29uUG9zaXRpb24gIT09IG51bGwpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEh5cGVybGlua0NvbXBvbmVudCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc1VuZGVybGluZTogaGFzVW5kZXJsaW5lLCBpY29uOiBpY29uLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgaHJlZjogdG8sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICAgICAgaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24ucmlnaHQgJiYgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUsIHNpemU6IHByb3BzLnNpemUsIHBvc2l0aW9uOiBpY29uUG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoXHJcbiAgICAgICAgICAgICAgICAgICAgICAgID8gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmxlZnRcclxuICAgICAgICAgICAgICAgICAgICAgICAgOiBpY29uUG9zaXRpb24gfSwgaGFzTXVsdGlJY29ucyA/IGljb25bMF0gOiBpY29uKSxcclxuICAgICAgICAgICAgICAgIGljb25Qb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmxlZnQgJiYgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAgICAgaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24uYm90aCAmJiBoYXNNdWx0aUljb25zICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lLCBzaXplOiBwcm9wcy5zaXplLCBwb3NpdGlvbjogaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24uYm90aFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPyBIeXBlcmxpbmtJY29uUG9zaXRpb24ucmlnaHRcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDogaWNvblBvc2l0aW9uIH0sIGljb25bMV0pKSkpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChIeXBlcmxpbmtDb21wb25lbnQsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoYXNVbmRlcmxpbmU6IGhhc1VuZGVybGluZSwgaHJlZjogdG8sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLCBjaGlsZHJlbikpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */");
3005
+ function getIconPadding$1(props) {
3006
+ switch (props.size) {
3007
+ case 'large':
3008
+ return props.theme.spaceScale.spacing05;
3009
+ case 'small':
3010
+ return props.theme.spaceScale.spacing02;
3011
+ default:
3012
+ return props.theme.spaceScale.spacing03;
3013
+ }
3014
+ }
3015
+ var IconWrapper$2 = /*#__PURE__*/_styled$1("span", {
3016
+ target: "e1v66uiy1",
3017
+ label: "IconWrapper"
3018
+ })("align-self:center;display:inline-flex;padding-left:", function (props) {
3019
+ return (props.position === exports.HyperlinkIconPosition.right || props.position === exports.HyperlinkIconPosition.both) && getIconPadding$1(props);
3020
+ }, ";padding-right:", function (props) {
3021
+ return (props.position === exports.HyperlinkIconPosition.left || props.position === exports.HyperlinkIconPosition.both) && getIconPadding$1(props);
3022
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtRGdDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBjc3MsIENsYXNzTmFtZXMgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgb21pdCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQmFzZVN0eWxlZEJ1dHRvbiwgYnV0dG9uU3R5bGVzIH0gZnJvbSAnLi4vU3R5bGVkQnV0dG9uJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmV4cG9ydCB2YXIgSHlwZXJsaW5rSWNvblBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKEh5cGVybGlua0ljb25Qb3NpdGlvbikge1xyXG4gICAgSHlwZXJsaW5rSWNvblBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgSHlwZXJsaW5rSWNvblBvc2l0aW9uW1wicmlnaHRcIl0gPSBcInJpZ2h0XCI7XHJcbiAgICBIeXBlcmxpbmtJY29uUG9zaXRpb25bXCJib3RoXCJdID0gXCJib3RoXCI7XHJcbn0pKEh5cGVybGlua0ljb25Qb3NpdGlvbiB8fCAoSHlwZXJsaW5rSWNvblBvc2l0aW9uID0ge30pKTtcclxuY29uc3QgbGlua1N0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnlcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICB0ZXh0LWRlY29yYXRpb246ICR7cHJvcHMuaGFzVW5kZXJsaW5lID8gJ3VuZGVybGluZScgOiAnbm9uZSd9O1xuICBmb250LWZhbWlseTogJHtwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAmOm5vdChbZGlzYWJsZWRdKSB7XG4gICAgJjpob3ZlcixcbiAgICAmOmZvY3VzIHtcbiAgICAgIGNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB9XG4gICAgJjpmb2N1cyB7XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICB9XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQuYSBgXG4gICR7bGlua1N0eWxlc31cbmA7XHJcbmZ1bmN0aW9uIGdldEljb25QYWRkaW5nKHByb3BzKSB7XHJcbiAgICBzd2l0Y2ggKHByb3BzLnNpemUpIHtcclxuICAgICAgICBjYXNlICdsYXJnZSc6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgICAgICBjYXNlICdzbWFsbCc6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMjtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDM7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIHBhZGRpbmctbGVmdDogJHtwcm9wcyA9PiAocHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5yaWdodCB8fFxyXG4gICAgcHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoKSAmJlxyXG4gICAgZ2V0SWNvblBhZGRpbmcocHJvcHMpfTtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiAocHJvcHMucG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICBwcm9wcy5wb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmJvdGgpICYmXHJcbiAgICBnZXRJY29uUGFkZGluZyhwcm9wcyl9O1xuYDtcclxuZXhwb3J0IGNvbnN0IEh5cGVybGluayA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIHRvLCBzdHlsZWRBcywgdGVzdElkLCBoYXNVbmRlcmxpbmUgPSB0cnVlLCBpY29uLCBpY29uUG9zaXRpb24gPSBudWxsLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IG90aGVyID0gb21pdChbJ3Bvc2l0aW9uVG9wJywgJ3Bvc2l0aW9uTGVmdCcsICd0eXBlJ10sIHJlc3QpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocHJvcHMuaXNJbnZlcnNlKTtcclxuICAgIGNvbnN0IGhhc011bHRpSWNvbnMgPSBpY29uICYmIGljb24gaW5zdGFuY2VvZiBBcnJheSAmJiBpY29uPy5sZW5ndGggPiAwO1xyXG4gICAgaWYgKHR5cGVvZiBjaGlsZHJlbiA9PT0gJ2Z1bmN0aW9uJykge1xyXG4gICAgICAgIGNvbnN0IGNvbXBvc2VkU3R5bGUgPSBzdHlsZWRBcyA9PT0gJ0J1dHRvbidcclxuICAgICAgICAgICAgPyBidXR0b25TdHlsZXMoeyAuLi5wcm9wcywgdGhlbWUgfSlcclxuICAgICAgICAgICAgOiBsaW5rU3R5bGVzKHsgLi4ucHJvcHMsIHRoZW1lIH0pO1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDbGFzc05hbWVzLCBudWxsLCAoeyBjc3M6IGNvbXBvc2VkQ3NzIH0pID0+IHtcclxuICAgICAgICAgICAgY29uc3QgY2xhc3NOYW1lID0gY29tcG9zZWRDc3MoY29tcG9zZWRTdHlsZSk7XHJcbiAgICAgICAgICAgIHJldHVybiBjaGlsZHJlbih7XHJcbiAgICAgICAgICAgICAgICB0byxcclxuICAgICAgICAgICAgICAgIGNsYXNzTmFtZSxcclxuICAgICAgICAgICAgICAgIGlzSW52ZXJzZSxcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgY29uc3QgTGlua1N0eWxlZEFzQnV0dG9uID0gQmFzZVN0eWxlZEJ1dHRvbi53aXRoQ29tcG9uZW50KCdhJyk7XHJcbiAgICAgICAgY29uc3QgSHlwZXJsaW5rQ29tcG9uZW50ID0gc3R5bGVkQXMgPT09ICdCdXR0b24nID8gTGlua1N0eWxlZEFzQnV0dG9uIDogU3R5bGVkTGluaztcclxuICAgICAgICBpZiAoaWNvbiAmJiBpY29uUG9zaXRpb24gIT09IG51bGwpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEh5cGVybGlua0NvbXBvbmVudCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc1VuZGVybGluZTogaGFzVW5kZXJsaW5lLCBpY29uOiBpY29uLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgaHJlZjogdG8sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICAgICAgaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24ucmlnaHQgJiYgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUsIHNpemU6IHByb3BzLnNpemUsIHBvc2l0aW9uOiBpY29uUG9zaXRpb24gPT09IEh5cGVybGlua0ljb25Qb3NpdGlvbi5ib3RoXHJcbiAgICAgICAgICAgICAgICAgICAgICAgID8gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmxlZnRcclxuICAgICAgICAgICAgICAgICAgICAgICAgOiBpY29uUG9zaXRpb24gfSwgaGFzTXVsdGlJY29ucyA/IGljb25bMF0gOiBpY29uKSxcclxuICAgICAgICAgICAgICAgIGljb25Qb3NpdGlvbiA9PT0gSHlwZXJsaW5rSWNvblBvc2l0aW9uLmxlZnQgJiYgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICAgICAgaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24uYm90aCAmJiBoYXNNdWx0aUljb25zICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICAgICAgICAgIGNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lLCBzaXplOiBwcm9wcy5zaXplLCBwb3NpdGlvbjogaWNvblBvc2l0aW9uID09PSBIeXBlcmxpbmtJY29uUG9zaXRpb24uYm90aFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPyBIeXBlcmxpbmtJY29uUG9zaXRpb24ucmlnaHRcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDogaWNvblBvc2l0aW9uIH0sIGljb25bMV0pKSkpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChIeXBlcmxpbmtDb21wb25lbnQsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoYXNVbmRlcmxpbmU6IGhhc1VuZGVybGluZSwgaHJlZjogdG8sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLCBjaGlsZHJlbikpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */"));
2995
3023
  var Hyperlink = /*#__PURE__*/React.forwardRef(function (props, ref) {
2996
3024
  var children = props.children,
2997
3025
  to = props.to,
2998
3026
  styledAs = props.styledAs,
2999
3027
  testId = props.testId,
3028
+ _props$hasUnderline = props.hasUnderline,
3029
+ hasUnderline = _props$hasUnderline === void 0 ? true : _props$hasUnderline,
3030
+ icon = props.icon,
3031
+ _props$iconPosition = props.iconPosition,
3032
+ iconPosition = _props$iconPosition === void 0 ? null : _props$iconPosition,
3000
3033
  rest = _objectWithoutPropertiesLoose(props, _excluded$b);
3001
3034
  var other = omit(['positionTop', 'positionLeft', 'type'], rest);
3002
3035
  var theme = React.useContext(ThemeContext);
3003
3036
  var isInverse = useIsInverse(props.isInverse);
3037
+ var hasMultiIcons = icon && icon instanceof Array && (icon == null ? void 0 : icon.length) > 0;
3004
3038
  if (typeof children === 'function') {
3005
3039
  var composedStyle = styledAs === 'Button' ? buttonStyles(_extends({}, props, {
3006
3040
  theme: theme
@@ -3018,17 +3052,39 @@ var Hyperlink = /*#__PURE__*/React.forwardRef(function (props, ref) {
3018
3052
  });
3019
3053
  } else {
3020
3054
  var LinkStyledAsButton = BaseStyledButton.withComponent('a', {
3021
- target: "e1v66uiy1",
3055
+ target: "e1v66uiy2",
3022
3056
  label: "LinkStyledAsButton"
3023
3057
  });
3024
3058
  var HyperlinkComponent = styledAs === 'Button' ? LinkStyledAsButton : StyledLink;
3025
- return React.createElement(HyperlinkComponent, Object.assign({}, other, {
3026
- ref: ref,
3027
- "data-testid": testId,
3028
- href: to,
3029
- isInverse: isInverse,
3030
- theme: theme
3031
- }), children);
3059
+ if (icon && iconPosition !== null) {
3060
+ return React.createElement(HyperlinkComponent, Object.assign({}, other, {
3061
+ "data-testid": testId,
3062
+ hasUnderline: hasUnderline,
3063
+ icon: icon,
3064
+ iconPosition: iconPosition,
3065
+ href: to,
3066
+ isInverse: isInverse,
3067
+ ref: ref,
3068
+ theme: theme
3069
+ }), iconPosition === exports.HyperlinkIconPosition.right && React.createElement(React.Fragment, null, children), React.createElement(IconWrapper$2, {
3070
+ theme: theme,
3071
+ size: props.size,
3072
+ position: iconPosition === exports.HyperlinkIconPosition.both ? exports.HyperlinkIconPosition.left : iconPosition
3073
+ }, hasMultiIcons ? icon[0] : icon), iconPosition === exports.HyperlinkIconPosition.left && React.createElement(React.Fragment, null, children), iconPosition === exports.HyperlinkIconPosition.both && hasMultiIcons && React.createElement(React.Fragment, null, children, React.createElement(IconWrapper$2, {
3074
+ theme: theme,
3075
+ size: props.size,
3076
+ position: iconPosition === exports.HyperlinkIconPosition.both ? exports.HyperlinkIconPosition.right : iconPosition
3077
+ }, icon[1])));
3078
+ } else {
3079
+ return React.createElement(HyperlinkComponent, Object.assign({}, other, {
3080
+ "data-testid": testId,
3081
+ hasUnderline: hasUnderline,
3082
+ href: to,
3083
+ isInverse: isInverse,
3084
+ ref: ref,
3085
+ theme: theme
3086
+ }), children);
3087
+ }
3032
3088
  }
3033
3089
  });
3034
3090
 
@@ -3042,10 +3098,10 @@ var StyledItem = /*#__PURE__*/_styled$1("li", {
3042
3098
  })( {
3043
3099
  name: "miqfjm",
3044
3100
  styles: "list-style:none;margin:0;padding:0;display:flex;",
3045
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyZWFkY3J1bWJJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPNkIiLCJmaWxlIjoiQnJlYWRjcnVtYkl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBIeXBlcmxpbmsgfSBmcm9tICcuLi9IeXBlcmxpbmsnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgQ2hldnJvblJpZ2h0SWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuY29uc3QgU3R5bGVkSXRlbSA9IHN0eWxlZC5saSBgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XHJcbmNvbnN0IFN0eWxlZFNwYW4gPSB0eXBlZFN0eWxlZC5zcGFuIGBcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcblxuICBzdmcge1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyfTtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJyZWFkY3J1bWJJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdG8sIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJdGVtLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgcmVmOiByZWYgfSksIHRvID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChIeXBlcmxpbmssIHsgdG86IHRvLCBpc0ludmVyc2U6IGlzSW52ZXJzZSB9LCBjaGlsZHJlbiksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGFuLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaGV2cm9uUmlnaHRJY29uLCB7IHNpemU6IHRoZW1lLmljb25TaXplcy5zbWFsbCB9KSkpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFNwYW4sIHsgXCJhcmlhLWN1cnJlbnRcIjogXCJwYWdlXCIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QnJlYWRjcnVtYkl0ZW0uanMubWFwIl19 */",
3101
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJyZWFkY3J1bWJJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPNkIiLCJmaWxlIjoiQnJlYWRjcnVtYkl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBIeXBlcmxpbmsgfSBmcm9tICcuLi9IeXBlcmxpbmsnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgQ2hldnJvblJpZ2h0SWNvbiB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuY29uc3QgU3R5bGVkSXRlbSA9IHN0eWxlZC5saSBgXG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG1hcmdpbjogMDtcbiAgcGFkZGluZzogMDtcbiAgZGlzcGxheTogZmxleDtcbmA7XHJcbmNvbnN0IFN0eWxlZFNwYW4gPSB0eXBlZFN0eWxlZC5zcGFuIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcblxuICBzdmcge1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyfTtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJyZWFkY3J1bWJJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdG8sIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJdGVtLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgcmVmOiByZWYgfSksIHRvID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChIeXBlcmxpbmssIHsgdG86IHRvLCBpc0ludmVyc2U6IGlzSW52ZXJzZSB9LCBjaGlsZHJlbiksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGFuLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaGV2cm9uUmlnaHRJY29uLCB7IHNpemU6IHRoZW1lLmljb25TaXplcy5zbWFsbCB9KSkpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFNwYW4sIHsgXCJhcmlhLWN1cnJlbnRcIjogXCJwYWdlXCIsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QnJlYWRjcnVtYkl0ZW0uanMubWFwIl19 */",
3046
3102
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
3047
3103
  });
3048
- var StyledSpan$1 = /*#__PURE__*/typedStyled$6.span(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n color: ", ";\n\n svg {\n margin: 0 ", ";\n color: ", ";\n }\n"])), function (props) {
3104
+ var StyledSpan$1 = /*#__PURE__*/typedStyled$6.span(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n display: flex;\n color: ", ";\n\n svg {\n margin: 0 ", ";\n color: ", ";\n }\n"])), function (props) {
3049
3105
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
3050
3106
  }, function (props) {
3051
3107
  return props.theme.spaceScale.spacing02;
@@ -3494,7 +3550,7 @@ var HiddenStyles = {
3494
3550
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
3495
3551
  };
3496
3552
 
3497
- var _excluded$j = ["children", "containerStyle", "defaultValue", "disabled", "hasCharacterCounter", "hasError", "icon", "iconAriaLabel", "iconRef", "isClearable", "isPasswordInput", "isPredictive", "maxCount", "maxLength", "onClear", "onIconClick", "onIconKeyDown", "inputLength", "inputSize", "inputStyle", "testId", "type"];
3553
+ var _excluded$j = ["children", "containerStyle", "defaultValue", "disabled", "hasCharacterCounter", "hasError", "icon", "iconAriaLabel", "iconRef", "isClearable", "isPasswordInput", "isPredictive", "maxCount", "maxLength", "onClear", "onIconClick", "onIconKeyDown", "onDateChange", "inputLength", "inputSize", "inputStyle", "inputWrapperStyle", "testId", "type"];
3498
3554
  var _templateObject$9;
3499
3555
  function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { 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)."; }
3500
3556
  (function (InputSize) {
@@ -3516,7 +3572,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to string
3516
3572
  })(exports.InputIconPosition || (exports.InputIconPosition = {}));
3517
3573
  var typedStyled$9 = _styled;
3518
3574
  var inputWrapperStyles = function inputWrapperStyles(props) {
3519
- return /*#__PURE__*/core.css("flex:1 1 auto;align-items:center;display:flex;flex-shrink:0;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? polished.transparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:2px;}", props.hasError && /*#__PURE__*/core.css("border-color:", props.isInverse ? props.theme.colors.danger200 : props.theme.colors.danger, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0DQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/core.css("border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/core.css("height:", props.theme.spaceScale.spacing11, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3575
+ return /*#__PURE__*/core.css("flex:1 1 auto;align-items:center;display:flex;flex-shrink:0;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? polished.transparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:2px;}", props.hasError && /*#__PURE__*/core.css("border-color:", props.isInverse ? props.theme.colors.danger200 : props.theme.colors.danger, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0DQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/core.css("border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/core.css("height:", props.theme.spaceScale.spacing11, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3520
3576
  };
3521
3577
  function getInputPadding(props) {
3522
3578
  var inputSize = props.inputSize,
@@ -3568,7 +3624,7 @@ function getInputPadding(props) {
3568
3624
  return padding;
3569
3625
  }
3570
3626
  var inputBaseStyles = function inputBaseStyles(props) {
3571
- return /*#__PURE__*/core.css("border:0;border-radius:", props.theme.borderRadius, ";background:transparent;color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";display:block;font-size:", props.theme.typeScale.size03.fontSize, ";line-height:", props.theme.typeScale.size03.lineHeight, ";font-family:", props.theme.bodyFont, ";height:", props.theme.spaceScale.spacing09, ";padding:", props.theme.spaceScale.spacing03, ";-webkit-appearance:none;width:100%;", props.inputSize === 'large' && /*#__PURE__*/core.css("font-size:", props.theme.typeScale.size04.fontSize, ";line-height:", props.theme.typeScale.size04.lineHeight, ";height:", props.theme.spaceScale.spacing11, ";padding:", props.theme.spaceScale.spacing04, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/core.css("color:", props.isInverse ? polished.transparentize(0.6, props.theme.colors.neutral100) : polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoLQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqI8C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3627
+ return /*#__PURE__*/core.css("border:0;border-radius:", props.theme.borderRadius, ";background:transparent;color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";display:block;font-size:", props.theme.typeScale.size03.fontSize, ";line-height:", props.theme.typeScale.size03.lineHeight, ";font-family:", props.theme.bodyFont, ";height:", props.theme.spaceScale.spacing09, ";padding:", props.theme.spaceScale.spacing03, ";-webkit-appearance:none;width:100%;", props.inputSize === 'large' && /*#__PURE__*/core.css("font-size:", props.theme.typeScale.size04.fontSize, ";line-height:", props.theme.typeScale.size04.lineHeight, ";height:", props.theme.spaceScale.spacing11, ";padding:", props.theme.spaceScale.spacing04, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAsJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/core.css("color:", props.isInverse ? polished.transparentize(0.6, props.theme.colors.neutral100) : polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoLQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqI8C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3572
3628
  };
3573
3629
  var InputContainer = /*#__PURE__*/_styled$1("div", {
3574
3630
  target: "e1jxjjn70",
@@ -3576,18 +3632,18 @@ var InputContainer = /*#__PURE__*/_styled$1("div", {
3576
3632
  })( {
3577
3633
  name: "k008qs",
3578
3634
  styles: "display:flex;",
3579
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkMkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3635
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkMkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
3580
3636
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
3581
3637
  });
3582
3638
  var InputWrapper = /*#__PURE__*/_styled$1("div", {
3583
3639
  target: "e1jxjjn71",
3584
3640
  label: "InputWrapper"
3585
- })(inputWrapperStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqMuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3641
+ })(inputWrapperStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqMuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3586
3642
  var StyledInput = /*#__PURE__*/_styled$1("input", {
3587
3643
  target: "e1jxjjn72",
3588
3644
  label: "StyledInput"
3589
- })(inputBaseStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwMiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3590
- var IconWrapper$2 = /*#__PURE__*/typedStyled$9.span(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n bottom: ", ";\n color: ", ";\n left: ", ";\n right: ", ";\n position: absolute;\n top: ", ";\n\n ", "\n"])), function (props) {
3645
+ })(inputBaseStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwMiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
3646
+ var IconWrapper$3 = /*#__PURE__*/typedStyled$9.span(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n bottom: ", ";\n color: ", ";\n left: ", ";\n right: ", ";\n position: absolute;\n top: ", ";\n\n ", "\n"])), function (props) {
3591
3647
  return props.iconPosition === 'top' ? '45px' : 'inherit';
3592
3648
  }, function (props) {
3593
3649
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
@@ -3600,7 +3656,7 @@ var IconWrapper$2 = /*#__PURE__*/typedStyled$9.span(_templateObject$9 || (_templ
3600
3656
  return props.theme.spaceScale.spacing03;
3601
3657
  };
3602
3658
  }, function (props) {
3603
- return props.inputSize === 'large' && /*#__PURE__*/core.css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4NQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3659
+ return props.inputSize === 'large' && /*#__PURE__*/core.css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4NQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3604
3660
  });
3605
3661
  function getIconButtonSVGSize(props) {
3606
3662
  var isClickable = props.isClickable,
@@ -3675,7 +3731,7 @@ var IconButtonContainer = /*#__PURE__*/_styled$1("span", {
3675
3731
  return getIconButtonSVGSize(props);
3676
3732
  }, ";width:", function (props) {
3677
3733
  return getIconButtonSVGSize(props);
3678
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiS+C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3734
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiS+C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3679
3735
  var PasswordButtonContainer = /*#__PURE__*/_styled$1("span", {
3680
3736
  target: "e1jxjjn74",
3681
3737
  label: "PasswordButtonContainer"
@@ -3683,7 +3739,7 @@ var PasswordButtonContainer = /*#__PURE__*/_styled$1("span", {
3683
3739
  return props.size === exports.InputSize.large ? -props.buttonWidth - 8 + "px" : -props.buttonWidth - 6 + "px";
3684
3740
  }, ",", function (props) {
3685
3741
  return props.size === exports.InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
3686
- }, " );" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiT4C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3742
+ }, " );" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiT4C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3687
3743
  function getClearablePosition(props) {
3688
3744
  if (props.hasChildren) {
3689
3745
  if (props.iconPosition === 'right') {
@@ -3724,7 +3780,7 @@ var IsClearableContainer = /*#__PURE__*/_styled$1("span", {
3724
3780
  return getClearablePosition(props);
3725
3781
  }, ",", function (props) {
3726
3782
  return props.inputSize === exports.InputSize.large ? props.theme.spaceScale.spacing03 : '7px';
3727
- }, " );" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4VyC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, inputLength, inputSize, inputStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, null,\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3783
+ }, " );" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4VyC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonVariant, ButtonType, ButtonSize, ButtonShape } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useForkedRef } from '../../utils';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nconst typedStyled = styled;\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = typedStyled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    let position = { x: '', y: '' };\r\n    if (iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            position.x = '-30px';\r\n            position.y = '2px';\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-28px';\r\n            position.y = '5px';\r\n        }\r\n        return position;\r\n    }\r\n    if (isClickable) {\r\n        if (inputSize === InputSize.large) {\r\n            if (hasChildren) {\r\n                position.x = '-43px';\r\n                position.y = '14px';\r\n            }\r\n            else {\r\n                position.x = '-49px';\r\n                position.y = '8px';\r\n            }\r\n        }\r\n        else if (inputSize === InputSize.medium) {\r\n            position.x = '-35px';\r\n            position.y = '6px';\r\n        }\r\n        return position;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        position.x = `-${theme.spaceScale.spacing10}`;\r\n        position.y = theme.spaceScale.spacing03;\r\n    }\r\n    else if (inputSize === InputSize.medium) {\r\n        position.x = '-24px';\r\n        position.y = '7px';\r\n    }\r\n    return position;\r\n}\r\nexport const IconButtonContainer = styled.span `\n  background-color: transparent;\n  bottom: ${props => (props.iconPosition === 'top' ? '40px' : 'inherit')};\n  height: auto;\n  margin: 0;\n  position: relative;\n  width: 0;\n  transform: translate(\n    ${props => getIconButtonTransform(props).x},\n    ${props => getIconButtonTransform(props).y}\n  );\n  svg {\n    height: ${props => getIconButtonSVGSize(props)};\n    width: ${props => getIconButtonSVGSize(props)};\n  }\n`;\r\nconst PasswordButtonContainer = styled.span `\n  background-color: transparent;\n  width: 0;\n  transform: translate(\n    ${props => props.size === InputSize.large\r\n    ? `${-props.buttonWidth - 8}px`\r\n    : `${-props.buttonWidth - 6}px`},\n    ${props => props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px'}\n  );\n`;\r\nfunction getClearablePosition(props) {\r\n    if (props.hasChildren) {\r\n        if (props.iconPosition === 'right') {\r\n            if (props.inputSize === 'large') {\r\n                return '92px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'left') {\r\n            if (props.inputSize === 'large') {\r\n                return '88px';\r\n            }\r\n            return props.theme.spaceScale.spacing12;\r\n        }\r\n        if (props.iconPosition === 'top') {\r\n            if (props.inputSize === 'large') {\r\n                return props.theme.spaceScale.spacing10;\r\n            }\r\n            return '34px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.iconPosition === 'right' && props.icon) {\r\n        if (props.inputSize === 'large') {\r\n            return '88px';\r\n        }\r\n        return props.theme.spaceScale.spacing12;\r\n    }\r\n    if (props.inputSize === 'large') {\r\n        return props.theme.spaceScale.spacing10;\r\n    }\r\n    return '34px';\r\n}\r\nconst IsClearableContainer = styled.span `\n  background-color: transparent;\n  margin: 0;\n  position: relative;\n  height: auto;\n  width: 0;\n  transform: translate(\n    -${props => getClearablePosition(props)},\n    ${props => props.inputSize === InputSize.large\r\n    ? props.theme.spaceScale.spacing03\r\n    : '7px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value && onDateChange && typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n        React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n            React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isClearable: inputWrapperStyle?.width\r\n                    ? isClearable\r\n                    : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n            icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                size: getIconSize(inputSize ? inputSize : InputSize.medium, theme, iconPosition),\r\n            }))))),\r\n        isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon, hasChildren: !!children && !isPasswordInput },\r\n            React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, isClickable: true },\r\n            React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                    ? ButtonSize.medium\r\n                    : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n        isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large ? InputSize.large : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize ? inputSize : InputSize.medium, theme: theme, isClickable: true, hasChildren: true }, children))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
3728
3784
  function getIconSize$1(size, theme, iconPosition) {
3729
3785
  switch (size) {
3730
3786
  case 'large':
@@ -3755,9 +3811,11 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
3755
3811
  onClear = props.onClear,
3756
3812
  onIconClick = props.onIconClick,
3757
3813
  onIconKeyDown = props.onIconKeyDown,
3814
+ onDateChange = props.onDateChange,
3758
3815
  inputLength = props.inputLength,
3759
3816
  inputSize = props.inputSize,
3760
3817
  inputStyle = props.inputStyle,
3818
+ inputWrapperStyle = props.inputWrapperStyle,
3761
3819
  testId = props.testId,
3762
3820
  type = props.type,
3763
3821
  other = _objectWithoutPropertiesLoose(props, _excluded$j);
@@ -3778,11 +3836,13 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
3778
3836
  function handleClearInput() {
3779
3837
  onClear && typeof onClear === 'function' && onClear();
3780
3838
  setValue('');
3839
+ onDateChange && typeof onDateChange === 'function' && onDateChange(null);
3781
3840
  inputRef.current.focus();
3782
3841
  }
3783
3842
  function handleChange(event) {
3784
3843
  props.onChange && typeof props.onChange === 'function' && props.onChange(event);
3785
3844
  setValue(event.target.value);
3845
+ if (!event.target.value && onDateChange && typeof onDateChange === 'function') onDateChange(null);
3786
3846
  }
3787
3847
  var passwordBtnWidth = function passwordBtnWidth() {
3788
3848
  var _children$props, _children$props$child, _children$props$child2, _children$props$child3, _children$props$child4;
@@ -3798,7 +3858,10 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
3798
3858
  return 54;
3799
3859
  }
3800
3860
  };
3801
- return React.createElement(InputContainer, null, React.createElement(InputWrapper, {
3861
+ return React.createElement(InputContainer, {
3862
+ style: inputWrapperStyle,
3863
+ "data-testid": testId + "-wrapper"
3864
+ }, React.createElement(InputWrapper, {
3802
3865
  disabled: disabled,
3803
3866
  iconPosition: iconPosition,
3804
3867
  isInverse: props.isInverse,
@@ -3815,7 +3878,7 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
3815
3878
  hasCharacterCounter: hasCharacterCounter,
3816
3879
  iconPosition: iconPosition,
3817
3880
  inputSize: inputSize ? inputSize : exports.InputSize.medium,
3818
- isClearable: isClearable && inputLength > 0,
3881
+ isClearable: inputWrapperStyle != null && inputWrapperStyle.width ? isClearable : isClearable && inputLength > 0,
3819
3882
  isInverse: useIsInverse(props.isInverse),
3820
3883
  isPredictive: isPredictive,
3821
3884
  hasError: hasError,
@@ -3826,7 +3889,7 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
3826
3889
  theme: theme,
3827
3890
  type: type ? type : exports.InputType.text,
3828
3891
  value: value
3829
- })), icon && !onIconClick && React.createElement(IconWrapper$2, {
3892
+ })), icon && !onIconClick && React.createElement(IconWrapper$3, {
3830
3893
  "aria-label": iconAriaLabel,
3831
3894
  iconPosition: iconPosition,
3832
3895
  inputSize: inputSize ? inputSize : exports.InputSize.medium,
@@ -3898,7 +3961,7 @@ function BuildMessageColor(props) {
3898
3961
  }
3899
3962
  return hasError ? theme.colors.danger : theme.colors.neutral500;
3900
3963
  }
3901
- var Message = /*#__PURE__*/typedStyled$a.div(_templateObject$a || (_templateObject$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n border-radius: ", ";\n color: ", ";\n display: flex;\n font-size: ", ";\n font-family: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-top: ", ";\n text-align: left;\n"])), function (props) {
3964
+ var Message = /*#__PURE__*/typedStyled$a.div(_templateObject$a || (_templateObject$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: flex-start;\n border-radius: ", ";\n color: ", ";\n display: flex;\n font-size: ", ";\n font-family: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-top: ", ";\n text-align: left;\n"])), function (props) {
3902
3965
  return props.theme.borderRadius;
3903
3966
  }, function (props) {
3904
3967
  return BuildMessageColor(props);
@@ -3913,7 +3976,7 @@ var Message = /*#__PURE__*/typedStyled$a.div(_templateObject$a || (_templateObje
3913
3976
  }, function (props) {
3914
3977
  return props.inputSize === exports.InputSize.large ? props.theme.spaceScale.spacing03 : props.theme.spaceScale.spacing02;
3915
3978
  });
3916
- var IconWrapper$3 = /*#__PURE__*/typedStyled$a.span(_templateObject2$2 || (_templateObject2$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: inline-flex;\n flex-shrink: 0;\n padding-right: ", ";\n"])), function (props) {
3979
+ var IconWrapper$4 = /*#__PURE__*/typedStyled$a.span(_templateObject2$2 || (_templateObject2$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: inline-flex;\n flex-shrink: 0;\n padding-right: ", ";\n"])), function (props) {
3917
3980
  return props.theme.spaceScale.spacing02;
3918
3981
  });
3919
3982
  var InputMessage = function InputMessage(_ref) {
@@ -3937,7 +4000,7 @@ var InputMessage = function InputMessage(_ref) {
3937
4000
  isInverse: isInverse,
3938
4001
  hasError: hasError,
3939
4002
  theme: theme
3940
- }), hasError && React.createElement(IconWrapper$3, {
4003
+ }), hasError && React.createElement(IconWrapper$4, {
3941
4004
  "aria-label": "Error",
3942
4005
  role: "img",
3943
4006
  theme: theme
@@ -3971,8 +4034,8 @@ var StyledLabel = /*#__PURE__*/_styled$1("label", {
3971
4034
  }, ";text-align:", function (props) {
3972
4035
  return props.labelPosition === exports.LabelPosition.left ? 'right' : 'left';
3973
4036
  }, ";white-space:", function (props) {
3974
- return props.iconPosition === exports.InputIconPosition.top || props.labelPosition === exports.LabelPosition.left ? 'inherit' : 'nowrap';
3975
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVaUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnB1dEljb25Qb3NpdGlvbiwgSW5wdXRTaXplIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBMYWJlbFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKExhYmVsUG9zaXRpb24pIHtcclxuICAgIExhYmVsUG9zaXRpb25bXCJsZWZ0XCJdID0gXCJsZWZ0XCI7XHJcbiAgICBMYWJlbFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoTGFiZWxQb3NpdGlvbiB8fCAoTGFiZWxQb3NpdGlvbiA9IHt9KSk7XHJcbmNvbnN0IFN0eWxlZExhYmVsID0gc3R5bGVkLmxhYmVsIGBcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMuc2l6ZSA9PT0gSW5wdXRTaXplLmxhcmdlXHJcbiAgICA/IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemVcclxuICAgIDogcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgbGV0dGVyLXNwYWNpbmc6ICR7cHJvcHMgPT4gcHJvcHMuc2l6ZSA9PT0gSW5wdXRTaXplLmxhcmdlXHJcbiAgICA/ICdpbmhlcml0J1xyXG4gICAgOiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy5zaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0XHJcbiAgICA6IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYCR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMGBcclxuICAgIDogYDAgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWB9O1xuICBtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMuaWNvblBvc2l0aW9uID09PSBJbnB1dEljb25Qb3NpdGlvbi50b3BcclxuICAgID8gJ2NhbGMoMTAwJSAtIDUxcHgpJ1xyXG4gICAgOiAnMTAwJSd9O1xuICB0ZXh0LWFsaWduOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCA/ICdyaWdodCcgOiAnbGVmdCd9O1xuICB3aGl0ZS1zcGFjZTogJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IElucHV0SWNvblBvc2l0aW9uLnRvcCB8fFxyXG4gICAgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/ICdpbmhlcml0J1xyXG4gICAgOiAnbm93cmFwJ307XG5gO1xyXG5jb25zdCBTdHlsZWRTcGFuID0gU3R5bGVkTGFiZWwud2l0aENvbXBvbmVudCgnc3BhbicpO1xyXG5leHBvcnQgY29uc3QgTGFiZWwgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFjdGlvbmFibGUgPSB0cnVlLCBjaGlsZHJlbiwgaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uLCBzaXplLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICByZXR1cm4gYWN0aW9uYWJsZSA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIHx8IExhYmVsUG9zaXRpb24udG9wLCByZWY6IHJlZiwgc2l6ZTogc2l6ZSA/IHNpemUgOiBJbnB1dFNpemUubWVkaXVtLCB0aGVtZTogdGhlbWUgfSksIGNoaWxkcmVuKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGFuLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIHx8IExhYmVsUG9zaXRpb24udG9wLCByZWY6IHJlZiwgc2l6ZTogc2l6ZSA/IHNpemUgOiBJbnB1dFNpemUubWVkaXVtLCB0aGVtZTogdGhlbWUgfSksIGNoaWxkcmVuKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
4037
+ return props.iconPosition === exports.InputIconPosition.top || props.labelPosition === exports.LabelPosition.left ? 'inherit' : 'normal';
4038
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVaUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnB1dEljb25Qb3NpdGlvbiwgSW5wdXRTaXplIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBMYWJlbFBvc2l0aW9uO1xyXG4oZnVuY3Rpb24gKExhYmVsUG9zaXRpb24pIHtcclxuICAgIExhYmVsUG9zaXRpb25bXCJsZWZ0XCJdID0gXCJsZWZ0XCI7XHJcbiAgICBMYWJlbFBvc2l0aW9uW1widG9wXCJdID0gXCJ0b3BcIjtcclxufSkoTGFiZWxQb3NpdGlvbiB8fCAoTGFiZWxQb3NpdGlvbiA9IHt9KSk7XHJcbmNvbnN0IFN0eWxlZExhYmVsID0gc3R5bGVkLmxhYmVsIGBcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMuc2l6ZSA9PT0gSW5wdXRTaXplLmxhcmdlXHJcbiAgICA/IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemVcclxuICAgIDogcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5mb250U2l6ZX07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgbGV0dGVyLXNwYWNpbmc6ICR7cHJvcHMgPT4gcHJvcHMuc2l6ZSA9PT0gSW5wdXRTaXplLmxhcmdlXHJcbiAgICA/ICdpbmhlcml0J1xyXG4gICAgOiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy5zaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0XHJcbiAgICA6IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnRcclxuICAgID8gYCR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDR9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMGBcclxuICAgIDogYDAgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWB9O1xuICBtYXgtd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMuaWNvblBvc2l0aW9uID09PSBJbnB1dEljb25Qb3NpdGlvbi50b3BcclxuICAgID8gJ2NhbGMoMTAwJSAtIDUxcHgpJ1xyXG4gICAgOiAnMTAwJSd9O1xuICB0ZXh0LWFsaWduOiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCA/ICdyaWdodCcgOiAnbGVmdCd9O1xuICB3aGl0ZS1zcGFjZTogJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IElucHV0SWNvblBvc2l0aW9uLnRvcCB8fFxyXG4gICAgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/ICdpbmhlcml0J1xyXG4gICAgOiAnbm9ybWFsJ307XG5gO1xyXG5jb25zdCBTdHlsZWRTcGFuID0gU3R5bGVkTGFiZWwud2l0aENvbXBvbmVudCgnc3BhbicpO1xyXG5leHBvcnQgY29uc3QgTGFiZWwgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFjdGlvbmFibGUgPSB0cnVlLCBjaGlsZHJlbiwgaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uLCBzaXplLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICByZXR1cm4gYWN0aW9uYWJsZSA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZExhYmVsLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIHx8IExhYmVsUG9zaXRpb24udG9wLCByZWY6IHJlZiwgc2l6ZTogc2l6ZSA/IHNpemUgOiBJbnB1dFNpemUubWVkaXVtLCB0aGVtZTogdGhlbWUgfSksIGNoaWxkcmVuKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGFuLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIHx8IExhYmVsUG9zaXRpb24udG9wLCByZWY6IHJlZiwgc2l6ZTogc2l6ZSA/IHNpemUgOiBJbnB1dFNpemUubWVkaXVtLCB0aGVtZTogdGhlbWUgfSksIGNoaWxkcmVuKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
3976
4039
  var StyledSpan$2 = /*#__PURE__*/StyledLabel.withComponent('span', {
3977
4040
  target: "egrtx8x1",
3978
4041
  label: "StyledSpan"
@@ -4630,7 +4693,7 @@ var SortButton = /*#__PURE__*/typedStyled$d.button(_templateObject2$4 || (_templ
4630
4693
  }, function (props) {
4631
4694
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
4632
4695
  });
4633
- var IconWrapper$4 = /*#__PURE__*/typedStyled$d.span(_templateObject3$2 || (_templateObject3$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding-left: ", ";\n position: relative;\n top: ", ";\n"])), function (props) {
4696
+ var IconWrapper$5 = /*#__PURE__*/typedStyled$d.span(_templateObject3$2 || (_templateObject3$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding-left: ", ";\n position: relative;\n top: ", ";\n"])), function (props) {
4634
4697
  return props.theme.spaceScale.spacing03;
4635
4698
  }, function (props) {
4636
4699
  return props.theme.spaceScale.spacing02;
@@ -4680,7 +4743,7 @@ var TableHeaderCell = /*#__PURE__*/React.forwardRef(function (props, ref) {
4680
4743
  onClick: handleSort,
4681
4744
  textAlign: align || exports.TableCellAlign.left,
4682
4745
  theme: theme
4683
- }, React.createElement("span", null, children), React.createElement(IconWrapper$4, {
4746
+ }, React.createElement("span", null, children), React.createElement(IconWrapper$5, {
4684
4747
  theme: theme
4685
4748
  }, SortIcon)) : React.createElement(React.Fragment, null, children));
4686
4749
  });
@@ -5087,7 +5150,7 @@ var SelectedItemButton = /*#__PURE__*/typedStyled$g.button(_templateObject3$3 ||
5087
5150
  }, function (props) {
5088
5151
  return props.theme.spaceScale.spacing03;
5089
5152
  });
5090
- var IconWrapper$5 = /*#__PURE__*/_styled$1("span", {
5153
+ var IconWrapper$6 = /*#__PURE__*/_styled$1("span", {
5091
5154
  target: "e1nm1jaa5",
5092
5155
  label: "IconWrapper"
5093
5156
  })( {
@@ -5137,50 +5200,51 @@ function defaultComponents(props) {
5137
5200
  }
5138
5201
 
5139
5202
  var _excluded$A = ["additionalContent", "children", "containerStyle", "disabled", "errorMessage", "id", "helperMessage", "isInverse", "labelPosition", "labelStyle", "labelText", "labelWidth", "messageStyle", "testId"];
5140
- var _templateObject$h;
5203
+ var _templateObject$h, _templateObject2$6, _templateObject3$4, _templateObject4$2;
5141
5204
  function _EMOTION_STRINGIFIED_CSS_ERROR__$e() { 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)."; }
5142
5205
  var typedStyled$h = _styled;
5143
- var StyledNativeSelectWrapper = /*#__PURE__*/_styled$1("div", {
5144
- target: "ek9bqze0",
5145
- label: "StyledNativeSelectWrapper"
5146
- })(inputWrapperStyles, " border:1px solid ", borderColors, ";svg{color:", function (props) {
5147
- return props.isInverse && props.disabled ? polished.transparentize(0.6, props.theme.colors.neutral100) : props.disabled ? polished.transparentize(0.4, props.theme.colors.neutral500) : 'inherit';
5148
- }, ";margin:0 0 0 -", function (props) {
5149
- return props.theme.spaceScale.spacing06;
5150
- }, ";pointer-events:none;z-index:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWTZDIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBpbnB1dEJhc2VTdHlsZXMsIGlucHV0V3JhcHBlclN0eWxlcyB9IGZyb20gJy4uL0lucHV0QmFzZSc7XHJcbmltcG9ydCB7IEZvcm1GaWVsZENvbnRhaW5lciwgfSBmcm9tICcuLi9Gb3JtRmllbGRDb250YWluZXInO1xyXG5pbXBvcnQgeyBEZWZhdWx0RHJvcGRvd25JbmRpY2F0b3IgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6ICdpbmhlcml0J307XG4gICAgbWFyZ2luOiAwIDAgMCAtJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNn07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgei1pbmRleDogMTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gYm9yZGVyQ29sb3JzKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMjAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMDtcclxufVxyXG5jb25zdCBTdHlsZWROYXRpdmVTZWxlY3QgPSBzdHlsZWQuc2VsZWN0IGBcbiAgJHtpbnB1dEJhc2VTdHlsZXN9O1xuICBoZWlnaHQ6IDM4cHg7XG4gIC8vIFJlcXVpcmVkIGZvciBXaW5kb3dzICYmIENocm9tZSBzdXBwb3J0XG4gIGJhY2tncm91bmQ6IGluaGVyaXQ7XG4gID4gb3B0aW9uIHtcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNjAwIDogJ25vbmUnfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkKEZvcm1GaWVsZENvbnRhaW5lcikgYFxuICBkaXNwbGF5OiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCA/ICdmbGV4JyA6ICcnfTtcblxuICAke3Byb3BzID0+IHByb3BzLmFkZGl0aW9uYWxDb250ZW50ICYmXHJcbiAgICBjc3MgYFxuICAgICAgZmxleDogMTtcbiAgICAgIGxhYmVsIHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMDtcbiAgfVxuICBidXR0b24ge1xuICAgIG1hcmdpbjogMCAwIDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBOYXRpdmVTZWxlY3QgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGRpc2FibGVkLCBlcnJvck1lc3NhZ2UsIGlkOiBkZWZhdWx0SWQsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGhhc0xhYmVsID0gISFsYWJlbFRleHQ7XHJcbiAgICBjb25zdCBuYXRpdmVTZWxlY3QgPSAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIHsgYWRkaXRpb25hbENvbnRlbnQ6IGFkZGl0aW9uYWxDb250ZW50LCBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tZm9ybS1maWVsZC1jb250YWluZXJgLCBlcnJvck1lc3NhZ2U6IGVycm9yTWVzc2FnZSwgZmllbGRJZDogaWQsIGhhc0xhYmVsOiAhIWxhYmVsVGV4dCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSA6IChsYWJlbFRleHQpLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgbWVzc2FnZVN0eWxlOiBtZXNzYWdlU3R5bGUsIHJlZjogcmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3RXcmFwcGVyLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0LCBPYmplY3QuYXNzaWduKHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpZDogaWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgb3RoZXIpLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yLCB7IGRpc2FibGVkOiBkaXNhYmxlZCB9KSkpKTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBGb3JtRmllbGRDb250YWluZXIsIE5hdGl2ZVNlbGVjdFdyYXBwZXIsIGFuZCBOYXRpdmVTZWxlY3QgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24udG9wICYmICFoYXNMYWJlbCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBcImRhdGEtdGVzdGlkXCI6IGAke3Rlc3RJZH0tYWRkaXRpb25hbC1jb250ZW50LXdyYXBwZXJgLCB0aGVtZTogdGhlbWUgfSwgcHJvcHMuY2hpbGRyZW4pKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgaWYgKGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIG5hdGl2ZVNlbGVjdCxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgICAgICghbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgcmV0dXJuIG5hdGl2ZVNlbGVjdDtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPU5hdGl2ZVNlbGVjdC5qcy5tYXAiXX0= */"));
5206
+ var StyledNativeSelectWrapper = /*#__PURE__*/typedStyled$h.div(_templateObject$h || (_templateObject$h = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", "\n border: 1px solid ", ";\n svg {\n color: ", ";\n margin: 0 ", " 0 -", ";\n pointer-events: none;\n z-index: 1;\n }\n"])), inputWrapperStyles, borderColors, function (props) {
5207
+ return props.isInverse && props.disabled ? polished.transparentize(0.6, props.theme.colors.neutral100) : props.disabled ? polished.transparentize(0.4, props.theme.colors.neutral500) : props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
5208
+ }, function (props) {
5209
+ return props.theme.spaceScale.spacing03;
5210
+ }, function (props) {
5211
+ return props.theme.spaceScale.spacing08;
5212
+ });
5151
5213
  function borderColors(props) {
5152
5214
  if (props.isInverse) {
5153
5215
  if (props.hasError) {
5154
5216
  return props.theme.colors.danger200;
5155
5217
  }
5218
+ if (props.disabled) {
5219
+ return polished.transparentize(0.85, props.theme.colors.neutral100);
5220
+ }
5156
5221
  return polished.transparentize(0.5, props.theme.colors.neutral100);
5157
5222
  }
5158
5223
  if (props.hasError) {
5159
5224
  return props.theme.colors.danger;
5160
5225
  }
5226
+ if (props.disabled) {
5227
+ return props.theme.colors.neutral300;
5228
+ }
5161
5229
  return props.theme.colors.neutral500;
5162
5230
  }
5163
- var StyledNativeSelect = /*#__PURE__*/_styled$1("select", {
5164
- target: "ek9bqze1",
5165
- label: "StyledNativeSelect"
5166
- })(inputBaseStyles, ";height:38px;background:inherit;> option{background:", function (props) {
5231
+ var StyledNativeSelect = /*#__PURE__*/typedStyled$h.select(_templateObject2$6 || (_templateObject2$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", ";\n height: 38px;\n padding-right: ", ";\n // Required for Windows && Chrome support\n background: inherit;\n > option {\n background: ", ";\n }\n"])), inputBaseStyles, function (props) {
5232
+ return props.theme.spaceScale.spacing08;
5233
+ }, function (props) {
5167
5234
  return props.isInverse ? props.theme.colors.neutral600 : 'none';
5168
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0N5QyIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgdHlwZWRTdHlsZWQgPSBzdHlsZWQ7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApXHJcbiAgICAgICAgOiAnaW5oZXJpdCd9O1xuICAgIG1hcmdpbjogMCAwIDAgLSR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDZ9O1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHotaW5kZXg6IDE7XG4gIH1cbmA7XHJcbmZ1bmN0aW9uIGJvcmRlckNvbG9ycyhwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIGlmIChwcm9wcy5oYXNFcnJvcikge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbn1cclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0ID0gc3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICAvLyBSZXF1aXJlZCBmb3IgV2luZG93cyAmJiBDaHJvbWUgc3VwcG9ydFxuICBiYWNrZ3JvdW5kOiBpbmhlcml0O1xuICA+IG9wdGlvbiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDYwMCA6ICdub25lJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGZsZXg6IDE7XG4gICAgICBsYWJlbCB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBtYXJnaW46IDAgMCAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgTmF0aXZlU2VsZWN0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhZGRpdGlvbmFsQ29udGVudCwgY2hpbGRyZW4sIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgZXJyb3JNZXNzYWdlLCBpZDogZGVmYXVsdElkLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGUsIGxhYmVsVGV4dCwgbGFiZWxXaWR0aCwgbWVzc2FnZVN0eWxlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgY29uc3QgaWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBjb25zdCBoYXNMYWJlbCA9ICEhbGFiZWxUZXh0O1xyXG4gICAgY29uc3QgbmF0aXZlU2VsZWN0ID0gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCB7IGFkZGl0aW9uYWxDb250ZW50OiBhZGRpdGlvbmFsQ29udGVudCwgY29udGFpbmVyU3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWZvcm0tZmllbGQtY29udGFpbmVyYCwgZXJyb3JNZXNzYWdlOiBlcnJvck1lc3NhZ2UsIGZpZWxkSWQ6IGlkLCBoYXNMYWJlbDogISFsYWJlbFRleHQsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGU6IGxhYmVsU3R5bGUsIGxhYmVsVGV4dDogbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkgOiAobGFiZWxUZXh0KSwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhlbHBlck1lc3NhZ2U6IGhlbHBlck1lc3NhZ2UsIG1lc3NhZ2VTdHlsZTogbWVzc2FnZVN0eWxlLCByZWY6IHJlZiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciwgeyBkaXNhYmxlZDogZGlzYWJsZWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZE5hdGl2ZVNlbGVjdCwgT2JqZWN0LmFzc2lnbih7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGRpc2FibGVkOiBkaXNhYmxlZCwgaWQ6IGlkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sIG90aGVyKSwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERlZmF1bHREcm9wZG93bkluZGljYXRvciwgeyBkaXNhYmxlZDogZGlzYWJsZWQgfSkpKSk7XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gJ2xlZnQnIHRoZW4gYSA8ZGl2PiB3cmFwcyB0aGUgRm9ybUZpZWxkQ29udGFpbmVyLCBOYXRpdmVTZWxlY3RXcmFwcGVyLCBhbmQgTmF0aXZlU2VsZWN0IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLnRvcCAmJiAhaGFzTGFiZWwpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiBgJHt0ZXN0SWR9LWFkZGl0aW9uYWwtY29udGVudC13cmFwcGVyYCwgdGhlbWU6IHRoZW1lIH0sIHByb3BzLmNoaWxkcmVuKSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgIH1cclxuICAgIGlmIChhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBuYXRpdmVTZWxlY3QsXHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgICAgICAoIWxhYmVsVGV4dCAmJiBhZGRpdGlvbmFsQ29udGVudCkpKTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIHJldHVybiBuYXRpdmVTZWxlY3Q7XHJcbiAgICB9XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1OYXRpdmVTZWxlY3QuanMubWFwIl19 */"));
5235
+ });
5169
5236
  var _ref$3 = {
5170
5237
  name: "i0lfe0-StyledFormFieldContainer",
5171
5238
  styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;",
5172
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbURRIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBpbnB1dEJhc2VTdHlsZXMsIGlucHV0V3JhcHBlclN0eWxlcyB9IGZyb20gJy4uL0lucHV0QmFzZSc7XHJcbmltcG9ydCB7IEZvcm1GaWVsZENvbnRhaW5lciwgfSBmcm9tICcuLi9Gb3JtRmllbGRDb250YWluZXInO1xyXG5pbXBvcnQgeyBEZWZhdWx0RHJvcGRvd25JbmRpY2F0b3IgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6ICdpbmhlcml0J307XG4gICAgbWFyZ2luOiAwIDAgMCAtJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNn07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgei1pbmRleDogMTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gYm9yZGVyQ29sb3JzKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMjAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMDtcclxufVxyXG5jb25zdCBTdHlsZWROYXRpdmVTZWxlY3QgPSBzdHlsZWQuc2VsZWN0IGBcbiAgJHtpbnB1dEJhc2VTdHlsZXN9O1xuICBoZWlnaHQ6IDM4cHg7XG4gIC8vIFJlcXVpcmVkIGZvciBXaW5kb3dzICYmIENocm9tZSBzdXBwb3J0XG4gIGJhY2tncm91bmQ6IGluaGVyaXQ7XG4gID4gb3B0aW9uIHtcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNjAwIDogJ25vbmUnfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkKEZvcm1GaWVsZENvbnRhaW5lcikgYFxuICBkaXNwbGF5OiAke3Byb3BzID0+IHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCA/ICdmbGV4JyA6ICcnfTtcblxuICAke3Byb3BzID0+IHByb3BzLmFkZGl0aW9uYWxDb250ZW50ICYmXHJcbiAgICBjc3MgYFxuICAgICAgZmxleDogMTtcbiAgICAgIGxhYmVsIHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMDtcbiAgfVxuICBidXR0b24ge1xuICAgIG1hcmdpbjogMCAwIDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBOYXRpdmVTZWxlY3QgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGRpc2FibGVkLCBlcnJvck1lc3NhZ2UsIGlkOiBkZWZhdWx0SWQsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGhhc0xhYmVsID0gISFsYWJlbFRleHQ7XHJcbiAgICBjb25zdCBuYXRpdmVTZWxlY3QgPSAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIHsgYWRkaXRpb25hbENvbnRlbnQ6IGFkZGl0aW9uYWxDb250ZW50LCBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tZm9ybS1maWVsZC1jb250YWluZXJgLCBlcnJvck1lc3NhZ2U6IGVycm9yTWVzc2FnZSwgZmllbGRJZDogaWQsIGhhc0xhYmVsOiAhIWxhYmVsVGV4dCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSA6IChsYWJlbFRleHQpLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgbWVzc2FnZVN0eWxlOiBtZXNzYWdlU3R5bGUsIHJlZjogcmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3RXcmFwcGVyLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0LCBPYmplY3QuYXNzaWduKHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpZDogaWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgb3RoZXIpLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yLCB7IGRpc2FibGVkOiBkaXNhYmxlZCB9KSkpKTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBGb3JtRmllbGRDb250YWluZXIsIE5hdGl2ZVNlbGVjdFdyYXBwZXIsIGFuZCBOYXRpdmVTZWxlY3QgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24udG9wICYmICFoYXNMYWJlbCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBcImRhdGEtdGVzdGlkXCI6IGAke3Rlc3RJZH0tYWRkaXRpb25hbC1jb250ZW50LXdyYXBwZXJgLCB0aGVtZTogdGhlbWUgfSwgcHJvcHMuY2hpbGRyZW4pKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgaWYgKGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIG5hdGl2ZVNlbGVjdCxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgICAgICghbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgcmV0dXJuIG5hdGl2ZVNlbGVjdDtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPU5hdGl2ZVNlbGVjdC5qcy5tYXAiXX0= */",
5239
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNERRIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBpbnB1dEJhc2VTdHlsZXMsIGlucHV0V3JhcHBlclN0eWxlcyB9IGZyb20gJy4uL0lucHV0QmFzZSc7XHJcbmltcG9ydCB7IEZvcm1GaWVsZENvbnRhaW5lciwgfSBmcm9tICcuLi9Gb3JtRmllbGRDb250YWluZXInO1xyXG5pbXBvcnQgeyBEZWZhdWx0RHJvcGRvd25JbmRpY2F0b3IgfSBmcm9tICcuLi9TZWxlY3QvY29tcG9uZW50cyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gICR7aW5wdXRXcmFwcGVyU3R5bGVzfVxuICBib3JkZXI6IDFweCBzb2xpZCAke2JvcmRlckNvbG9yc307XG4gIHN2ZyB7XG4gICAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlICYmIHByb3BzLmRpc2FibGVkXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNiwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLmRpc2FibGVkXHJcbiAgICAgICAgPyB0cmFuc3BhcmVudGl6ZSgwLjQsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwKVxyXG4gICAgICAgIDogcHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgICAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgLSR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDh9O1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHotaW5kZXg6IDE7XG4gIH1cbmA7XHJcbmZ1bmN0aW9uIGJvcmRlckNvbG9ycyhwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIGlmIChwcm9wcy5oYXNFcnJvcikge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHByb3BzLmRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjg1LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgIH1cclxuICAgIGlmIChwcm9wcy5oYXNFcnJvcikge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmRpc2FibGVkKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdCA9IHR5cGVkU3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICBwYWRkaW5nLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgLy8gUmVxdWlyZWQgZm9yIFdpbmRvd3MgJiYgQ2hyb21lIHN1cHBvcnRcbiAgYmFja2dyb3VuZDogaW5oZXJpdDtcbiAgPiBvcHRpb24ge1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw2MDAgOiAnbm9uZSd9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRGb3JtRmllbGRDb250YWluZXIgPSB0eXBlZFN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGZsZXg6IDE7XG4gICAgICBsYWJlbCB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBtYXJnaW46IDAgMCAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgTmF0aXZlU2VsZWN0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhZGRpdGlvbmFsQ29udGVudCwgY2hpbGRyZW4sIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgZXJyb3JNZXNzYWdlLCBpZDogZGVmYXVsdElkLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGUsIGxhYmVsVGV4dCwgbGFiZWxXaWR0aCwgbWVzc2FnZVN0eWxlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgY29uc3QgaWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBjb25zdCBoYXNMYWJlbCA9ICEhbGFiZWxUZXh0O1xyXG4gICAgY29uc3QgbmF0aXZlU2VsZWN0ID0gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCB7IGFkZGl0aW9uYWxDb250ZW50OiBhZGRpdGlvbmFsQ29udGVudCwgY29udGFpbmVyU3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWZvcm0tZmllbGQtY29udGFpbmVyYCwgZXJyb3JNZXNzYWdlOiBlcnJvck1lc3NhZ2UsIGZpZWxkSWQ6IGlkLCBoYXNMYWJlbDogISFsYWJlbFRleHQsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGU6IGxhYmVsU3R5bGUsIGxhYmVsVGV4dDogbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkgOiAobGFiZWxUZXh0KSwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhlbHBlck1lc3NhZ2U6IGhlbHBlck1lc3NhZ2UsIG1lc3NhZ2VTdHlsZTogbWVzc2FnZVN0eWxlLCByZWY6IHJlZiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciwgeyBkaXNhYmxlZDogZGlzYWJsZWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZE5hdGl2ZVNlbGVjdCwgT2JqZWN0LmFzc2lnbih7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGRpc2FibGVkOiBkaXNhYmxlZCwgaWQ6IGlkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sIG90aGVyKSwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERlZmF1bHREcm9wZG93bkluZGljYXRvciwgeyBkaXNhYmxlZDogZGlzYWJsZWQgfSkpKSk7XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gJ2xlZnQnIHRoZW4gYSA8ZGl2PiB3cmFwcyB0aGUgRm9ybUZpZWxkQ29udGFpbmVyLCBOYXRpdmVTZWxlY3RXcmFwcGVyLCBhbmQgTmF0aXZlU2VsZWN0IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLnRvcCAmJiAhaGFzTGFiZWwpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiBgJHt0ZXN0SWR9LWFkZGl0aW9uYWwtY29udGVudC13cmFwcGVyYCwgdGhlbWU6IHRoZW1lIH0sIHByb3BzLmNoaWxkcmVuKSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgIH1cclxuICAgIGlmIChhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBuYXRpdmVTZWxlY3QsXHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgICAgICAoIWxhYmVsVGV4dCAmJiBhZGRpdGlvbmFsQ29udGVudCkpKTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIHJldHVybiBuYXRpdmVTZWxlY3Q7XHJcbiAgICB9XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1OYXRpdmVTZWxlY3QuanMubWFwIl19 */",
5173
5240
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$e
5174
5241
  };
5175
- var StyledFormFieldContainer$1 = /*#__PURE__*/ /*#__PURE__*/_styled$1(FormFieldContainer, {
5176
- target: "ek9bqze2",
5177
- label: "StyledFormFieldContainer"
5178
- })("display:", function (props) {
5242
+ var StyledFormFieldContainer$1 = /*#__PURE__*/typedStyled$h(FormFieldContainer)(_templateObject3$4 || (_templateObject3$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: ", ";\n\n ", "\n"])), function (props) {
5179
5243
  return props.labelPosition === exports.LabelPosition.left ? 'flex' : '';
5180
- }, ";", function (props) {
5244
+ }, function (props) {
5181
5245
  return props.additionalContent && _ref$3;
5182
- }, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0M0RCIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgdHlwZWRTdHlsZWQgPSBzdHlsZWQ7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApXHJcbiAgICAgICAgOiAnaW5oZXJpdCd9O1xuICAgIG1hcmdpbjogMCAwIDAgLSR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDZ9O1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICAgIHotaW5kZXg6IDE7XG4gIH1cbmA7XHJcbmZ1bmN0aW9uIGJvcmRlckNvbG9ycyhwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIGlmIChwcm9wcy5oYXNFcnJvcikge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbn1cclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0ID0gc3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICAvLyBSZXF1aXJlZCBmb3IgV2luZG93cyAmJiBDaHJvbWUgc3VwcG9ydFxuICBiYWNrZ3JvdW5kOiBpbmhlcml0O1xuICA+IG9wdGlvbiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDYwMCA6ICdub25lJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGZsZXg6IDE7XG4gICAgICBsYWJlbCB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgbGFiZWwge1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIDA7XG4gIH1cbiAgYnV0dG9uIHtcbiAgICBtYXJnaW46IDAgMCAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgTmF0aXZlU2VsZWN0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhZGRpdGlvbmFsQ29udGVudCwgY2hpbGRyZW4sIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgZXJyb3JNZXNzYWdlLCBpZDogZGVmYXVsdElkLCBoZWxwZXJNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGUsIGxhYmVsVGV4dCwgbGFiZWxXaWR0aCwgbWVzc2FnZVN0eWxlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKGlzSW52ZXJzZVByb3ApO1xyXG4gICAgY29uc3QgaWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBjb25zdCBoYXNMYWJlbCA9ICEhbGFiZWxUZXh0O1xyXG4gICAgY29uc3QgbmF0aXZlU2VsZWN0ID0gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCB7IGFkZGl0aW9uYWxDb250ZW50OiBhZGRpdGlvbmFsQ29udGVudCwgY29udGFpbmVyU3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWZvcm0tZmllbGQtY29udGFpbmVyYCwgZXJyb3JNZXNzYWdlOiBlcnJvck1lc3NhZ2UsIGZpZWxkSWQ6IGlkLCBoYXNMYWJlbDogISFsYWJlbFRleHQsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGU6IGxhYmVsU3R5bGUsIGxhYmVsVGV4dDogbGFiZWxQb3NpdGlvbiAhPT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkgOiAobGFiZWxUZXh0KSwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhlbHBlck1lc3NhZ2U6IGhlbHBlck1lc3NhZ2UsIG1lc3NhZ2VTdHlsZTogbWVzc2FnZVN0eWxlLCByZWY6IHJlZiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciwgeyBkaXNhYmxlZDogZGlzYWJsZWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZE5hdGl2ZVNlbGVjdCwgT2JqZWN0LmFzc2lnbih7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGRpc2FibGVkOiBkaXNhYmxlZCwgaWQ6IGlkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sIG90aGVyKSwgY2hpbGRyZW4pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERlZmF1bHREcm9wZG93bkluZGljYXRvciwgeyBkaXNhYmxlZDogZGlzYWJsZWQgfSkpKSk7XHJcbiAgICAvLyBJZiB0aGUgbGFiZWxQb3NpdGlvbiBpcyBzZXQgdG8gJ2xlZnQnIHRoZW4gYSA8ZGl2PiB3cmFwcyB0aGUgRm9ybUZpZWxkQ29udGFpbmVyLCBOYXRpdmVTZWxlY3RXcmFwcGVyLCBhbmQgTmF0aXZlU2VsZWN0IGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbiAgICBmdW5jdGlvbiBBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0IHx8XHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLnRvcCAmJiAhaGFzTGFiZWwpKSB7XHJcbiAgICAgICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgXCJkYXRhLXRlc3RpZFwiOiBgJHt0ZXN0SWR9LWFkZGl0aW9uYWwtY29udGVudC13cmFwcGVyYCwgdGhlbWU6IHRoZW1lIH0sIHByb3BzLmNoaWxkcmVuKSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgIH1cclxuICAgIGlmIChhZGRpdGlvbmFsQ29udGVudCkge1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBZGRpdGlvbmFsQ29udGVudFdyYXBwZXIsIHsgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9LFxyXG4gICAgICAgICAgICBuYXRpdmVTZWxlY3QsXHJcbiAgICAgICAgICAgIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQpIHx8XHJcbiAgICAgICAgICAgICAgICAoIWxhYmVsVGV4dCAmJiBhZGRpdGlvbmFsQ29udGVudCkpKTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIHJldHVybiBuYXRpdmVTZWxlY3Q7XHJcbiAgICB9XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1OYXRpdmVTZWxlY3QuanMubWFwIl19 */");
5183
- var StyledAdditionalContentWrapper = /*#__PURE__*/typedStyled$h.div(_templateObject$h || (_templateObject$h = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n display: flex;\n label {\n margin: 0 ", " 0 0;\n }\n button {\n margin: 0 0 0 ", ";\n }\n"])), function (props) {
5246
+ });
5247
+ var StyledAdditionalContentWrapper = /*#__PURE__*/typedStyled$h.div(_templateObject4$2 || (_templateObject4$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n display: flex;\n label {\n margin: 0 ", " 0 0;\n }\n button {\n margin: 0 0 0 ", ";\n }\n"])), function (props) {
5184
5248
  return props.theme.spaceScale.spacing03;
5185
5249
  }, function (props) {
5186
5250
  return props.theme.spaceScale.spacing03;
@@ -5402,7 +5466,7 @@ var TablePagination = /*#__PURE__*/React.forwardRef(function (props, ref) {
5402
5466
  });
5403
5467
 
5404
5468
  var _excluded$C = ["children", "headerRowStatus", "isSelected", "isSelectableDisabled", "sortDirection", "onHeaderRowSelect", "onTableRowSelect", "rowIndex", "onSort", "testId"];
5405
- var _templateObject$i, _templateObject2$6, _templateObject3$4;
5469
+ var _templateObject$i, _templateObject2$7, _templateObject3$5;
5406
5470
  var typedStyled$i = _styled;
5407
5471
  function buildTableRowBackground(props) {
5408
5472
  if (props.isInverse) {
@@ -5450,14 +5514,14 @@ var StyledTableRow = /*#__PURE__*/typedStyled$i.tr(_templateObject$i || (_templa
5450
5514
  }, function (props) {
5451
5515
  return props.color && /*#__PURE__*/core.css("background:", buildTableRowBackground(props), ";color:", buildTableRowColor(props), ";;label:StyledTableRow;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TableRow.tsx"],"names":[],"mappings":"AAkFQ","file":"TableRow.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport { TableContext, TableRowColor, TableCell, TableHeaderCell, TableCellAlign, TableSortDirection, } from './';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, } from '../IndeterminateCheckbox';\r\nimport { transparentize } from 'polished';\r\nimport { NorthIcon, SortDoubleArrowIcon, SouthIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nfunction buildTableRowBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.color) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            case 'info':\r\n                return props.theme.colors.info200;\r\n            default:\r\n                return 'inherit';\r\n        }\r\n    }\r\n    switch (props.color) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        case 'info':\r\n            return props.theme.colors.info;\r\n        default:\r\n            return 'inherit';\r\n    }\r\n}\r\nfunction buildTableRowColor(props) {\r\n    if (props.color && props.isInverse) {\r\n        return props.theme.colors.neutral700;\r\n    }\r\n    if (props.color && !props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    return 'inherit';\r\n}\r\nconst StyledTableRow = typedStyled.tr `\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  color: inherit;\n  display: table-row;\n  outline: 0;\n  vertical-align: top;\n\n  &:last-child {\n    border-bottom: 0;\n  }\n\n  ${props => !props.color &&\r\n    css `\n      &:nth-of-type(even) {\n        background: ${props.hasZebraStripes\r\n        ? props.isInverse\r\n            ? transparentize(0.93, props.theme.colors.neutral100)\r\n            : props.theme.colors.neutral200\r\n        : 'none'};\n      }\n    `};\n\n  ${props => props.hasHoverStyles &&\r\n    !props.color &&\r\n    css `\n    &:hover {\n      background: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : transparentize(0.93, props.theme.colors.neutral900)};\n    `}\n\n  ${props => props.color &&\r\n    css `\n      background: ${buildTableRowBackground(props)};\n      color: ${buildTableRowColor(props)};\n    `};\n`;\r\nconst SortButton = typedStyled.button `\n  align-items: flex-end;\n  background: none;\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  margin: 0;\n  text-align: left;\n  width: 100%;\n  flex: 1 1 auto;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -2px;\n  }\n\n  &:hover,\n  &:focus {\n    cursor: pointer;\n    svg {\n      fill: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n    }\n  }\n`;\r\nconst SortIconWrapper = typedStyled.span `\n  position: relative;\n  top: ${props => props.theme.spaceScale.spacing01};\n`;\r\nexport const TableRow = React.forwardRef((props, ref) => {\r\n    const { children, headerRowStatus, isSelected, isSelectableDisabled, sortDirection, onHeaderRowSelect, onTableRowSelect, rowIndex, onSort, testId, ...other } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const tableContext = React.useContext(TableContext);\r\n    let isHeaderRow = false;\r\n    React.Children.forEach(children, (child) => {\r\n        if (child.type.displayName === 'TableHeaderCell') {\r\n            isHeaderRow = true;\r\n            return;\r\n        }\r\n    });\r\n    function getIsCheckboxInverse() {\r\n        if (props.color && props.color === TableRowColor.warning) {\r\n            return false;\r\n        }\r\n        if (props.color && props.color !== TableRowColor.warning) {\r\n            return true;\r\n        }\r\n        return tableContext.isInverse;\r\n    }\r\n    const [isHovering, setIsHovering] = React.useState(false);\r\n    const handleMouseEnter = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(true);\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (tableContext.isSortableBySelected)\r\n            setIsHovering(false);\r\n    };\r\n    function handleSort() {\r\n        onSort && typeof onSort === 'function' && onSort();\r\n    }\r\n    const SortIcon = sortDirection === TableSortDirection.ascending ? (React.createElement(NorthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-ascending\" })) : sortDirection === TableSortDirection.descending ? (React.createElement(SouthIcon, { color: tableContext.isInverse\r\n            ? theme.colors.neutral100\r\n            : theme.colors.neutral700, size: theme.iconSizes.small, testId: \"sort-descending\" })) : (React.createElement(SortDoubleArrowIcon, { color: tableContext.isInverse\r\n            ? transparentize(0.3, theme.colors.neutral100)\r\n            : theme.colors.neutral500, size: theme.iconSizes.small, testId: \"sort-none\" }));\r\n    return (React.createElement(StyledTableRow, Object.assign({}, other, { \"data-testid\": testId, hasHoverStyles: tableContext.hasHoverStyles && !isHeaderRow, hasZebraStripes: tableContext.hasZebraStripes, isInverse: tableContext.isInverse, ref: ref, theme: theme }),\r\n        tableContext.isSelectable && isHeaderRow && (React.createElement(TableHeaderCell, { width: theme.spaceScale.spacing05, style: {\r\n                background: isHovering\r\n                    ? transparentize(0.93, theme.colors.neutral900)\r\n                    : '',\r\n            } },\r\n            React.createElement(\"span\", { style: { display: 'flex', flexDirection: 'row' } },\r\n                React.createElement(IndeterminateCheckbox, { status: headerRowStatus, isInverse: getIsCheckboxInverse(), labelStyle: { padding: 0 }, labelText: \"Select all rows\", isTextVisuallyHidden: true, onChange: onHeaderRowSelect }),\r\n                tableContext.isSortableBySelected && (React.createElement(SortButton, { density: tableContext.density, isInverse: tableContext.isInverse, onClick: handleSort, textAlign: TableCellAlign.left, theme: theme, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, \"data-testid\": `${testId || ''}-sort-button`, \"aria-label\": \"Sort rows\" },\r\n                    React.createElement(SortIconWrapper, { theme: theme }, SortIcon)))))),\r\n        tableContext.isSelectable && !isHeaderRow && (React.createElement(TableCell, { width: theme.spaceScale.spacing05, style: { verticalAlign: 'middle' } },\r\n            React.createElement(Checkbox, { checked: isSelected, disabled: isSelectableDisabled, labelStyle: { padding: 0 }, labelText: `Select row ${rowIndex} of ${tableContext.rowCount}`, isTextVisuallyHidden: true, isInverse: getIsCheckboxInverse(), onChange: onTableRowSelect }))),\r\n        children));\r\n});\r\n//# sourceMappingURL=TableRow.js.map"]} */"));
5452
5516
  });
5453
- var SortButton$1 = /*#__PURE__*/typedStyled$i.button(_templateObject2$6 || (_templateObject2$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: flex-end;\n background: none;\n border: 0;\n color: ", ";\n margin: 0;\n text-align: left;\n width: 100%;\n flex: 1 1 auto;\n\n &:focus {\n outline: 2px solid\n ", ";\n outline-offset: -2px;\n }\n\n &:hover,\n &:focus {\n cursor: pointer;\n svg {\n fill: ", ";\n }\n }\n"])), function (props) {
5517
+ var SortButton$1 = /*#__PURE__*/typedStyled$i.button(_templateObject2$7 || (_templateObject2$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: flex-end;\n background: none;\n border: 0;\n color: ", ";\n margin: 0;\n text-align: left;\n width: 100%;\n flex: 1 1 auto;\n\n &:focus {\n outline: 2px solid\n ", ";\n outline-offset: -2px;\n }\n\n &:hover,\n &:focus {\n cursor: pointer;\n svg {\n fill: ", ";\n }\n }\n"])), function (props) {
5454
5518
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
5455
5519
  }, function (props) {
5456
5520
  return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
5457
5521
  }, function (props) {
5458
5522
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
5459
5523
  });
5460
- var SortIconWrapper = /*#__PURE__*/typedStyled$i.span(_templateObject3$4 || (_templateObject3$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n top: ", ";\n"])), function (props) {
5524
+ var SortIconWrapper = /*#__PURE__*/typedStyled$i.span(_templateObject3$5 || (_templateObject3$5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n position: relative;\n top: ", ";\n"])), function (props) {
5461
5525
  return props.theme.spaceScale.spacing01;
5462
5526
  });
5463
5527
  var TableRow = /*#__PURE__*/React.forwardRef(function (props, ref) {
@@ -5739,7 +5803,7 @@ var CalendarContext = /*#__PURE__*/React.createContext({
5739
5803
  });
5740
5804
 
5741
5805
  var _excluded$E = ["arrowStyle", "children", "content", "containerStyle", "id", "position", "testId", "tooltipStyle"];
5742
- var _templateObject$j, _templateObject2$7;
5806
+ var _templateObject$j, _templateObject2$8;
5743
5807
  function _EMOTION_STRINGIFIED_CSS_ERROR__$f() { 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)."; }
5744
5808
  (function (TooltipPosition) {
5745
5809
  TooltipPosition["bottom"] = "bottom";
@@ -5765,7 +5829,7 @@ var TooltipArrow = /*#__PURE__*/typedStyled$j.span(_templateObject$j || (_templa
5765
5829
  }, function (props) {
5766
5830
  return props.isInverse ? props.theme.tooltip.inverse.backgroundColor : props.theme.tooltip.backgroundColor;
5767
5831
  });
5768
- var StyledTooltip = /*#__PURE__*/typedStyled$j.div(_templateObject2$7 || (_templateObject2$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n border-radius: ", ";\n color: ", ";\n font-size: ", ";\n font-family: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n font-weight: ", ";\n max-width: ", ";\n min-height: 2.5em;\n padding: ", "\n ", ";\n z-index: ", ";\n\n &[data-popper-placement='top'] {\n margin-bottom: 14px;\n & > span:last-child {\n bottom: 10px;\n }\n }\n\n &[data-popper-placement='bottom'] {\n margin-top: 14px;\n & > span:last-child {\n top: 10px;\n }\n }\n\n &[data-popper-placement='left'] {\n margin-right: 14px;\n & > span:last-child {\n right: 10px;\n }\n }\n\n &[data-popper-placement='right'] {\n margin-left: 14px;\n & > span:last-child {\n left: 10px;\n }\n }\n"])), function (props) {
5832
+ var StyledTooltip = /*#__PURE__*/typedStyled$j.div(_templateObject2$8 || (_templateObject2$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n border-radius: ", ";\n color: ", ";\n font-size: ", ";\n font-family: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n font-weight: ", ";\n max-width: ", ";\n min-height: 2.5em;\n padding: ", "\n ", ";\n z-index: ", ";\n\n &[data-popper-placement='top'] {\n margin-bottom: 14px;\n & > span:last-child {\n bottom: 10px;\n }\n }\n\n &[data-popper-placement='bottom'] {\n margin-top: 14px;\n & > span:last-child {\n top: 10px;\n }\n }\n\n &[data-popper-placement='left'] {\n margin-right: 14px;\n & > span:last-child {\n right: 10px;\n }\n }\n\n &[data-popper-placement='right'] {\n margin-left: 14px;\n & > span:last-child {\n left: 10px;\n }\n }\n"])), function (props) {
5769
5833
  return props.isInverse ? props.theme.tooltip.inverse.backgroundColor : props.theme.tooltip.backgroundColor;
5770
5834
  }, function (props) {
5771
5835
  return props.theme.borderRadius;
@@ -5983,7 +6047,7 @@ function getDateFromString(date) {
5983
6047
  return date ? date instanceof Date ? date : new Date(date) : null;
5984
6048
  }
5985
6049
 
5986
- var _templateObject$k, _templateObject2$8, _templateObject3$5;
6050
+ var _templateObject$k, _templateObject2$9, _templateObject3$6;
5987
6051
  var typedStyled$k = _styled;
5988
6052
  var CalendarHeaderContainer = /*#__PURE__*/typedStyled$k.div(_templateObject$k || (_templateObject$k = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n display: flex;\n padding: ", " 0\n ", ";\n margin-top: -", ";\n"])), function (props) {
5989
6053
  return props.theme.spaceScale.spacing10;
@@ -5992,10 +6056,10 @@ var CalendarHeaderContainer = /*#__PURE__*/typedStyled$k.div(_templateObject$k |
5992
6056
  }, function (props) {
5993
6057
  return props.theme.spaceScale.spacing01;
5994
6058
  });
5995
- var CalendarIconButton = /*#__PURE__*/typedStyled$k.div(_templateObject2$8 || (_templateObject2$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n flex-grow: 0;\n flex-width: 10%;\n flex-basis: 10%;\n order: ", ";\n"])), function (props) {
6059
+ var CalendarIconButton = /*#__PURE__*/typedStyled$k.div(_templateObject2$9 || (_templateObject2$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n flex-grow: 0;\n flex-width: 10%;\n flex-basis: 10%;\n order: ", ";\n"])), function (props) {
5996
6060
  return props.next ? 2 : 0;
5997
6061
  });
5998
- var CalendarHeaderText = /*#__PURE__*/typedStyled$k.div(_templateObject3$5 || (_templateObject3$5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n caption-side: initial;\n color: ", ";\n font-size: ", ";\n line-height: ", ";\n order: 1;\n text-align: center;\n flex-grow: 0;\n flex-width: 90%;\n flex-basis: 90%;\n &:focus {\n outline: 2px solid\n ", ";\n"])), function (props) {
6062
+ var CalendarHeaderText = /*#__PURE__*/typedStyled$k.div(_templateObject3$6 || (_templateObject3$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n caption-side: initial;\n color: ", ";\n font-size: ", ";\n line-height: ", ";\n order: 1;\n text-align: center;\n flex-grow: 0;\n flex-width: 90%;\n flex-basis: 90%;\n &:focus {\n outline: 2px solid\n ", ";\n"])), function (props) {
5999
6063
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
6000
6064
  }, function (props) {
6001
6065
  return props.theme.typeScale.size03.fontSize;
@@ -6052,7 +6116,7 @@ var CalendarHeader = /*#__PURE__*/React.forwardRef(function (props, forwardedRef
6052
6116
  })));
6053
6117
  });
6054
6118
 
6055
- var _templateObject$l, _templateObject2$9, _templateObject3$6, _templateObject4$2;
6119
+ var _templateObject$l, _templateObject2$a, _templateObject3$7, _templateObject4$3;
6056
6120
  var typedStyled$l = _styled;
6057
6121
  function buildCalendarDayBackground(props) {
6058
6122
  if (props.isInverse) {
@@ -6099,7 +6163,7 @@ var CalendarDayCell = /*#__PURE__*/typedStyled$l.td(_templateObject$l || (_templ
6099
6163
  }, function (props) {
6100
6164
  return props.theme.spaceScale.spacing09;
6101
6165
  });
6102
- var CalendarDayInner = /*#__PURE__*/typedStyled$l.button(_templateObject2$9 || (_templateObject2$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n background: ", ";\n border: 2px solid transparent;\n border-radius: 100%;\n color: ", ";\n cursor: ", ";\n display: flex;\n height: calc(", " - 4px);\n justify-content: center;\n margin: ", ";\n overflow: hidden;\n outline-offset: 0;\n position: relative;\n transition: background 0.5s ease-in-out 0s;\n width: calc(", " - 4px);\n\n &:focus {\n outline: 2px solid\n ", ";\n }\n\n &:before {\n background: ", ";\n content: '';\n height: 200%;\n left: 0;\n opacity: 0;\n position: absolute;\n top: -50%;\n transition: 0.2s;\n width: 200%;\n }\n\n &:hover {\n &:before {\n opacity: ", ";\n }\n }\n"])), function (props) {
6166
+ var CalendarDayInner = /*#__PURE__*/typedStyled$l.button(_templateObject2$a || (_templateObject2$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: center;\n background: ", ";\n border: 2px solid transparent;\n border-radius: 100%;\n color: ", ";\n cursor: ", ";\n display: flex;\n height: calc(", " - 4px);\n justify-content: center;\n margin: ", ";\n overflow: hidden;\n outline-offset: 0;\n position: relative;\n transition: background 0.5s ease-in-out 0s;\n width: calc(", " - 4px);\n\n &:focus {\n outline: 2px solid\n ", ";\n }\n\n &:before {\n background: ", ";\n content: '';\n height: 200%;\n left: 0;\n opacity: 0;\n position: absolute;\n top: -50%;\n transition: 0.2s;\n width: 200%;\n }\n\n &:hover {\n &:before {\n opacity: ", ";\n }\n }\n"])), function (props) {
6103
6167
  return buildCalendarDayBackground(props);
6104
6168
  }, function (props) {
6105
6169
  return buildCalendarDayColor(props);
@@ -6118,8 +6182,8 @@ var CalendarDayInner = /*#__PURE__*/typedStyled$l.button(_templateObject2$9 || (
6118
6182
  }, function (props) {
6119
6183
  return props.disabled ? 0 : 0.1;
6120
6184
  });
6121
- var EmptyCell = /*#__PURE__*/typedStyled$l.td(_templateObject3$6 || (_templateObject3$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n padding: 0;\n"])));
6122
- var TodayIndicator = /*#__PURE__*/typedStyled$l.span(_templateObject4$2 || (_templateObject4$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border-left: 8px solid\n ", ";\n border-top: 8px solid transparent;\n border-bottom: 8px solid transparent;\n bottom: -6px;\n display: block;\n height: 0;\n position: absolute;\n transform: rotate(45deg);\n right: -2px;\n width: 0;\n"])), function (props) {
6185
+ var EmptyCell = /*#__PURE__*/typedStyled$l.td(_templateObject3$7 || (_templateObject3$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n padding: 0;\n"])));
6186
+ var TodayIndicator = /*#__PURE__*/typedStyled$l.span(_templateObject4$3 || (_templateObject4$3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border-left: 8px solid\n ", ";\n border-top: 8px solid transparent;\n border-bottom: 8px solid transparent;\n bottom: -6px;\n display: block;\n height: 0;\n position: absolute;\n transform: rotate(45deg);\n right: -2px;\n width: 0;\n"])), function (props) {
6123
6187
  return props.isInverse ? props.theme.colors.secondary : props.theme.colors.primary;
6124
6188
  });
6125
6189
  var CalendarDay = function CalendarDay(props) {
@@ -6193,16 +6257,16 @@ var CalendarDay = function CalendarDay(props) {
6193
6257
  }
6194
6258
  };
6195
6259
 
6196
- var _templateObject$m, _templateObject2$a, _templateObject3$7, _templateObject4$3, _templateObject5$1;
6260
+ var _templateObject$m, _templateObject2$b, _templateObject3$8, _templateObject4$4, _templateObject5$1;
6197
6261
  function _EMOTION_STRINGIFIED_CSS_ERROR__$g() { 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)."; }
6198
6262
  var typedStyled$m = _styled;
6199
6263
  var List = /*#__PURE__*/typedStyled$m.ul(_templateObject$m || (_templateObject$m = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n list-style: none;\n margin: 0;\n padding: 0;\n text-align: left;\n"])));
6200
- var Item = /*#__PURE__*/typedStyled$m.li(_templateObject2$a || (_templateObject2$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n list-style: none;\n margin-bottom: 12px;\n font-size: ", ";\n line-height: ", ";\n align-items: center;\n span {\n flex: 0 0 100px;\n overflow: hidden;\n line-height: 28px;\n min-height: 36px;\n height: max-content;\n text-align: center;\n }\n div {\n flex: 1;\n }\n"])), function (props) {
6264
+ var Item = /*#__PURE__*/typedStyled$m.li(_templateObject2$b || (_templateObject2$b = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n list-style: none;\n margin-bottom: 12px;\n font-size: ", ";\n line-height: ", ";\n align-items: center;\n span {\n flex: 0 0 100px;\n overflow: hidden;\n line-height: 28px;\n min-height: 36px;\n height: max-content;\n text-align: center;\n }\n div {\n flex: 1;\n }\n"])), function (props) {
6201
6265
  return props.theme.typeScale.size02.fontSize;
6202
6266
  }, function (props) {
6203
6267
  return props.theme.typeScale.size02.lineHeight;
6204
6268
  });
6205
- var KeyboardShortcutButtonWrapper = /*#__PURE__*/typedStyled$m.span(_templateObject3$7 || (_templateObject3$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n font-family: monospace;\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-right: ", ";\n text-transform: uppercase;\n padding: ", "\n ", ";\n"])), function (props) {
6269
+ var KeyboardShortcutButtonWrapper = /*#__PURE__*/typedStyled$m.span(_templateObject3$8 || (_templateObject3$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n font-family: monospace;\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-right: ", ";\n text-transform: uppercase;\n padding: ", "\n ", ";\n"])), function (props) {
6206
6270
  return props.isInverse ? props.theme.colors.primary400 : props.theme.colors.neutral200;
6207
6271
  }, function (props) {
6208
6272
  return props.theme.typeScale.size02.fontSize;
@@ -6235,7 +6299,7 @@ var StyledNavContainer = /*#__PURE__*/_styled$1("div", {
6235
6299
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAoDsC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst List = typedStyled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = typedStyled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = typedStyled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  justify-content: space-between;\n  padding: 2px;\n`;\r\nconst StyledContent = typedStyled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = typedStyled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\r\n        React.createElement(StyledNavContainer, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onClose }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
6236
6300
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
6237
6301
  });
6238
- var StyledContent = /*#__PURE__*/typedStyled$m.div(_templateObject4$3 || (_templateObject4$3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n z-index: 9999;\n position: relative;\n color: ", ";\n\n h2 {\n margin: 10px 0 12px 0;\n }\n"])), function (props) {
6302
+ var StyledContent = /*#__PURE__*/typedStyled$m.div(_templateObject4$4 || (_templateObject4$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n z-index: 9999;\n position: relative;\n color: ", ";\n\n h2 {\n margin: 10px 0 12px 0;\n }\n"])), function (props) {
6239
6303
  var _props$theme, _props$theme$colors, _props$theme2, _props$theme2$colors;
6240
6304
  return props.isInverse ? props == null ? void 0 : (_props$theme = props.theme) == null ? void 0 : (_props$theme$colors = _props$theme.colors) == null ? void 0 : _props$theme$colors.neutral100 : props == null ? void 0 : (_props$theme2 = props.theme) == null ? void 0 : (_props$theme2$colors = _props$theme2.colors) == null ? void 0 : _props$theme2$colors.neutral700;
6241
6305
  });
@@ -6422,7 +6486,7 @@ function useFocusLock(active, header, body) {
6422
6486
  return rootNode;
6423
6487
  }
6424
6488
 
6425
- var _templateObject$n, _templateObject2$b, _templateObject3$8, _templateObject4$4;
6489
+ var _templateObject$n, _templateObject2$c, _templateObject3$9, _templateObject4$5;
6426
6490
  var typedStyled$n = _styled;
6427
6491
  var CalendarContainer = /*#__PURE__*/typedStyled$n.div(_templateObject$n || (_templateObject$n = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n padding: 0 ", "\n ", ";\n overflow: visible;\n"])), function (props) {
6428
6492
  return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
@@ -6431,15 +6495,15 @@ var CalendarContainer = /*#__PURE__*/typedStyled$n.div(_templateObject$n || (_te
6431
6495
  }, function (props) {
6432
6496
  return props.theme.spaceScale.spacing03;
6433
6497
  });
6434
- var MonthContainer = /*#__PURE__*/typedStyled$n.div(_templateObject2$b || (_templateObject2$b = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n font-family: ", ";\n text-align: center;\n user-select: none;\n vertical-align: top;\n"])), function (props) {
6498
+ var MonthContainer = /*#__PURE__*/typedStyled$n.div(_templateObject2$c || (_templateObject2$c = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n font-family: ", ";\n text-align: center;\n user-select: none;\n vertical-align: top;\n"])), function (props) {
6435
6499
  return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
6436
6500
  }, function (props) {
6437
6501
  return props.theme.bodyFont;
6438
6502
  });
6439
- var Table$1 = /*#__PURE__*/typedStyled$n.table(_templateObject3$8 || (_templateObject3$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border-collapse: collapse;\n border-spacing: 0;\n margin-bottom: ", ";\n"])), function (props) {
6503
+ var Table$1 = /*#__PURE__*/typedStyled$n.table(_templateObject3$9 || (_templateObject3$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border-collapse: collapse;\n border-spacing: 0;\n margin-bottom: ", ";\n"])), function (props) {
6440
6504
  return props.theme.spaceScale.spacing03;
6441
6505
  });
6442
- var Th = /*#__PURE__*/typedStyled$n.th(_templateObject4$4 || (_templateObject4$4 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n color: ", ";\n font-size: ", ";\n line-height: ", ";\n font-weight: normal;\n padding: 0;\n text-align: center;\n"])), function (props) {
6506
+ var Th = /*#__PURE__*/typedStyled$n.th(_templateObject4$5 || (_templateObject4$5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n color: ", ";\n font-size: ", ";\n line-height: ", ";\n font-weight: normal;\n padding: 0;\n text-align: center;\n"])), function (props) {
6443
6507
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
6444
6508
  }, function (props) {
6445
6509
  return props.theme.typeScale.size02.fontSize;
@@ -6455,7 +6519,7 @@ var HelperButton = /*#__PURE__*/_styled$1("span", {
6455
6519
  return props.theme.spaceScale.spacing01;
6456
6520
  }, ";position:absolute;left:", function (props) {
6457
6521
  return props.theme.spaceScale.spacing01;
6458
- }, ";z-index:2;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAgDiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst CalendarContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n`;\r\nconst Table = typedStyled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Th = typedStyled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const days = [\r\n        'sunday',\r\n        'monday',\r\n        'tuesday',\r\n        'wednesday',\r\n        'thursday',\r\n        'friday',\r\n        'saturday',\r\n    ];\r\n    const startOfWeek = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse }, i18n.days.min[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onClose: context.hideHelperInformation })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: focusTrapElement },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { role: \"presentation\", onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
6522
+ }, ";z-index:2;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAgDiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst CalendarContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n`;\r\nconst Table = typedStyled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Th = typedStyled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const days = [\r\n        'sunday',\r\n        'monday',\r\n        'tuesday',\r\n        'wednesday',\r\n        'thursday',\r\n        'friday',\r\n        'saturday',\r\n    ];\r\n    const startOfWeek = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse }, i18n.days.min[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onClose: context.hideHelperInformation })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: focusTrapElement },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
6459
6523
  var CloseButton = /*#__PURE__*/_styled$1("span", {
6460
6524
  target: "eeao89h1",
6461
6525
  label: "CloseButton"
@@ -6465,7 +6529,7 @@ var CloseButton = /*#__PURE__*/_styled$1("span", {
6465
6529
  return props.theme.spaceScale.spacing01;
6466
6530
  }, ";z-index:1;margin:", function (props) {
6467
6531
  return props.theme.spaceScale.spacing02;
6468
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAuDgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst CalendarContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n`;\r\nconst Table = typedStyled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Th = typedStyled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const days = [\r\n        'sunday',\r\n        'monday',\r\n        'tuesday',\r\n        'wednesday',\r\n        'thursday',\r\n        'friday',\r\n        'saturday',\r\n    ];\r\n    const startOfWeek = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse }, i18n.days.min[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onClose: context.hideHelperInformation })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: focusTrapElement },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { role: \"presentation\", onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
6532
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAuDgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst CalendarContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = typedStyled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n`;\r\nconst Table = typedStyled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Th = typedStyled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const days = [\r\n        'sunday',\r\n        'monday',\r\n        'tuesday',\r\n        'wednesday',\r\n        'thursday',\r\n        'friday',\r\n        'saturday',\r\n    ];\r\n    const startOfWeek = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse }, i18n.days.min[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onClose: context.hideHelperInformation })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: focusTrapElement },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
6469
6533
  var CalendarMonth = function CalendarMonth(props) {
6470
6534
  var lastFocus = React.useRef();
6471
6535
  var headingRef = React.useRef();
@@ -6536,7 +6600,6 @@ var CalendarMonth = function CalendarMonth(props) {
6536
6600
  focusHeader: focusHeader,
6537
6601
  isInverse: context.isInverse
6538
6602
  }), React.createElement(Table$1, {
6539
- role: "presentation",
6540
6603
  onBlur: onCalendarTableBlur,
6541
6604
  onFocus: onCalendarTableFocus,
6542
6605
  theme: theme
@@ -6653,6 +6716,7 @@ var Input = /*#__PURE__*/React.forwardRef(function (props, ref) {
6653
6716
  maxLength: maxLengthNum,
6654
6717
  onChange: handleChange,
6655
6718
  onClear: handleClear,
6719
+ onDateChange: props.onDateChange,
6656
6720
  ref: ref,
6657
6721
  testId: testId,
6658
6722
  value: value
@@ -6669,7 +6733,7 @@ var DatePickerContainer = /*#__PURE__*/_styled$1("div", {
6669
6733
  })( {
6670
6734
  name: "79elbk",
6671
6735
  styles: "position:relative;",
6672
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = typedStyled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n        }\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        lastFocus.current.focus();\r\n    }\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        setFocusedDate(getPrevMonthFromDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        setFocusedDate(getNextMonthFromDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                setFocusedDate(newChosenDate);\r\n            }\r\n        }\r\n        else {\r\n            if (event.key === '?') {\r\n                showHelperInformation();\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
6736
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = typedStyled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        lastFocus.current.focus();\r\n    }\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        setFocusedDate(getPrevMonthFromDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        setFocusedDate(getNextMonthFromDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                setFocusedDate(newChosenDate);\r\n            }\r\n        }\r\n        else {\r\n            if (event.key === '?') {\r\n                showHelperInformation();\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
6673
6737
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
6674
6738
  });
6675
6739
  var DatePickerCalendar = /*#__PURE__*/typedStyled$o.div(_templateObject$o || (_templateObject$o = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 1px solid\n ", ";\n border-radius: ", ";\n box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n color: ", ";\n display: ", ";\n margin-top: ", ";\n opacity: ", ";\n overflow: hidden;\n position: absolute;\n transition: opacity 0.2s ease-in-out 0s;\n width: 320px;\n z-index: ", ";\n"])), function (props) {
@@ -6717,9 +6781,10 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
6717
6781
  }, [calendarOpened]);
6718
6782
  React.useEffect(function () {
6719
6783
  if (props.value) {
6720
- setChosenDate(setDateFromConsumer(props.value));
6721
6784
  setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());
6785
+ setChosenDate(setDateFromConsumer(props.value));
6722
6786
  }
6787
+ if (props.value === null) setChosenDate(undefined);
6723
6788
  }, [props.value]);
6724
6789
  function showHelperInformation() {
6725
6790
  lastFocus.current = document.activeElement;
@@ -6818,7 +6883,7 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
6818
6883
  }
6819
6884
  function handleDateChange(day, event) {
6820
6885
  props.onDateChange && typeof props.onDateChange === 'function' && props.onDateChange(day, event);
6821
- props.onChange && typeof props.onChange === 'function' && props.onChange(day.toISOString(), event);
6886
+ props.onChange && typeof props.onChange === 'function' && props.onChange(day == null ? void 0 : day.toISOString(), event);
6822
6887
  onDateChange(day);
6823
6888
  setFocusedDate(day);
6824
6889
  }
@@ -6889,6 +6954,7 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
6889
6954
  onBlur: handleInputBlur,
6890
6955
  onFocus: handleInputFocus,
6891
6956
  onKeyDown: handleInputKeyDown,
6957
+ onDateChange: handleDateChange,
6892
6958
  placeholder: placeholder ? placeholder : dateFormat.toLowerCase(),
6893
6959
  type: exports.InputType.text,
6894
6960
  value: inputValue
@@ -7358,7 +7424,7 @@ var StyledItem$2 = /*#__PURE__*/_styled$1("div", {
7358
7424
  target: "evspqdv0",
7359
7425
  label: "StyledItem"
7360
7426
  })(MenuItemStyles, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duTWVudUl0ZW0udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNFOEIiLCJmaWxlIjoiRHJvcGRvd25NZW51SXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBEcm9wZG93bkNvbnRleHQgfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgQ2hlY2tJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IHR5cGVkU3R5bGVkID0gc3R5bGVkO1xyXG5leHBvcnQgZnVuY3Rpb24gbWVudUNvbG9ycyhwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmRpc2FibGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjQsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwKTtcclxuICAgIH1cclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDA7XHJcbn1cclxuZXhwb3J0IGZ1bmN0aW9uIG1lbnVCYWNrZ3JvdW5kKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICByZXR1cm4gJ25vbmUnO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTYwMDtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDIwMDtcclxufVxyXG5mdW5jdGlvbiBtZW51SXRlbVBhZGRpbmcocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0luYWN0aXZlKSB7XHJcbiAgICAgICAgcmV0dXJuIGAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fSAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzExfWA7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICByZXR1cm4gYCR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9YDtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgTWVudUl0ZW1TdHlsZXMgPSBwcm9wcyA9PiB7XHJcbiAgICByZXR1cm4gY3NzIGBcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIGNvbG9yOiAke21lbnVDb2xvcnMocHJvcHMpfTtcbiAgICBjdXJzb3I6ICR7cHJvcHMuZGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInfTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGZvbnQtc2l6ZTogJHtwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgICBmb250LWZhbWlseTogJHtwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gICAgbGluZS1oZWlnaHQ6ICR7cHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICBtYXJnaW46IDA7XG4gICAgcGFkZGluZzogJHttZW51SXRlbVBhZGRpbmcocHJvcHMpfTtcbiAgICB3aGl0ZS1zcGFjZTogJHtwcm9wcy5pc0ZpeGVkV2lkdGggPyAnbm9ybWFsJyA6ICdub3dyYXAnfTtcblxuICAgICY6aG92ZXIsXG4gICAgJjpmb2N1cyB7XG4gICAgICBiYWNrZ3JvdW5kOiAke21lbnVCYWNrZ3JvdW5kKHByb3BzKX07XG4gICAgfVxuXG4gICAgJjpmb2N1cyB7XG4gICAgICBvdXRsaW5lLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgIG91dGxpbmUtb2Zmc2V0OiAtMnB4O1xuICAgIH1cbiAgICAmOmFjdGl2ZSB7XG4gICAgICBvdXRsaW5lLWNvbG9yOiAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICB9XG4gIGA7XHJcbn07XHJcbmNvbnN0IFN0eWxlZEl0ZW0gPSBzdHlsZWQuZGl2IGBcbiAgJHtNZW51SXRlbVN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBJY29uV3JhcHBlciA9IHR5cGVkU3R5bGVkLnNwYW4gYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDB9O1xuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgbWFyZ2luLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fTtcblxuICBzdmcge1xuICAgIGhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5pY29uU2l6ZXMubWVkaXVtfXB4O1xuICAgIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmljb25TaXplcy5tZWRpdW19cHg7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBEcm9wZG93bk1lbnVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIG9uQ2xpY2ssIHZhbHVlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBvd25SZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgY29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25Db250ZXh0KTtcclxuICAgIGNvbnN0IHJlZiA9IHVzZUZvcmtlZFJlZihmb3J3YXJkZWRSZWYsIG93blJlZik7XHJcbiAgICBjb25zdCBpbmRleCA9IGNvbnRleHQuaXRlbVJlZkFycmF5LmN1cnJlbnQuZmluZEluZGV4KCh7IGN1cnJlbnQ6IGl0ZW0gfSkgPT4ge1xyXG4gICAgICAgIGlmICghaXRlbSB8fCAhb3duUmVmLmN1cnJlbnQpXHJcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICByZXR1cm4gaXRlbSA9PT0gb3duUmVmLmN1cnJlbnQ7XHJcbiAgICB9KTtcclxuICAgIGZ1bmN0aW9uIGhhbmRsZUNsaWNrKGV2ZW50KSB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuYWN0aXZlSXRlbUluZGV4ID49IDApIHtcclxuICAgICAgICAgICAgY29udGV4dC5zZXRBY3RpdmVJdGVtSW5kZXgoaW5kZXgpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAob25DbGljayAmJiAhZGlzYWJsZWQpIHtcclxuICAgICAgICAgICAgb25DbGljayh2YWx1ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmICghZGlzYWJsZWQgJiYgY29udGV4dC5hY3RpdmVJdGVtSW5kZXggPCAwKSB7XHJcbiAgICAgICAgICAgIGNvbnRleHQuY2xvc2VEcm9wZG93bihldmVudCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gaGFuZGxlS2V5RG93bihldmVudCkge1xyXG4gICAgICAgIGlmIChldmVudC5rZXkgPT09ICdFbnRlcicgfHwgZXZlbnQua2V5ID09PSAnICcpIHtcclxuICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgaGFuZGxlQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIGNvbnN0IGlzQWN0aXZlID0gY29udGV4dC5hY3RpdmVJdGVtSW5kZXggPj0gMCAmJiBjb250ZXh0LmFjdGl2ZUl0ZW1JbmRleCA9PT0gaW5kZXg7XHJcbiAgICBjb25zdCBpc0luYWN0aXZlID0gY29udGV4dC5hY3RpdmVJdGVtSW5kZXggPj0gMCAmJiBjb250ZXh0LmFjdGl2ZUl0ZW1JbmRleCAhPT0gaW5kZXg7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICghZGlzYWJsZWQpXHJcbiAgICAgICAgICAgIGNvbnRleHQucmVnaXN0ZXJEcm9wZG93bk1lbnVJdGVtKGNvbnRleHQuaXRlbVJlZkFycmF5LCBvd25SZWYpO1xyXG4gICAgfSwgW10pO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEl0ZW0sIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1kaXNhYmxlZFwiOiBkaXNhYmxlZCwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpc0ZpeGVkV2lkdGg6IGNvbnRleHQuaXNGaXhlZFdpZHRoLCBpc0luYWN0aXZlOiBpc0luYWN0aXZlLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCBvbkNsaWNrOiBoYW5kbGVDbGljaywgb25LZXlEb3duOiBoYW5kbGVLZXlEb3duLCByZWY6IGRpc2FibGVkID8gbnVsbCA6IHJlZiwgcm9sZTogXCJtZW51aXRlbVwiLCB0aGVtZTogdGhlbWUsIHRhYkluZGV4OiBkaXNhYmxlZCA/IG51bGwgOiAtMSwgdmFsdWU6IHZhbHVlIH0pLFxyXG4gICAgICAgIGljb24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlIH0sIGljb24pKSxcclxuICAgICAgICBpc0FjdGl2ZSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaGVja0ljb24sIHsgXCJhcmlhLWxhYmVsXCI6IGkxOG4uZHJvcGRvd24ubWVudUl0ZW1TZWxlY3RlZEFyaWFMYWJlbCB9KSkpLFxyXG4gICAgICAgIGNoaWxkcmVuKSk7XHJcbn0pO1xyXG5Ecm9wZG93bk1lbnVJdGVtLmRpc3BsYXlOYW1lID0gJ0Ryb3Bkb3duTWVudUl0ZW0nO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ecm9wZG93bk1lbnVJdGVtLmpzLm1hcCJdfQ== */");
7361
- var IconWrapper$6 = /*#__PURE__*/typedStyled$s.span(_templateObject$s || (_templateObject$s = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n color: ", ";\n display: inline-flex;\n margin-right: ", ";\n\n svg {\n height: ", "px;\n width: ", "px;\n }\n"])), function (props) {
7427
+ var IconWrapper$7 = /*#__PURE__*/typedStyled$s.span(_templateObject$s || (_templateObject$s = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n color: ", ";\n display: inline-flex;\n margin-right: ", ";\n\n svg {\n height: ", "px;\n width: ", "px;\n }\n"])), function (props) {
7362
7428
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral500;
7363
7429
  }, function (props) {
7364
7430
  return props.theme.spaceScale.spacing05;
@@ -7419,10 +7485,10 @@ var DropdownMenuItem = /*#__PURE__*/React.forwardRef(function (props, forwardedR
7419
7485
  theme: theme,
7420
7486
  tabIndex: disabled ? null : -1,
7421
7487
  value: value
7422
- }), icon && React.createElement(IconWrapper$6, {
7488
+ }), icon && React.createElement(IconWrapper$7, {
7423
7489
  theme: theme,
7424
7490
  isInverse: context.isInverse
7425
- }, icon), isActive && React.createElement(IconWrapper$6, {
7491
+ }, icon), isActive && React.createElement(IconWrapper$7, {
7426
7492
  isInverse: context.isInverse,
7427
7493
  theme: theme
7428
7494
  }, React.createElement(reactMagmaIcons.CheckIcon, {
@@ -7455,7 +7521,7 @@ var DropdownMenuNavItem = /*#__PURE__*/React.forwardRef(function (props, forward
7455
7521
  role: "menuitem",
7456
7522
  tabIndex: -1,
7457
7523
  theme: theme
7458
- }), icon && React.createElement(IconWrapper$6, {
7524
+ }), icon && React.createElement(IconWrapper$7, {
7459
7525
  theme: theme
7460
7526
  }, icon), children);
7461
7527
  });
@@ -8048,7 +8114,7 @@ var StyledAccordionButton = /*#__PURE__*/typedStyled$x(AccordionButton)(_templat
8048
8114
  }, function (props) {
8049
8115
  return props.isMenuItemContextDisabled ? '' : menuBackground;
8050
8116
  });
8051
- var StyledIconWrapper = /*#__PURE__*/ /*#__PURE__*/_styled$1(IconWrapper$6, {
8117
+ var StyledIconWrapper = /*#__PURE__*/ /*#__PURE__*/_styled$1(IconWrapper$7, {
8052
8118
  target: "e1404z5f0",
8053
8119
  label: "StyledIconWrapper"
8054
8120
  })( {
@@ -8313,7 +8379,7 @@ var Form = /*#__PURE__*/React.forwardRef(function (props, ref) {
8313
8379
  });
8314
8380
 
8315
8381
  var _excluded$12 = ["color", "height", "id", "isAnimated", "isLabelVisible", "isLoadingIndicator", "percentage", "testId"];
8316
- var _templateObject$z, _templateObject2$c, _templateObject3$9;
8382
+ var _templateObject$z, _templateObject2$d, _templateObject3$a;
8317
8383
  (function (ProgressBarColor) {
8318
8384
  ProgressBarColor["danger"] = "danger";
8319
8385
  ProgressBarColor["primary"] = "primary";
@@ -8322,22 +8388,24 @@ var _templateObject$z, _templateObject2$c, _templateObject3$9;
8322
8388
  var typedStyled$z = _styled;
8323
8389
  function buildProgressBarBackground(props) {
8324
8390
  if (props.isInverse) {
8325
- switch (props.color) {
8326
- case 'danger':
8327
- return props.theme.colors.danger200;
8328
- case 'success':
8329
- return props.theme.colors.success200;
8330
- default:
8331
- return props.theme.colors.tertiary;
8391
+ if (typeof props.color === 'string' && !Object.values(exports.ProgressBarColor).includes(props.color)) {
8392
+ return props.color;
8393
+ } else if (props.color === exports.ProgressBarColor.primary) {
8394
+ return props.theme.colors.tertiary;
8395
+ } else if (props.color === exports.ProgressBarColor.danger) {
8396
+ return props.theme.colors.danger200;
8397
+ } else if (props.color === exports.ProgressBarColor.success) {
8398
+ return props.theme.colors.success200;
8332
8399
  }
8333
8400
  }
8334
- switch (props.color) {
8335
- case 'danger':
8336
- return props.theme.colors.danger;
8337
- case 'success':
8338
- return props.theme.colors.success;
8339
- default:
8340
- return props.theme.colors.primary;
8401
+ if (typeof props.color === 'string' && !Object.values(exports.ProgressBarColor).includes(props.color)) {
8402
+ return props.color;
8403
+ } else if (props.color === exports.ProgressBarColor.primary) {
8404
+ return props.theme.colors.primary;
8405
+ } else if (props.color === exports.ProgressBarColor.danger) {
8406
+ return props.theme.colors.danger;
8407
+ } else if (props.color === exports.ProgressBarColor.success) {
8408
+ return props.theme.colors.success;
8341
8409
  }
8342
8410
  }
8343
8411
  var Container$3 = /*#__PURE__*/_styled$1("div", {
@@ -8345,7 +8413,7 @@ var Container$3 = /*#__PURE__*/_styled$1("div", {
8345
8413
  label: "Container"
8346
8414
  })("align-items:center;display:", function (props) {
8347
8415
  return props.isLoadingIndicator ? 'block' : 'flex';
8348
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQzZCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGNvbnZlcnRTdHlsZVZhbHVlVG9TdHJpbmcsIHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBQcm9ncmVzc0JhckNvbG9yO1xyXG4oZnVuY3Rpb24gKFByb2dyZXNzQmFyQ29sb3IpIHtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJkYW5nZXJcIl0gPSBcImRhbmdlclwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInByaW1hcnlcIl0gPSBcInByaW1hcnlcIjtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJzdWNjZXNzXCJdID0gXCJzdWNjZXNzXCI7XHJcbn0pKFByb2dyZXNzQmFyQ29sb3IgfHwgKFByb2dyZXNzQmFyQ29sb3IgPSB7fSkpO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuZnVuY3Rpb24gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBzd2l0Y2ggKHByb3BzLmNvbG9yKSB7XHJcbiAgICAgICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICAgICAgY2FzZSAnc3VjY2Vzcyc6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3MyMDA7XHJcbiAgICAgICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5O1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHN3aXRjaCAocHJvcHMuY29sb3IpIHtcclxuICAgICAgICBjYXNlICdkYW5nZXInOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzO1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTtcclxuICAgIH1cclxufVxyXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiAocHJvcHMuaXNMb2FkaW5nSW5kaWNhdG9yID8gJ2Jsb2NrJyA6ICdmbGV4Jyl9O1xuYDtcclxuY29uc3QgVHJhY2sgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjc1LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBib3gtc2hhZG93OiBpbnNldCAwIDAgMCAxcHhcbiAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGJvcmRlci1yYWRpdXM6IDUwZW07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy5oZWlnaHR9O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmNvbnN0IEJhciA9IHN0eWxlZC5kaXYgYFxuICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX07XG4gIGJvcmRlci1yYWRpdXM6IDUwZW07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHRyYW5zaXRpb246IHdpZHRoIDAuM3M7XG4gIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnBlcmNlbnRhZ2V9JTtcblxuICAke3Byb3BzID0+IHByb3BzLmlzQW5pbWF0ZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kLWltYWdlOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICAke2J1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX0gMCUsXG4gICAgICAgIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC41KSAyMCUsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSA0MCUsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSAxMDAlXG4gICAgICApO1xuICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgIGJhY2tncm91bmQtc2l6ZTogMTgwMHB4IDEwNHB4O1xuICAgICAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gICAgICBhbmltYXRpb24tZHVyYXRpb246IDFzO1xuICAgICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgICBhbmltYXRpb24taXRlcmF0aW9uLWNvdW50OiBpbmZpbml0ZTtcbiAgICAgIGFuaW1hdGlvbi1uYW1lOiBwbGFjZWhvbGRlclNoaW1tZXI7XG4gICAgICBhbmltYXRpb24tdGltaW5nLWZ1bmN0aW9uOiBsaW5lYXI7XG5cbiAgICAgIEBrZXlmcmFtZXMgcGxhY2Vob2xkZXJTaGltbWVyIHtcbiAgICAgICAgMCUge1xuICAgICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IC02MDBweCAwO1xuICAgICAgICB9XG5cbiAgICAgICAgMTAwJSB7XG4gICAgICAgICAgYmFja2dyb3VuZC1wb3NpdGlvbjogNjAwcHggMDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBQZXJjZW50YWdlID0gdHlwZWRTdHlsZWQuc3BhbiBgXG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmZvbnRTaXplfTtcbiAgbGV0dGVyLXNwYWNpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5sZXR0ZXJTcGFjaW5nfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgbWFyZ2luLWxlZnQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuYDtcclxuY29uc3QgVG9wUGVyY2VudGFnZSA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTA1LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwNS5saW5lSGVpZ2h0fTtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbmA7XHJcbmV4cG9ydCBjb25zdCBQcm9ncmVzc0JhciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGhlaWdodCwgaWQ6IGRlZmF1bHRJZCwgaXNBbmltYXRlZCwgaXNMYWJlbFZpc2libGUsIGlzTG9hZGluZ0luZGljYXRvciwgcGVyY2VudGFnZSwgdGVzdElkLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGxhYmVsSWQgPSBgJHtpZH1fX2xhYmVsYDtcclxuICAgIGNvbnN0IHBlcmNlbnRhZ2VWYWx1ZSA9IHBlcmNlbnRhZ2UgPyBwZXJjZW50YWdlIDogMDtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaGVpZ2h0U3RyaW5nID0gY29udmVydFN0eWxlVmFsdWVUb1N0cmluZyhoZWlnaHQsIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzKTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShwcm9wcy5pc0ludmVyc2UpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgaWQ6IGRlZmF1bHRJZCwgaXNMb2FkaW5nSW5kaWNhdG9yOiBpc0xvYWRpbmdJbmRpY2F0b3IgfSksXHJcbiAgICAgICAgaXNMb2FkaW5nSW5kaWNhdG9yICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFRvcFBlcmNlbnRhZ2UsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFRyYWNrLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoZWlnaHQ6IGhlaWdodFN0cmluZywgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCYXIsIHsgXCJhcmlhLWxhYmVsbGVkYnlcIjogbGFiZWxJZCwgXCJhcmlhLXZhbHVlbm93XCI6IHBlcmNlbnRhZ2VWYWx1ZSwgXCJhcmlhLXZhbHVlbWluXCI6IDAsIFwiYXJpYS12YWx1ZW1heFwiOiAxMDAsIGNvbG9yOiBjb2xvciwgaXNBbmltYXRlZDogaXNBbmltYXRlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBlcmNlbnRhZ2U6IHBlcmNlbnRhZ2VWYWx1ZSwgcm9sZTogXCJwcm9ncmVzc2JhclwiLCB0aGVtZTogdGhlbWUgfSkpLFxyXG4gICAgICAgIGlzTGFiZWxWaXNpYmxlID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGVyY2VudGFnZSwgeyBpZDogbGFiZWxJZCwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCB7IGlkOiBsYWJlbElkIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
8416
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QzZCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGNvbnZlcnRTdHlsZVZhbHVlVG9TdHJpbmcsIHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBQcm9ncmVzc0JhckNvbG9yO1xyXG4oZnVuY3Rpb24gKFByb2dyZXNzQmFyQ29sb3IpIHtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJkYW5nZXJcIl0gPSBcImRhbmdlclwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInByaW1hcnlcIl0gPSBcInByaW1hcnlcIjtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJzdWNjZXNzXCJdID0gXCJzdWNjZXNzXCI7XHJcbn0pKFByb2dyZXNzQmFyQ29sb3IgfHwgKFByb2dyZXNzQmFyQ29sb3IgPSB7fSkpO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuZnVuY3Rpb24gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBpZiAodHlwZW9mIHByb3BzLmNvbG9yID09PSAnc3RyaW5nJyAmJlxyXG4gICAgICAgICAgICAhT2JqZWN0LnZhbHVlcyhQcm9ncmVzc0JhckNvbG9yKS5pbmNsdWRlcyhwcm9wcy5jb2xvcikpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLmNvbG9yO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5wcmltYXJ5KSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2UgaWYgKHByb3BzLmNvbG9yID09PSBQcm9ncmVzc0JhckNvbG9yLmRhbmdlcikge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSBpZiAocHJvcHMuY29sb3IgPT09IFByb2dyZXNzQmFyQ29sb3Iuc3VjY2Vzcykge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3MyMDA7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgaWYgKHR5cGVvZiBwcm9wcy5jb2xvciA9PT0gJ3N0cmluZycgJiZcclxuICAgICAgICAhT2JqZWN0LnZhbHVlcyhQcm9ncmVzc0JhckNvbG9yKS5pbmNsdWRlcyhwcm9wcy5jb2xvcikpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMuY29sb3I7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5wcmltYXJ5KSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5O1xyXG4gICAgfVxyXG4gICAgZWxzZSBpZiAocHJvcHMuY29sb3IgPT09IFByb2dyZXNzQmFyQ29sb3IuZGFuZ2VyKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5zdWNjZXNzKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc0xvYWRpbmdJbmRpY2F0b3IgPyAnYmxvY2snIDogJ2ZsZXgnKX07XG5gO1xyXG5jb25zdCBUcmFjayA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNzUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweFxuICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgZGlzcGxheTogZmxleDtcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLmhlaWdodH07XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgQmFyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgZGlzcGxheTogZmxleDtcbiAgdHJhbnNpdGlvbjogd2lkdGggMC4zcztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMucGVyY2VudGFnZX0lO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNBbmltYXRlZCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGJhY2tncm91bmQtaW1hZ2U6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSAwJSxcbiAgICAgICAgcmdiYSgyNTUsIDI1NSwgMjU1LCAwLjUpIDIwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDQwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDEwMCVcbiAgICAgICk7XG4gICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgYmFja2dyb3VuZC1zaXplOiAxODAwcHggMTA0cHg7XG4gICAgICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMXM7XG4gICAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICAgIGFuaW1hdGlvbi1pdGVyYXRpb24tY291bnQ6IGluZmluaXRlO1xuICAgICAgYW5pbWF0aW9uLW5hbWU6IHBsYWNlaG9sZGVyU2hpbW1lcjtcbiAgICAgIGFuaW1hdGlvbi10aW1pbmctZnVuY3Rpb246IGxpbmVhcjtcblxuICAgICAgQGtleWZyYW1lcyBwbGFjZWhvbGRlclNoaW1tZXIge1xuICAgICAgICAwJSB7XG4gICAgICAgICAgYmFja2dyb3VuZC1wb3NpdGlvbjogLTYwMHB4IDA7XG4gICAgICAgIH1cblxuICAgICAgICAxMDAlIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiA2MDBweCAwO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFBlcmNlbnRhZ2UgPSB0eXBlZFN0eWxlZC5zcGFuIGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUb3BQZXJjZW50YWdlID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDUuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTA1LmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzQmFyID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjb2xvciA9IFByb2dyZXNzQmFyQ29sb3IucHJpbWFyeSwgaGVpZ2h0LCBpZDogZGVmYXVsdElkLCBpc0FuaW1hdGVkLCBpc0xhYmVsVmlzaWJsZSwgaXNMb2FkaW5nSW5kaWNhdG9yLCBwZXJjZW50YWdlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChkZWZhdWx0SWQpO1xyXG4gICAgY29uc3QgbGFiZWxJZCA9IGAke2lkfV9fbGFiZWxgO1xyXG4gICAgY29uc3QgcGVyY2VudGFnZVZhbHVlID0gcGVyY2VudGFnZSA/IHBlcmNlbnRhZ2UgOiAwO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBoZWlnaHRTdHJpbmcgPSBjb252ZXJ0U3R5bGVWYWx1ZVRvU3RyaW5nKGhlaWdodCwgdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDMpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBpZDogZGVmYXVsdElkLCBpc0xvYWRpbmdJbmRpY2F0b3I6IGlzTG9hZGluZ0luZGljYXRvciB9KSxcclxuICAgICAgICBpc0xvYWRpbmdJbmRpY2F0b3IgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVG9wUGVyY2VudGFnZSwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHJhY2ssIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhlaWdodDogaGVpZ2h0U3RyaW5nLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJhciwgeyBcImFyaWEtbGFiZWxsZWRieVwiOiBsYWJlbElkLCBcImFyaWEtdmFsdWVub3dcIjogcGVyY2VudGFnZVZhbHVlLCBcImFyaWEtdmFsdWVtaW5cIjogMCwgXCJhcmlhLXZhbHVlbWF4XCI6IDEwMCwgY29sb3I6IGNvbG9yLCBpc0FuaW1hdGVkOiBpc0FuaW1hdGVkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcGVyY2VudGFnZTogcGVyY2VudGFnZVZhbHVlLCByb2xlOiBcInByb2dyZXNzYmFyXCIsIHRoZW1lOiB0aGVtZSB9KSksXHJcbiAgICAgICAgaXNMYWJlbFZpc2libGUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChQZXJjZW50YWdlLCB7IGlkOiBsYWJlbElkLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIHsgaWQ6IGxhYmVsSWQgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
8349
8417
  var Track = /*#__PURE__*/typedStyled$z.div(_templateObject$z || (_templateObject$z = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n box-shadow: inset 0 0 0 1px\n ", ";\n border-radius: 50em;\n overflow: hidden;\n display: flex;\n height: ", ";\n width: 100%;\n"])), function (props) {
8350
8418
  return props.isInverse ? polished.transparentize(0.75, props.theme.colors.neutral900) : props.theme.colors.neutral100;
8351
8419
  }, function (props) {
@@ -8361,9 +8429,9 @@ var Bar = /*#__PURE__*/_styled$1("div", {
8361
8429
  }, ";border-radius:50em;display:flex;transition:width 0.3s;width:", function (props) {
8362
8430
  return props.percentage;
8363
8431
  }, "%;", function (props) {
8364
- return props.isAnimated && /*#__PURE__*/core.css("background-image:linear-gradient( to right,", buildProgressBarBackground(props), " 0%,rgba(255,255,255,0.5) 20%,", buildProgressBarBackground(props), " 40%,", buildProgressBarBackground(props), " 100% );background-repeat:no-repeat;background-size:1800px 104px;display:inline-block;position:relative;animation-duration:1s;animation-fill-mode:forwards;animation-iteration-count:infinite;animation-name:placeholderShimmer;animation-timing-function:linear;@keyframes placeholderShimmer{0%{background-position:-600px 0;}100%{background-position:600px 0;}};label:Bar;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RFEiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgY29udmVydFN0eWxlVmFsdWVUb1N0cmluZywgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFZpc3VhbGx5SGlkZGVuIH0gZnJvbSAnLi4vVmlzdWFsbHlIaWRkZW4nO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5leHBvcnQgdmFyIFByb2dyZXNzQmFyQ29sb3I7XHJcbihmdW5jdGlvbiAoUHJvZ3Jlc3NCYXJDb2xvcikge1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcImRhbmdlclwiXSA9IFwiZGFuZ2VyXCI7XHJcbiAgICBQcm9ncmVzc0JhckNvbG9yW1wicHJpbWFyeVwiXSA9IFwicHJpbWFyeVwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInN1Y2Nlc3NcIl0gPSBcInN1Y2Nlc3NcIjtcclxufSkoUHJvZ3Jlc3NCYXJDb2xvciB8fCAoUHJvZ3Jlc3NCYXJDb2xvciA9IHt9KSk7XHJcbmNvbnN0IHR5cGVkU3R5bGVkID0gc3R5bGVkO1xyXG5mdW5jdGlvbiBidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIHN3aXRjaCAocHJvcHMuY29sb3IpIHtcclxuICAgICAgICAgICAgY2FzZSAnZGFuZ2VyJzpcclxuICAgICAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMjAwO1xyXG4gICAgICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuc3VjY2VzczIwMDtcclxuICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgc3dpdGNoIChwcm9wcy5jb2xvcikge1xyXG4gICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyO1xyXG4gICAgICAgIGNhc2UgJ3N1Y2Nlc3MnOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3M7XHJcbiAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5O1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc0xvYWRpbmdJbmRpY2F0b3IgPyAnYmxvY2snIDogJ2ZsZXgnKX07XG5gO1xyXG5jb25zdCBUcmFjayA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNzUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweFxuICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgZGlzcGxheTogZmxleDtcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLmhlaWdodH07XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgQmFyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgZGlzcGxheTogZmxleDtcbiAgdHJhbnNpdGlvbjogd2lkdGggMC4zcztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMucGVyY2VudGFnZX0lO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNBbmltYXRlZCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGJhY2tncm91bmQtaW1hZ2U6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSAwJSxcbiAgICAgICAgcmdiYSgyNTUsIDI1NSwgMjU1LCAwLjUpIDIwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDQwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDEwMCVcbiAgICAgICk7XG4gICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgYmFja2dyb3VuZC1zaXplOiAxODAwcHggMTA0cHg7XG4gICAgICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMXM7XG4gICAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICAgIGFuaW1hdGlvbi1pdGVyYXRpb24tY291bnQ6IGluZmluaXRlO1xuICAgICAgYW5pbWF0aW9uLW5hbWU6IHBsYWNlaG9sZGVyU2hpbW1lcjtcbiAgICAgIGFuaW1hdGlvbi10aW1pbmctZnVuY3Rpb246IGxpbmVhcjtcblxuICAgICAgQGtleWZyYW1lcyBwbGFjZWhvbGRlclNoaW1tZXIge1xuICAgICAgICAwJSB7XG4gICAgICAgICAgYmFja2dyb3VuZC1wb3NpdGlvbjogLTYwMHB4IDA7XG4gICAgICAgIH1cblxuICAgICAgICAxMDAlIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiA2MDBweCAwO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFBlcmNlbnRhZ2UgPSB0eXBlZFN0eWxlZC5zcGFuIGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUb3BQZXJjZW50YWdlID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDUuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTA1LmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzQmFyID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjb2xvciwgaGVpZ2h0LCBpZDogZGVmYXVsdElkLCBpc0FuaW1hdGVkLCBpc0xhYmVsVmlzaWJsZSwgaXNMb2FkaW5nSW5kaWNhdG9yLCBwZXJjZW50YWdlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChkZWZhdWx0SWQpO1xyXG4gICAgY29uc3QgbGFiZWxJZCA9IGAke2lkfV9fbGFiZWxgO1xyXG4gICAgY29uc3QgcGVyY2VudGFnZVZhbHVlID0gcGVyY2VudGFnZSA/IHBlcmNlbnRhZ2UgOiAwO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBoZWlnaHRTdHJpbmcgPSBjb252ZXJ0U3R5bGVWYWx1ZVRvU3RyaW5nKGhlaWdodCwgdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDMpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBpZDogZGVmYXVsdElkLCBpc0xvYWRpbmdJbmRpY2F0b3I6IGlzTG9hZGluZ0luZGljYXRvciB9KSxcclxuICAgICAgICBpc0xvYWRpbmdJbmRpY2F0b3IgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVG9wUGVyY2VudGFnZSwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHJhY2ssIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhlaWdodDogaGVpZ2h0U3RyaW5nLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJhciwgeyBcImFyaWEtbGFiZWxsZWRieVwiOiBsYWJlbElkLCBcImFyaWEtdmFsdWVub3dcIjogcGVyY2VudGFnZVZhbHVlLCBcImFyaWEtdmFsdWVtaW5cIjogMCwgXCJhcmlhLXZhbHVlbWF4XCI6IDEwMCwgY29sb3I6IGNvbG9yLCBpc0FuaW1hdGVkOiBpc0FuaW1hdGVkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcGVyY2VudGFnZTogcGVyY2VudGFnZVZhbHVlLCByb2xlOiBcInByb2dyZXNzYmFyXCIsIHRoZW1lOiB0aGVtZSB9KSksXHJcbiAgICAgICAgaXNMYWJlbFZpc2libGUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChQZXJjZW50YWdlLCB7IGlkOiBsYWJlbElkLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIHsgaWQ6IGxhYmVsSWQgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
8365
- }, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRHVCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGNvbnZlcnRTdHlsZVZhbHVlVG9TdHJpbmcsIHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBQcm9ncmVzc0JhckNvbG9yO1xyXG4oZnVuY3Rpb24gKFByb2dyZXNzQmFyQ29sb3IpIHtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJkYW5nZXJcIl0gPSBcImRhbmdlclwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInByaW1hcnlcIl0gPSBcInByaW1hcnlcIjtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJzdWNjZXNzXCJdID0gXCJzdWNjZXNzXCI7XHJcbn0pKFByb2dyZXNzQmFyQ29sb3IgfHwgKFByb2dyZXNzQmFyQ29sb3IgPSB7fSkpO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuZnVuY3Rpb24gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBzd2l0Y2ggKHByb3BzLmNvbG9yKSB7XHJcbiAgICAgICAgICAgIGNhc2UgJ2Rhbmdlcic6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICAgICAgY2FzZSAnc3VjY2Vzcyc6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3MyMDA7XHJcbiAgICAgICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5O1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHN3aXRjaCAocHJvcHMuY29sb3IpIHtcclxuICAgICAgICBjYXNlICdkYW5nZXInOlxyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgICAgICBjYXNlICdzdWNjZXNzJzpcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzO1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTtcclxuICAgIH1cclxufVxyXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiAocHJvcHMuaXNMb2FkaW5nSW5kaWNhdG9yID8gJ2Jsb2NrJyA6ICdmbGV4Jyl9O1xuYDtcclxuY29uc3QgVHJhY2sgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjc1LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMClcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBib3gtc2hhZG93OiBpbnNldCAwIDAgMCAxcHhcbiAgICAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGJvcmRlci1yYWRpdXM6IDUwZW07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy5oZWlnaHR9O1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmNvbnN0IEJhciA9IHN0eWxlZC5kaXYgYFxuICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX07XG4gIGJvcmRlci1yYWRpdXM6IDUwZW07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHRyYW5zaXRpb246IHdpZHRoIDAuM3M7XG4gIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnBlcmNlbnRhZ2V9JTtcblxuICAke3Byb3BzID0+IHByb3BzLmlzQW5pbWF0ZWQgJiZcclxuICAgIGNzcyBgXG4gICAgICBiYWNrZ3JvdW5kLWltYWdlOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICAke2J1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX0gMCUsXG4gICAgICAgIHJnYmEoMjU1LCAyNTUsIDI1NSwgMC41KSAyMCUsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSA0MCUsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSAxMDAlXG4gICAgICApO1xuICAgICAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgICAgIGJhY2tncm91bmQtc2l6ZTogMTgwMHB4IDEwNHB4O1xuICAgICAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xuXG4gICAgICBhbmltYXRpb24tZHVyYXRpb246IDFzO1xuICAgICAgYW5pbWF0aW9uLWZpbGwtbW9kZTogZm9yd2FyZHM7XG4gICAgICBhbmltYXRpb24taXRlcmF0aW9uLWNvdW50OiBpbmZpbml0ZTtcbiAgICAgIGFuaW1hdGlvbi1uYW1lOiBwbGFjZWhvbGRlclNoaW1tZXI7XG4gICAgICBhbmltYXRpb24tdGltaW5nLWZ1bmN0aW9uOiBsaW5lYXI7XG5cbiAgICAgIEBrZXlmcmFtZXMgcGxhY2Vob2xkZXJTaGltbWVyIHtcbiAgICAgICAgMCUge1xuICAgICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IC02MDBweCAwO1xuICAgICAgICB9XG5cbiAgICAgICAgMTAwJSB7XG4gICAgICAgICAgYmFja2dyb3VuZC1wb3NpdGlvbjogNjAwcHggMDtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIGB9XG5gO1xyXG5jb25zdCBQZXJjZW50YWdlID0gdHlwZWRTdHlsZWQuc3BhbiBgXG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmZvbnRTaXplfTtcbiAgbGV0dGVyLXNwYWNpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5sZXR0ZXJTcGFjaW5nfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5saW5lSGVpZ2h0fTtcbiAgbWFyZ2luLWxlZnQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuYDtcclxuY29uc3QgVG9wUGVyY2VudGFnZSA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTA1LmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwNS5saW5lSGVpZ2h0fTtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbmA7XHJcbmV4cG9ydCBjb25zdCBQcm9ncmVzc0JhciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGhlaWdodCwgaWQ6IGRlZmF1bHRJZCwgaXNBbmltYXRlZCwgaXNMYWJlbFZpc2libGUsIGlzTG9hZGluZ0luZGljYXRvciwgcGVyY2VudGFnZSwgdGVzdElkLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGxhYmVsSWQgPSBgJHtpZH1fX2xhYmVsYDtcclxuICAgIGNvbnN0IHBlcmNlbnRhZ2VWYWx1ZSA9IHBlcmNlbnRhZ2UgPyBwZXJjZW50YWdlIDogMDtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaGVpZ2h0U3RyaW5nID0gY29udmVydFN0eWxlVmFsdWVUb1N0cmluZyhoZWlnaHQsIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzKTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShwcm9wcy5pc0ludmVyc2UpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgaWQ6IGRlZmF1bHRJZCwgaXNMb2FkaW5nSW5kaWNhdG9yOiBpc0xvYWRpbmdJbmRpY2F0b3IgfSksXHJcbiAgICAgICAgaXNMb2FkaW5nSW5kaWNhdG9yICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFRvcFBlcmNlbnRhZ2UsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFRyYWNrLCB7IFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBoZWlnaHQ6IGhlaWdodFN0cmluZywgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChCYXIsIHsgXCJhcmlhLWxhYmVsbGVkYnlcIjogbGFiZWxJZCwgXCJhcmlhLXZhbHVlbm93XCI6IHBlcmNlbnRhZ2VWYWx1ZSwgXCJhcmlhLXZhbHVlbWluXCI6IDAsIFwiYXJpYS12YWx1ZW1heFwiOiAxMDAsIGNvbG9yOiBjb2xvciwgaXNBbmltYXRlZDogaXNBbmltYXRlZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHBlcmNlbnRhZ2U6IHBlcmNlbnRhZ2VWYWx1ZSwgcm9sZTogXCJwcm9ncmVzc2JhclwiLCB0aGVtZTogdGhlbWUgfSkpLFxyXG4gICAgICAgIGlzTGFiZWxWaXNpYmxlID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGVyY2VudGFnZSwgeyBpZDogbGFiZWxJZCwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCB7IGlkOiBsYWJlbElkIH0sXHJcbiAgICAgICAgICAgIHBlcmNlbnRhZ2VWYWx1ZSxcclxuICAgICAgICAgICAgXCIlXCIpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */");
8366
- var Percentage = /*#__PURE__*/typedStyled$z.span(_templateObject2$c || (_templateObject2$c = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-left: ", ";\n"])), function (props) {
8432
+ return props.isAnimated && /*#__PURE__*/core.css("background-image:linear-gradient( to right,", buildProgressBarBackground(props), " 0%,rgba(255,255,255,0.5) 20%,", buildProgressBarBackground(props), " 40%,", buildProgressBarBackground(props), " 100% );background-repeat:no-repeat;background-size:1800px 104px;display:inline-block;position:relative;animation-duration:1s;animation-fill-mode:forwards;animation-iteration-count:infinite;animation-name:placeholderShimmer;animation-timing-function:linear;@keyframes placeholderShimmer{0%{background-position:-600px 0;}100%{background-position:600px 0;}};label:Bar;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RVEiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgY29udmVydFN0eWxlVmFsdWVUb1N0cmluZywgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFZpc3VhbGx5SGlkZGVuIH0gZnJvbSAnLi4vVmlzdWFsbHlIaWRkZW4nO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5leHBvcnQgdmFyIFByb2dyZXNzQmFyQ29sb3I7XHJcbihmdW5jdGlvbiAoUHJvZ3Jlc3NCYXJDb2xvcikge1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcImRhbmdlclwiXSA9IFwiZGFuZ2VyXCI7XHJcbiAgICBQcm9ncmVzc0JhckNvbG9yW1wicHJpbWFyeVwiXSA9IFwicHJpbWFyeVwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInN1Y2Nlc3NcIl0gPSBcInN1Y2Nlc3NcIjtcclxufSkoUHJvZ3Jlc3NCYXJDb2xvciB8fCAoUHJvZ3Jlc3NCYXJDb2xvciA9IHt9KSk7XHJcbmNvbnN0IHR5cGVkU3R5bGVkID0gc3R5bGVkO1xyXG5mdW5jdGlvbiBidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgIGlmICh0eXBlb2YgcHJvcHMuY29sb3IgPT09ICdzdHJpbmcnICYmXHJcbiAgICAgICAgICAgICFPYmplY3QudmFsdWVzKFByb2dyZXNzQmFyQ29sb3IpLmluY2x1ZGVzKHByb3BzLmNvbG9yKSkge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMuY29sb3I7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2UgaWYgKHByb3BzLmNvbG9yID09PSBQcm9ncmVzc0JhckNvbG9yLnByaW1hcnkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy50ZXJ0aWFyeTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSBpZiAocHJvcHMuY29sb3IgPT09IFByb2dyZXNzQmFyQ29sb3IuZGFuZ2VyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMjAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5zdWNjZXNzKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuc3VjY2VzczIwMDtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBpZiAodHlwZW9mIHByb3BzLmNvbG9yID09PSAnc3RyaW5nJyAmJlxyXG4gICAgICAgICFPYmplY3QudmFsdWVzKFByb2dyZXNzQmFyQ29sb3IpLmluY2x1ZGVzKHByb3BzLmNvbG9yKSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy5jb2xvcjtcclxuICAgIH1cclxuICAgIGVsc2UgaWYgKHByb3BzLmNvbG9yID09PSBQcm9ncmVzc0JhckNvbG9yLnByaW1hcnkpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5kYW5nZXIpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIGVsc2UgaWYgKHByb3BzLmNvbG9yID09PSBQcm9ncmVzc0JhckNvbG9yLnN1Y2Nlc3MpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3M7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gKHByb3BzLmlzTG9hZGluZ0luZGljYXRvciA/ICdibG9jaycgOiAnZmxleCcpfTtcbmA7XHJcbmNvbnN0IFRyYWNrID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC43NSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4XG4gICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBib3JkZXItcmFkaXVzOiA1MGVtO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBkaXNwbGF5OiBmbGV4O1xuICBoZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMuaGVpZ2h0fTtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBCYXIgPSBzdHlsZWQuZGl2IGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9O1xuICBib3JkZXItcmFkaXVzOiA1MGVtO1xuICBkaXNwbGF5OiBmbGV4O1xuICB0cmFuc2l0aW9uOiB3aWR0aCAwLjNzO1xuICB3aWR0aDogJHtwcm9wcyA9PiBwcm9wcy5wZXJjZW50YWdlfSU7XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5pc0FuaW1hdGVkICYmXHJcbiAgICBjc3MgYFxuICAgICAgYmFja2dyb3VuZC1pbWFnZTogbGluZWFyLWdyYWRpZW50KFxuICAgICAgICB0byByaWdodCxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDAlLFxuICAgICAgICByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuNSkgMjAlLFxuICAgICAgICAke2J1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX0gNDAlLFxuICAgICAgICAke2J1aWxkUHJvZ3Jlc3NCYXJCYWNrZ3JvdW5kKHByb3BzKX0gMTAwJVxuICAgICAgKTtcbiAgICAgIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gICAgICBiYWNrZ3JvdW5kLXNpemU6IDE4MDBweCAxMDRweDtcbiAgICAgIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcblxuICAgICAgYW5pbWF0aW9uLWR1cmF0aW9uOiAxcztcbiAgICAgIGFuaW1hdGlvbi1maWxsLW1vZGU6IGZvcndhcmRzO1xuICAgICAgYW5pbWF0aW9uLWl0ZXJhdGlvbi1jb3VudDogaW5maW5pdGU7XG4gICAgICBhbmltYXRpb24tbmFtZTogcGxhY2Vob2xkZXJTaGltbWVyO1xuICAgICAgYW5pbWF0aW9uLXRpbWluZy1mdW5jdGlvbjogbGluZWFyO1xuXG4gICAgICBAa2V5ZnJhbWVzIHBsYWNlaG9sZGVyU2hpbW1lciB7XG4gICAgICAgIDAlIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiAtNjAwcHggMDtcbiAgICAgICAgfVxuXG4gICAgICAgIDEwMCUge1xuICAgICAgICAgIGJhY2tncm91bmQtcG9zaXRpb246IDYwMHB4IDA7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgUGVyY2VudGFnZSA9IHR5cGVkU3R5bGVkLnNwYW4gYFxuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5mb250U2l6ZX07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbi1sZWZ0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbmA7XHJcbmNvbnN0IFRvcFBlcmNlbnRhZ2UgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwNS5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDUubGluZUhlaWdodH07XG4gIG1hcmdpbi1ib3R0b206ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xyXG5leHBvcnQgY29uc3QgUHJvZ3Jlc3NCYXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGNvbG9yID0gUHJvZ3Jlc3NCYXJDb2xvci5wcmltYXJ5LCBoZWlnaHQsIGlkOiBkZWZhdWx0SWQsIGlzQW5pbWF0ZWQsIGlzTGFiZWxWaXNpYmxlLCBpc0xvYWRpbmdJbmRpY2F0b3IsIHBlcmNlbnRhZ2UsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBjb25zdCBsYWJlbElkID0gYCR7aWR9X19sYWJlbGA7XHJcbiAgICBjb25zdCBwZXJjZW50YWdlVmFsdWUgPSBwZXJjZW50YWdlID8gcGVyY2VudGFnZSA6IDA7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGhlaWdodFN0cmluZyA9IGNvbnZlcnRTdHlsZVZhbHVlVG9TdHJpbmcoaGVpZ2h0LCB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMyk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UocHJvcHMuaXNJbnZlcnNlKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IGlkOiBkZWZhdWx0SWQsIGlzTG9hZGluZ0luZGljYXRvcjogaXNMb2FkaW5nSW5kaWNhdG9yIH0pLFxyXG4gICAgICAgIGlzTG9hZGluZ0luZGljYXRvciAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUb3BQZXJjZW50YWdlLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBwZXJjZW50YWdlVmFsdWUsXHJcbiAgICAgICAgICAgIFwiJVwiKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUcmFjaywgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGVpZ2h0OiBoZWlnaHRTdHJpbmcsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQmFyLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGxhYmVsSWQsIFwiYXJpYS12YWx1ZW5vd1wiOiBwZXJjZW50YWdlVmFsdWUsIFwiYXJpYS12YWx1ZW1pblwiOiAwLCBcImFyaWEtdmFsdWVtYXhcIjogMTAwLCBjb2xvcjogY29sb3IsIGlzQW5pbWF0ZWQ6IGlzQW5pbWF0ZWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBwZXJjZW50YWdlOiBwZXJjZW50YWdlVmFsdWUsIHJvbGU6IFwicHJvZ3Jlc3NiYXJcIiwgdGhlbWU6IHRoZW1lIH0pKSxcclxuICAgICAgICBpc0xhYmVsVmlzaWJsZSA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFBlcmNlbnRhZ2UsIHsgaWQ6IGxhYmVsSWQsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBwZXJjZW50YWdlVmFsdWUsXHJcbiAgICAgICAgICAgIFwiJVwiKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgeyBpZDogbGFiZWxJZCB9LFxyXG4gICAgICAgICAgICBwZXJjZW50YWdlVmFsdWUsXHJcbiAgICAgICAgICAgIFwiJVwiKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */"));
8433
+ }, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErRHVCIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IGNvbnZlcnRTdHlsZVZhbHVlVG9TdHJpbmcsIHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IHZhciBQcm9ncmVzc0JhckNvbG9yO1xyXG4oZnVuY3Rpb24gKFByb2dyZXNzQmFyQ29sb3IpIHtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJkYW5nZXJcIl0gPSBcImRhbmdlclwiO1xyXG4gICAgUHJvZ3Jlc3NCYXJDb2xvcltcInByaW1hcnlcIl0gPSBcInByaW1hcnlcIjtcclxuICAgIFByb2dyZXNzQmFyQ29sb3JbXCJzdWNjZXNzXCJdID0gXCJzdWNjZXNzXCI7XHJcbn0pKFByb2dyZXNzQmFyQ29sb3IgfHwgKFByb2dyZXNzQmFyQ29sb3IgPSB7fSkpO1xyXG5jb25zdCB0eXBlZFN0eWxlZCA9IHN0eWxlZDtcclxuZnVuY3Rpb24gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBpZiAodHlwZW9mIHByb3BzLmNvbG9yID09PSAnc3RyaW5nJyAmJlxyXG4gICAgICAgICAgICAhT2JqZWN0LnZhbHVlcyhQcm9ncmVzc0JhckNvbG9yKS5pbmNsdWRlcyhwcm9wcy5jb2xvcikpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLmNvbG9yO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5wcmltYXJ5KSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMudGVydGlhcnk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2UgaWYgKHByb3BzLmNvbG9yID09PSBQcm9ncmVzc0JhckNvbG9yLmRhbmdlcikge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjIwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSBpZiAocHJvcHMuY29sb3IgPT09IFByb2dyZXNzQmFyQ29sb3Iuc3VjY2Vzcykge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLnN1Y2Nlc3MyMDA7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgaWYgKHR5cGVvZiBwcm9wcy5jb2xvciA9PT0gJ3N0cmluZycgJiZcclxuICAgICAgICAhT2JqZWN0LnZhbHVlcyhQcm9ncmVzc0JhckNvbG9yKS5pbmNsdWRlcyhwcm9wcy5jb2xvcikpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMuY29sb3I7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5wcmltYXJ5KSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5O1xyXG4gICAgfVxyXG4gICAgZWxzZSBpZiAocHJvcHMuY29sb3IgPT09IFByb2dyZXNzQmFyQ29sb3IuZGFuZ2VyKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmIChwcm9wcy5jb2xvciA9PT0gUHJvZ3Jlc3NCYXJDb2xvci5zdWNjZXNzKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5zdWNjZXNzO1xyXG4gICAgfVxyXG59XHJcbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc0xvYWRpbmdJbmRpY2F0b3IgPyAnYmxvY2snIDogJ2ZsZXgnKX07XG5gO1xyXG5jb25zdCBUcmFjayA9IHR5cGVkU3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNzUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwKVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweFxuICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgZGlzcGxheTogZmxleDtcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLmhlaWdodH07XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuY29uc3QgQmFyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gYnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfTtcbiAgYm9yZGVyLXJhZGl1czogNTBlbTtcbiAgZGlzcGxheTogZmxleDtcbiAgdHJhbnNpdGlvbjogd2lkdGggMC4zcztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gcHJvcHMucGVyY2VudGFnZX0lO1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuaXNBbmltYXRlZCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGJhY2tncm91bmQtaW1hZ2U6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgICR7YnVpbGRQcm9ncmVzc0JhckJhY2tncm91bmQocHJvcHMpfSAwJSxcbiAgICAgICAgcmdiYSgyNTUsIDI1NSwgMjU1LCAwLjUpIDIwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDQwJSxcbiAgICAgICAgJHtidWlsZFByb2dyZXNzQmFyQmFja2dyb3VuZChwcm9wcyl9IDEwMCVcbiAgICAgICk7XG4gICAgICBiYWNrZ3JvdW5kLXJlcGVhdDogbm8tcmVwZWF0O1xuICAgICAgYmFja2dyb3VuZC1zaXplOiAxODAwcHggMTA0cHg7XG4gICAgICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gICAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG5cbiAgICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMXM7XG4gICAgICBhbmltYXRpb24tZmlsbC1tb2RlOiBmb3J3YXJkcztcbiAgICAgIGFuaW1hdGlvbi1pdGVyYXRpb24tY291bnQ6IGluZmluaXRlO1xuICAgICAgYW5pbWF0aW9uLW5hbWU6IHBsYWNlaG9sZGVyU2hpbW1lcjtcbiAgICAgIGFuaW1hdGlvbi10aW1pbmctZnVuY3Rpb246IGxpbmVhcjtcblxuICAgICAgQGtleWZyYW1lcyBwbGFjZWhvbGRlclNoaW1tZXIge1xuICAgICAgICAwJSB7XG4gICAgICAgICAgYmFja2dyb3VuZC1wb3NpdGlvbjogLTYwMHB4IDA7XG4gICAgICAgIH1cblxuICAgICAgICAxMDAlIHtcbiAgICAgICAgICBiYWNrZ3JvdW5kLXBvc2l0aW9uOiA2MDBweCAwO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFBlcmNlbnRhZ2UgPSB0eXBlZFN0eWxlZC5zcGFuIGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBsZXR0ZXItc3BhY2luZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxldHRlclNwYWNpbmd9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAyLmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tbGVmdDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUb3BQZXJjZW50YWdlID0gdHlwZWRTdHlsZWQuZGl2IGBcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDUuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTA1LmxpbmVIZWlnaHR9O1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzQmFyID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjb2xvciA9IFByb2dyZXNzQmFyQ29sb3IucHJpbWFyeSwgaGVpZ2h0LCBpZDogZGVmYXVsdElkLCBpc0FuaW1hdGVkLCBpc0xhYmVsVmlzaWJsZSwgaXNMb2FkaW5nSW5kaWNhdG9yLCBwZXJjZW50YWdlLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChkZWZhdWx0SWQpO1xyXG4gICAgY29uc3QgbGFiZWxJZCA9IGAke2lkfV9fbGFiZWxgO1xyXG4gICAgY29uc3QgcGVyY2VudGFnZVZhbHVlID0gcGVyY2VudGFnZSA/IHBlcmNlbnRhZ2UgOiAwO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBoZWlnaHRTdHJpbmcgPSBjb252ZXJ0U3R5bGVWYWx1ZVRvU3RyaW5nKGhlaWdodCwgdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDMpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBpZDogZGVmYXVsdElkLCBpc0xvYWRpbmdJbmRpY2F0b3I6IGlzTG9hZGluZ0luZGljYXRvciB9KSxcclxuICAgICAgICBpc0xvYWRpbmdJbmRpY2F0b3IgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVG9wUGVyY2VudGFnZSwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHJhY2ssIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhlaWdodDogaGVpZ2h0U3RyaW5nLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJhciwgeyBcImFyaWEtbGFiZWxsZWRieVwiOiBsYWJlbElkLCBcImFyaWEtdmFsdWVub3dcIjogcGVyY2VudGFnZVZhbHVlLCBcImFyaWEtdmFsdWVtaW5cIjogMCwgXCJhcmlhLXZhbHVlbWF4XCI6IDEwMCwgY29sb3I6IGNvbG9yLCBpc0FuaW1hdGVkOiBpc0FuaW1hdGVkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcGVyY2VudGFnZTogcGVyY2VudGFnZVZhbHVlLCByb2xlOiBcInByb2dyZXNzYmFyXCIsIHRoZW1lOiB0aGVtZSB9KSksXHJcbiAgICAgICAgaXNMYWJlbFZpc2libGUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChQZXJjZW50YWdlLCB7IGlkOiBsYWJlbElkLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIHsgaWQ6IGxhYmVsSWQgfSxcclxuICAgICAgICAgICAgcGVyY2VudGFnZVZhbHVlLFxyXG4gICAgICAgICAgICBcIiVcIikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */");
8434
+ var Percentage = /*#__PURE__*/typedStyled$z.span(_templateObject2$d || (_templateObject2$d = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin-left: ", ";\n"])), function (props) {
8367
8435
  return props.theme.typeScale.size02.fontSize;
8368
8436
  }, function (props) {
8369
8437
  return props.theme.typeScale.size02.letterSpacing;
@@ -8372,7 +8440,7 @@ var Percentage = /*#__PURE__*/typedStyled$z.span(_templateObject2$c || (_templat
8372
8440
  }, function (props) {
8373
8441
  return props.theme.spaceScale.spacing03;
8374
8442
  });
8375
- var TopPercentage = /*#__PURE__*/typedStyled$z.div(_templateObject3$9 || (_templateObject3$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-size: ", ";\n line-height: ", ";\n margin-bottom: ", ";\n text-align: center;\n"])), function (props) {
8443
+ var TopPercentage = /*#__PURE__*/typedStyled$z.div(_templateObject3$a || (_templateObject3$a = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n font-size: ", ";\n line-height: ", ";\n margin-bottom: ", ";\n text-align: center;\n"])), function (props) {
8376
8444
  return props.theme.typeScale.size05.fontSize;
8377
8445
  }, function (props) {
8378
8446
  return props.theme.typeScale.size05.lineHeight;
@@ -8380,7 +8448,8 @@ var TopPercentage = /*#__PURE__*/typedStyled$z.div(_templateObject3$9 || (_templ
8380
8448
  return props.theme.spaceScale.spacing03;
8381
8449
  });
8382
8450
  var ProgressBar = /*#__PURE__*/React.forwardRef(function (props, ref) {
8383
- var color = props.color,
8451
+ var _props$color = props.color,
8452
+ color = _props$color === void 0 ? exports.ProgressBarColor.primary : _props$color,
8384
8453
  height = props.height,
8385
8454
  defaultId = props.id,
8386
8455
  isAnimated = props.isAnimated,
@@ -10199,7 +10268,7 @@ var Radio = /*#__PURE__*/React.forwardRef(function (props, ref) {
10199
10268
  }, context.selectedValue === value ? React.createElement(reactMagmaIcons.RadioButtonCheckedIcon, null) : React.createElement(reactMagmaIcons.RadioButtonUncheckedIcon, null)), isTextVisuallyHidden ? React.createElement(HiddenLabelText$1, null, labelText) : textPosition !== exports.RadioTextPosition.left && labelText && labelText));
10200
10269
  });
10201
10270
 
10202
- var _excluded$1i = ["children", "closeAriaLabel", "closeButtonSize", "containerStyle", "containerTransition", "isBackgroundClickDisabled", "isEscKeyDownDisabled", "header", "isCloseButtonHidden", "isOpen", "unmountOnExit", "testId"];
10271
+ var _excluded$1i = ["ariaLabel", "children", "closeAriaLabel", "closeButtonSize", "containerStyle", "containerTransition", "isBackgroundClickDisabled", "isEscKeyDownDisabled", "header", "isCloseButtonHidden", "isOpen", "unmountOnExit", "testId"];
10203
10272
  (function (ModalSize) {
10204
10273
  ModalSize["large"] = "large";
10205
10274
  ModalSize["medium"] = "medium";
@@ -10210,13 +10279,13 @@ var ModalContainer = /*#__PURE__*/ /*#__PURE__*/_styled$1(Transition, {
10210
10279
  label: "ModalContainer"
10211
10280
  })("bottom:0;left:0;overflow-y:auto;padding:", function (props) {
10212
10281
  return props.theme.spaceScale.spacing03;
10213
- }, ";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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10282
+ }, ";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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10214
10283
  var ModalBackdrop = /*#__PURE__*/ /*#__PURE__*/_styled$1(Transition, {
10215
10284
  target: "e1pxemtw1",
10216
10285
  label: "ModalBackdrop"
10217
10286
  })("backdrop-filter:blur(3px);background:", function (props) {
10218
10287
  return polished.transparentize(0.4, props.theme.colors.neutral900);
10219
- }, ";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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10288
+ }, ";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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10220
10289
  var ModalContent = /*#__PURE__*/_styled$1("div", {
10221
10290
  target: "e1pxemtw2",
10222
10291
  label: "ModalContent"
@@ -10243,7 +10312,7 @@ var ModalContent = /*#__PURE__*/_styled$1("div", {
10243
10312
  return props.theme.breakpoints.small;
10244
10313
  }, "px){margin:", function (props) {
10245
10314
  return props.theme.spaceScale.spacing08;
10246
- }, " 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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10315
+ }, " 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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10247
10316
  var ModalHeader = /*#__PURE__*/_styled$1("div", {
10248
10317
  target: "e1pxemtw3",
10249
10318
  label: "ModalHeader"
@@ -10261,7 +10330,7 @@ var ModalHeader = /*#__PURE__*/_styled$1("div", {
10261
10330
  return props.theme.spaceScale.spacing06;
10262
10331
  }, " 0 ", function (props) {
10263
10332
  return props.theme.spaceScale.spacing06;
10264
- }, ";}" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10333
+ }, ";}" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10265
10334
  var ModalWrapper = /*#__PURE__*/_styled$1("div", {
10266
10335
  target: "e1pxemtw4",
10267
10336
  label: "ModalWrapper"
@@ -10271,7 +10340,7 @@ var ModalWrapper = /*#__PURE__*/_styled$1("div", {
10271
10340
  return props.theme.breakpoints.small;
10272
10341
  }, "px){padding:", function (props) {
10273
10342
  return props.theme.spaceScale.spacing06;
10274
- }, ";}" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10343
+ }, ";}" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10275
10344
  var H1 = /*#__PURE__*/ /*#__PURE__*/_styled$1(Heading, {
10276
10345
  target: "e1pxemtw5",
10277
10346
  label: "H1"
@@ -10283,13 +10352,13 @@ var H1 = /*#__PURE__*/ /*#__PURE__*/_styled$1(Heading, {
10283
10352
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
10284
10353
  }, ";margin:0;padding-right:", function (props) {
10285
10354
  return props.theme.spaceScale.spacing10;
10286
- }, ";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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10355
+ }, ";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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10287
10356
  var CloseBtn = /*#__PURE__*/_styled$1("span", {
10288
10357
  target: "e1pxemtw6",
10289
10358
  label: "CloseBtn"
10290
10359
  })("position:absolute;top:0;right:0;margin:", function (props) {
10291
10360
  return props.theme.spaceScale.spacing02;
10292
- }, ";" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"));
10361
+ }, ";" + ( "/*# 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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"));
10293
10362
  var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10294
10363
  var lastFocus = React.useRef();
10295
10364
  var headingRef = React.useRef();
@@ -10375,7 +10444,8 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10375
10444
  props.onClose && typeof props.onClose === 'function' && props.onClose();
10376
10445
  }, 300);
10377
10446
  }
10378
- var children = props.children,
10447
+ var ariaLabel = props.ariaLabel,
10448
+ children = props.children,
10379
10449
  closeAriaLabel = props.closeAriaLabel,
10380
10450
  closeButtonSize = props.closeButtonSize,
10381
10451
  containerStyle = props.containerStyle,
@@ -10401,11 +10471,20 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10401
10471
  return isModalOpen ? ReactDOM.createPortal(React.createElement("div", {
10402
10472
  ref: focusTrapElement
10403
10473
  }, React.createElement(core.Global, {
10404
- styles: /*#__PURE__*/core.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2MsD","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/core';\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, props.header ? headingRef : null, 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        }\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 { 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\": \"modal\", \"aria-describedby\": \"modal\", \"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 }))))),\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 })), document.getElementsByTagName('body')[0])\r\n        : null;\r\n});\r\n//# sourceMappingURL=Modal.js.map"]} */"))
10405
- }), React.createElement(ModalContainer, Object.assign({
10474
+ styles: /*#__PURE__*/core.css("html{overflow:", isOpen ? 'hidden' : 'auto', ";};label:styles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2MsD","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/core';\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, props.header ? headingRef : null, 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        }\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"]} */"))
10475
+ }), React.createElement(ModalBackdrop, {
10476
+ "data-testid": "modal-backdrop",
10477
+ isExiting: isExiting,
10478
+ onMouseDown: isBackgroundClickDisabled ? function (event) {
10479
+ return event.preventDefault();
10480
+ } : null,
10481
+ fade: true,
10482
+ isOpen: isModalOpen,
10483
+ unmountOnExit: true,
10484
+ theme: theme
10485
+ }, React.createElement(ModalContainer, Object.assign({
10406
10486
  "aria-labelledby": header ? headingId : null,
10407
- "aria-label": "modal",
10408
- "aria-describedby": "modal",
10487
+ "aria-label": !header ? ariaLabel : null,
10409
10488
  "aria-modal": true,
10410
10489
  "data-testid": testId,
10411
10490
  id: id,
@@ -10446,17 +10525,7 @@ var Modal = /*#__PURE__*/React.forwardRef(function (props, ref) {
10446
10525
  onClick: handleClose,
10447
10526
  testId: "modal-closebtn",
10448
10527
  variant: exports.ButtonVariant.link
10449
- })))), React.createElement(ModalBackdrop, {
10450
- "data-testid": "modal-backdrop",
10451
- isExiting: isExiting,
10452
- onMouseDown: isBackgroundClickDisabled ? function (event) {
10453
- return event.preventDefault();
10454
- } : null,
10455
- fade: true,
10456
- isOpen: isModalOpen,
10457
- unmountOnExit: true,
10458
- theme: theme
10459
- })), document.getElementsByTagName('body')[0]) : null;
10528
+ })))))), document.getElementsByTagName('body')[0]) : null;
10460
10529
  });
10461
10530
 
10462
10531
  var _excluded$1j = ["iconAriaLabel", "isClearable", "isInverse", "isLoading", "labelText", "placeholder", "onSearch", "onClear"];
@@ -10827,13 +10896,13 @@ function Select(props) {
10827
10896
  event.preventDefault();
10828
10897
  openMenu();
10829
10898
  }
10830
- _onKeyDown && typeof _onKeyDown === 'function' && _onKeyDown(event);
10899
+ _onKeyDown && typeof _onKeyDown === 'function' && (_onKeyDown == null ? void 0 : _onKeyDown(event));
10831
10900
  },
10832
10901
  onKeyPress: function onKeyPress(event) {
10833
- return _onKeyPress(event);
10902
+ return _onKeyPress == null ? void 0 : _onKeyPress(event);
10834
10903
  },
10835
10904
  onKeyUp: function onKeyUp(event) {
10836
- return _onKeyUp(event);
10905
+ return _onKeyUp == null ? void 0 : _onKeyUp(event);
10837
10906
  },
10838
10907
  onFocus: onFocus,
10839
10908
  ref: ref
@@ -10998,13 +11067,13 @@ function MultiSelect(props) {
10998
11067
  event.preventDefault();
10999
11068
  openMenu();
11000
11069
  }
11001
- _onKeyDown && typeof _onKeyDown === 'function' && _onKeyDown(event);
11070
+ _onKeyDown && typeof _onKeyDown === 'function' && (_onKeyDown == null ? void 0 : _onKeyDown(event));
11002
11071
  },
11003
11072
  onKeyPress: function onKeyPress(event) {
11004
- return _onKeyPress(event);
11073
+ return _onKeyPress == null ? void 0 : _onKeyPress(event);
11005
11074
  },
11006
11075
  onKeyUp: function onKeyUp(event) {
11007
- return _onKeyUp(event);
11076
+ return _onKeyUp == null ? void 0 : _onKeyUp(event);
11008
11077
  },
11009
11078
  onFocus: onFocus,
11010
11079
  preventKeyAction: isOpen
@@ -11050,7 +11119,7 @@ function MultiSelect(props) {
11050
11119
  },
11051
11120
  theme: theme,
11052
11121
  isInverse: isInverse
11053
- }), multiSelectedItemString, React.createElement(IconWrapper$5, null, React.createElement(reactMagmaIcons.CloseIcon, {
11122
+ }), multiSelectedItemString, React.createElement(IconWrapper$6, null, React.createElement(reactMagmaIcons.CloseIcon, {
11054
11123
  size: theme.iconSizes.xSmall
11055
11124
  })));
11056
11125
  }) : typeof placeholder === 'string' ? React.createElement(SelectText, null, placeholder) : React.createElement(SelectText, null, i18n.multiSelect.placeholder)), React.createElement(ItemsList, {
@@ -11763,7 +11832,7 @@ function MultiCombobox(props) {
11763
11832
  theme: theme,
11764
11833
  isInverse: isInverse,
11765
11834
  type: exports.ButtonType.button
11766
- }), itemToString(multiSelectedItem), React.createElement(IconWrapper$5, null, React.createElement(reactMagmaIcons.CloseIcon, {
11835
+ }), itemToString(multiSelectedItem), React.createElement(IconWrapper$6, null, React.createElement(reactMagmaIcons.CloseIcon, {
11767
11836
  size: theme.iconSizes.xSmall
11768
11837
  })));
11769
11838
  })) : null;
@@ -11945,7 +12014,343 @@ var SkipLinkContent = function SkipLinkContent(props) {
11945
12014
  }, children);
11946
12015
  };
11947
12016
 
11948
- var _excluded$1p = ["children", "color", "labelText", "onClick", "onDelete", "isInverse", "size", "testId"];
12017
+ var _excluded$1p = ["ariaLabel", "breakpoint", "breakpointLayout", "children", "currentStep", "layout", "stepLabel", "isInverse", "testId"];
12018
+ var _templateObject$D, _templateObject2$e, _templateObject3$b, _templateObject4$6, _templateObject5$2;
12019
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$y() { 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)."; }
12020
+ (function (StepperLayout) {
12021
+ StepperLayout["showLabels"] = "showLabels";
12022
+ StepperLayout["hideLabels"] = "hideLabels";
12023
+ StepperLayout["summaryView"] = "summaryView";
12024
+ })(exports.StepperLayout || (exports.StepperLayout = {}));
12025
+ function buildSeparatorBackgroundColors(props) {
12026
+ var isInverse = props.isInverse,
12027
+ theme = props.theme,
12028
+ stepStatus = props.stepStatus;
12029
+ if (isInverse) {
12030
+ if (stepStatus === StepStatus.completed) {
12031
+ return theme.colors.tertiary500;
12032
+ }
12033
+ return theme.colors.primary400;
12034
+ } else {
12035
+ if (stepStatus === StepStatus.completed) {
12036
+ return theme.colors.primary500;
12037
+ }
12038
+ return theme.colors.neutral300;
12039
+ }
12040
+ }
12041
+ var typedStyled$D = _styled;
12042
+ var StyledStepper = /*#__PURE__*/typedStyled$D.div(_templateObject$D || (_templateObject$D = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex: 1;\n flex-direction: column;\n"])));
12043
+ var StyledStepContent = /*#__PURE__*/typedStyled$D.ol(_templateObject2$e || (_templateObject2$e = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n margin: 0;\n padding: 0;\n"])));
12044
+ var _ref$6 = {
12045
+ name: "1osgo7l-StyledLiWrapper",
12046
+ styles: "position:relative;flex:1;;label:StyledLiWrapper;",
12047
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Stepper.tsx"],"names":[],"mappings":"AA2CU","file":"Stepper.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { Step, StepStatus } from './Step';\r\nimport { transparentize } from 'polished';\r\nimport { I18nContext } from '../../i18n';\r\nexport var StepperLayout;\r\n(function (StepperLayout) {\r\n    StepperLayout[\"showLabels\"] = \"showLabels\";\r\n    StepperLayout[\"hideLabels\"] = \"hideLabels\";\r\n    StepperLayout[\"summaryView\"] = \"summaryView\";\r\n})(StepperLayout || (StepperLayout = {}));\r\nfunction buildSeparatorBackgroundColors(props) {\r\n    const { isInverse, theme, stepStatus } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        return theme.colors.primary400;\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed) {\r\n            return theme.colors.primary500;\r\n        }\r\n        return theme.colors.neutral300;\r\n    }\r\n}\r\nconst typedStyled = styled;\r\nconst StyledStepper = typedStyled.div `\n  display: flex;\n  flex: 1;\n  flex-direction: column;\n`;\r\nconst StyledStepContent = typedStyled.ol `\n  display: flex;\n  margin: 0;\n  padding: 0;\n`;\r\nconst StyledLiWrapper = typedStyled.li `\n  list-style-type: none;\n  ${props => props.hasLabels\r\n    ? css `\n          position: relative;\n          flex: 1;\n        `\r\n    : css `\n          display: contents;\n        `}\n`;\r\nconst StyledSeparator = typedStyled.div `\n  background: ${buildSeparatorBackgroundColors};\n  width: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'calc(100% - 24px)'\r\n    : '100%'};\n  height: 2px;\n  top: 11px;\n  left: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'calc(50% + 12px)'\r\n    : ''};\n  position: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'absolute'\r\n    : 'relative'};\n  align-self: baseline;\n  transition: all 0.4s ease;\n`;\r\nconst StyledSummary = typedStyled.div `\n  display: flex;\n  flex-direction: column;\n  position:relative;\n  font-size: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  span {\n    display: flex;\n    text-align: left;\n  }\n  svg {\n    height: 0;\n  }\n  div > span:first-child {\n    height: auto;\n    margin: 0;\n  }\n  div span {\n    margin: 3px 0;\n    span:first-child {\n      margin: 0\n    }\n    span:last-child {\n      margin: 4px 0 0 0;\n    } \n  }\n`;\r\n// Stepper!\r\nexport const Stepper = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, breakpoint, breakpointLayout, children, currentStep, layout = StepperLayout.showLabels, stepLabel, isInverse: isInverseProp, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    // Controls the varying layouts with a set breakpoint number between a breakpointLayout type and / or a layout type.\r\n    const [showLabelsLayout, setShowLabelsLayout] = React.useState(false);\r\n    const [hideLabelsLayout, setHideLabelsLayout] = React.useState(false);\r\n    const [summaryViewLayout, setSummaryViewLayout] = React.useState(false);\r\n    React.useEffect(() => {\r\n        setHideLabelsLayout(layout === StepperLayout.hideLabels);\r\n        setShowLabelsLayout(layout === StepperLayout.showLabels);\r\n        setSummaryViewLayout(layout === StepperLayout.summaryView);\r\n    }, [layout]);\r\n    React.useEffect(() => {\r\n        setHideLabelsLayout(breakpointLayout === StepperLayout.hideLabels);\r\n        setShowLabelsLayout(breakpointLayout === StepperLayout.showLabels);\r\n        setSummaryViewLayout(breakpointLayout === StepperLayout.summaryView);\r\n    }, [breakpointLayout]);\r\n    const [windowWidth, setWindowWidth] = React.useState(window.innerWidth);\r\n    React.useEffect(() => {\r\n        function handleResize() {\r\n            setWindowWidth(window.innerWidth);\r\n            if (window.innerWidth < breakpoint && breakpoint) {\r\n                setShowLabelsLayout(breakpointLayout === StepperLayout.showLabels);\r\n                setHideLabelsLayout(breakpointLayout === StepperLayout.hideLabels);\r\n                setSummaryViewLayout(breakpointLayout === StepperLayout.summaryView);\r\n            }\r\n            if (window.innerWidth > breakpoint || !breakpoint) {\r\n                setShowLabelsLayout(layout === StepperLayout.showLabels);\r\n                setHideLabelsLayout(layout === StepperLayout.hideLabels);\r\n                setSummaryViewLayout(layout === StepperLayout.summaryView);\r\n            }\r\n            if (showLabelsLayout) {\r\n                setHideLabelsLayout(false);\r\n                setSummaryViewLayout(false);\r\n            }\r\n            else if (hideLabelsLayout) {\r\n                setShowLabelsLayout(false);\r\n                setSummaryViewLayout(false);\r\n            }\r\n            else if (summaryViewLayout) {\r\n                setShowLabelsLayout(false);\r\n                setHideLabelsLayout(false);\r\n            }\r\n        }\r\n        window.addEventListener('resize', handleResize);\r\n        handleResize();\r\n        return () => window.removeEventListener('resize', handleResize);\r\n    }, [windowWidth]);\r\n    const stepperChildren = React.Children.toArray(children);\r\n    const numberOfSteps = stepperChildren.length;\r\n    let allStepsHaveLabels = false;\r\n    let allStepsHaveSecondaryLabels = false;\r\n    for (const stepChild of stepperChildren) {\r\n        if (React.isValidElement(stepChild)) {\r\n            if (Object.keys(stepChild.props).includes('label')) {\r\n                allStepsHaveLabels = true;\r\n            }\r\n            if (Object.keys(stepChild.props).includes('secondaryLabel')) {\r\n                allStepsHaveSecondaryLabels = true;\r\n            }\r\n        }\r\n    }\r\n    const stepContent = React.Children.map(children, (child, index) => {\r\n        if (child.type === Step) {\r\n            const stepStatusStyles = currentStep >= index + 1\r\n                ? StepStatus.completed\r\n                : currentStep >= index\r\n                    ? StepStatus.active\r\n                    : StepStatus.incomplete;\r\n            const item = React.cloneElement(child, {\r\n                isInverse,\r\n                index,\r\n                layout: summaryViewLayout\r\n                    ? StepperLayout.summaryView\r\n                    : hideLabelsLayout\r\n                        ? StepperLayout.hideLabels\r\n                        : StepperLayout.showLabels,\r\n                stepLabel: stepLabel || i18n.stepper.stepLabel,\r\n                stepStatus: stepStatusStyles,\r\n            });\r\n            const stepAndSeparator = () => {\r\n                return [\r\n                    item,\r\n                    index !== numberOfSteps - 1 && (React.createElement(StyledSeparator, { key: `separator-${index}`, isInverse: isInverse, bothLabels: allStepsHaveLabels && allStepsHaveSecondaryLabels, allStepsHaveLabels: allStepsHaveLabels, secondaryLabel: allStepsHaveSecondaryLabels, showLabelsLayout: showLabelsLayout, stepStatus: stepStatusStyles, theme: theme })),\r\n                ];\r\n            };\r\n            return (React.createElement(StyledLiWrapper, { \"aria-current\": currentStep === index ? 'step' : false, hasLabels: showLabelsLayout &&\r\n                    (allStepsHaveLabels || allStepsHaveSecondaryLabels) }, stepAndSeparator()));\r\n        }\r\n    });\r\n    // When summaryView is set to true, this shows one step label and description at a time based on the active step below the Stepper component.\r\n    const getSummaryStepLabels = () => React.Children.map(children, (child, index) => {\r\n        const item = child;\r\n        if (item.type === Step && currentStep === index) {\r\n            return item;\r\n        }\r\n    });\r\n    // Final step description\r\n    const completionLabel = props.completionLabel || i18n.stepper.completionLabel;\r\n    return (React.createElement(StyledStepper, Object.assign({}, rest, { \"data-testid\": testId, ref: ref }),\r\n        React.createElement(StyledStepContent, { \"aria-label\": ariaLabel, theme: theme }, stepContent),\r\n        summaryViewLayout && (React.createElement(StyledSummary, { \"data-testid\": testId && `${testId}-stepper-summary`, isInverse: isInverse, theme: theme },\r\n            currentStep < numberOfSteps\r\n                ? stepLabel\r\n                    ? `${stepLabel} ${currentStep + 1} ${i18n.stepper.stepOfLabel} ${numberOfSteps}`\r\n                    : `${i18n.stepper.stepLabel} \n          ${currentStep + 1} ${i18n.stepper.stepOfLabel} ${numberOfSteps}`\r\n                : completionLabel,\r\n            getSummaryStepLabels()))));\r\n});\r\n//# sourceMappingURL=Stepper.js.map"]} */",
12048
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$y
12049
+ };
12050
+ var _ref2$1 = {
12051
+ name: "1pfxik0-StyledLiWrapper",
12052
+ styles: "display:contents;;label:StyledLiWrapper;",
12053
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Stepper.tsx"],"names":[],"mappings":"AA+CU","file":"Stepper.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { css } from '@emotion/core';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { Step, StepStatus } from './Step';\r\nimport { transparentize } from 'polished';\r\nimport { I18nContext } from '../../i18n';\r\nexport var StepperLayout;\r\n(function (StepperLayout) {\r\n    StepperLayout[\"showLabels\"] = \"showLabels\";\r\n    StepperLayout[\"hideLabels\"] = \"hideLabels\";\r\n    StepperLayout[\"summaryView\"] = \"summaryView\";\r\n})(StepperLayout || (StepperLayout = {}));\r\nfunction buildSeparatorBackgroundColors(props) {\r\n    const { isInverse, theme, stepStatus } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        return theme.colors.primary400;\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed) {\r\n            return theme.colors.primary500;\r\n        }\r\n        return theme.colors.neutral300;\r\n    }\r\n}\r\nconst typedStyled = styled;\r\nconst StyledStepper = typedStyled.div `\n  display: flex;\n  flex: 1;\n  flex-direction: column;\n`;\r\nconst StyledStepContent = typedStyled.ol `\n  display: flex;\n  margin: 0;\n  padding: 0;\n`;\r\nconst StyledLiWrapper = typedStyled.li `\n  list-style-type: none;\n  ${props => props.hasLabels\r\n    ? css `\n          position: relative;\n          flex: 1;\n        `\r\n    : css `\n          display: contents;\n        `}\n`;\r\nconst StyledSeparator = typedStyled.div `\n  background: ${buildSeparatorBackgroundColors};\n  width: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'calc(100% - 24px)'\r\n    : '100%'};\n  height: 2px;\n  top: 11px;\n  left: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'calc(50% + 12px)'\r\n    : ''};\n  position: ${props => props.showLabelsLayout &&\r\n    (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel)\r\n    ? 'absolute'\r\n    : 'relative'};\n  align-self: baseline;\n  transition: all 0.4s ease;\n`;\r\nconst StyledSummary = typedStyled.div `\n  display: flex;\n  flex-direction: column;\n  position:relative;\n  font-size: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight};\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  span {\n    display: flex;\n    text-align: left;\n  }\n  svg {\n    height: 0;\n  }\n  div > span:first-child {\n    height: auto;\n    margin: 0;\n  }\n  div span {\n    margin: 3px 0;\n    span:first-child {\n      margin: 0\n    }\n    span:last-child {\n      margin: 4px 0 0 0;\n    } \n  }\n`;\r\n// Stepper!\r\nexport const Stepper = React.forwardRef((props, ref) => {\r\n    const { ariaLabel, breakpoint, breakpointLayout, children, currentStep, layout = StepperLayout.showLabels, stepLabel, isInverse: isInverseProp, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    // Controls the varying layouts with a set breakpoint number between a breakpointLayout type and / or a layout type.\r\n    const [showLabelsLayout, setShowLabelsLayout] = React.useState(false);\r\n    const [hideLabelsLayout, setHideLabelsLayout] = React.useState(false);\r\n    const [summaryViewLayout, setSummaryViewLayout] = React.useState(false);\r\n    React.useEffect(() => {\r\n        setHideLabelsLayout(layout === StepperLayout.hideLabels);\r\n        setShowLabelsLayout(layout === StepperLayout.showLabels);\r\n        setSummaryViewLayout(layout === StepperLayout.summaryView);\r\n    }, [layout]);\r\n    React.useEffect(() => {\r\n        setHideLabelsLayout(breakpointLayout === StepperLayout.hideLabels);\r\n        setShowLabelsLayout(breakpointLayout === StepperLayout.showLabels);\r\n        setSummaryViewLayout(breakpointLayout === StepperLayout.summaryView);\r\n    }, [breakpointLayout]);\r\n    const [windowWidth, setWindowWidth] = React.useState(window.innerWidth);\r\n    React.useEffect(() => {\r\n        function handleResize() {\r\n            setWindowWidth(window.innerWidth);\r\n            if (window.innerWidth < breakpoint && breakpoint) {\r\n                setShowLabelsLayout(breakpointLayout === StepperLayout.showLabels);\r\n                setHideLabelsLayout(breakpointLayout === StepperLayout.hideLabels);\r\n                setSummaryViewLayout(breakpointLayout === StepperLayout.summaryView);\r\n            }\r\n            if (window.innerWidth > breakpoint || !breakpoint) {\r\n                setShowLabelsLayout(layout === StepperLayout.showLabels);\r\n                setHideLabelsLayout(layout === StepperLayout.hideLabels);\r\n                setSummaryViewLayout(layout === StepperLayout.summaryView);\r\n            }\r\n            if (showLabelsLayout) {\r\n                setHideLabelsLayout(false);\r\n                setSummaryViewLayout(false);\r\n            }\r\n            else if (hideLabelsLayout) {\r\n                setShowLabelsLayout(false);\r\n                setSummaryViewLayout(false);\r\n            }\r\n            else if (summaryViewLayout) {\r\n                setShowLabelsLayout(false);\r\n                setHideLabelsLayout(false);\r\n            }\r\n        }\r\n        window.addEventListener('resize', handleResize);\r\n        handleResize();\r\n        return () => window.removeEventListener('resize', handleResize);\r\n    }, [windowWidth]);\r\n    const stepperChildren = React.Children.toArray(children);\r\n    const numberOfSteps = stepperChildren.length;\r\n    let allStepsHaveLabels = false;\r\n    let allStepsHaveSecondaryLabels = false;\r\n    for (const stepChild of stepperChildren) {\r\n        if (React.isValidElement(stepChild)) {\r\n            if (Object.keys(stepChild.props).includes('label')) {\r\n                allStepsHaveLabels = true;\r\n            }\r\n            if (Object.keys(stepChild.props).includes('secondaryLabel')) {\r\n                allStepsHaveSecondaryLabels = true;\r\n            }\r\n        }\r\n    }\r\n    const stepContent = React.Children.map(children, (child, index) => {\r\n        if (child.type === Step) {\r\n            const stepStatusStyles = currentStep >= index + 1\r\n                ? StepStatus.completed\r\n                : currentStep >= index\r\n                    ? StepStatus.active\r\n                    : StepStatus.incomplete;\r\n            const item = React.cloneElement(child, {\r\n                isInverse,\r\n                index,\r\n                layout: summaryViewLayout\r\n                    ? StepperLayout.summaryView\r\n                    : hideLabelsLayout\r\n                        ? StepperLayout.hideLabels\r\n                        : StepperLayout.showLabels,\r\n                stepLabel: stepLabel || i18n.stepper.stepLabel,\r\n                stepStatus: stepStatusStyles,\r\n            });\r\n            const stepAndSeparator = () => {\r\n                return [\r\n                    item,\r\n                    index !== numberOfSteps - 1 && (React.createElement(StyledSeparator, { key: `separator-${index}`, isInverse: isInverse, bothLabels: allStepsHaveLabels && allStepsHaveSecondaryLabels, allStepsHaveLabels: allStepsHaveLabels, secondaryLabel: allStepsHaveSecondaryLabels, showLabelsLayout: showLabelsLayout, stepStatus: stepStatusStyles, theme: theme })),\r\n                ];\r\n            };\r\n            return (React.createElement(StyledLiWrapper, { \"aria-current\": currentStep === index ? 'step' : false, hasLabels: showLabelsLayout &&\r\n                    (allStepsHaveLabels || allStepsHaveSecondaryLabels) }, stepAndSeparator()));\r\n        }\r\n    });\r\n    // When summaryView is set to true, this shows one step label and description at a time based on the active step below the Stepper component.\r\n    const getSummaryStepLabels = () => React.Children.map(children, (child, index) => {\r\n        const item = child;\r\n        if (item.type === Step && currentStep === index) {\r\n            return item;\r\n        }\r\n    });\r\n    // Final step description\r\n    const completionLabel = props.completionLabel || i18n.stepper.completionLabel;\r\n    return (React.createElement(StyledStepper, Object.assign({}, rest, { \"data-testid\": testId, ref: ref }),\r\n        React.createElement(StyledStepContent, { \"aria-label\": ariaLabel, theme: theme }, stepContent),\r\n        summaryViewLayout && (React.createElement(StyledSummary, { \"data-testid\": testId && `${testId}-stepper-summary`, isInverse: isInverse, theme: theme },\r\n            currentStep < numberOfSteps\r\n                ? stepLabel\r\n                    ? `${stepLabel} ${currentStep + 1} ${i18n.stepper.stepOfLabel} ${numberOfSteps}`\r\n                    : `${i18n.stepper.stepLabel} \n          ${currentStep + 1} ${i18n.stepper.stepOfLabel} ${numberOfSteps}`\r\n                : completionLabel,\r\n            getSummaryStepLabels()))));\r\n});\r\n//# sourceMappingURL=Stepper.js.map"]} */",
12054
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$y
12055
+ };
12056
+ var StyledLiWrapper = /*#__PURE__*/typedStyled$D.li(_templateObject3$b || (_templateObject3$b = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n list-style-type: none;\n ", "\n"])), function (props) {
12057
+ return props.hasLabels ? _ref$6 : _ref2$1;
12058
+ });
12059
+ var StyledSeparator = /*#__PURE__*/typedStyled$D.div(_templateObject4$6 || (_templateObject4$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n width: ", ";\n height: 2px;\n top: 11px;\n left: ", ";\n position: ", ";\n align-self: baseline;\n transition: all 0.4s ease;\n"])), buildSeparatorBackgroundColors, function (props) {
12060
+ return props.showLabelsLayout && (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel) ? 'calc(100% - 24px)' : '100%';
12061
+ }, function (props) {
12062
+ return props.showLabelsLayout && (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel) ? 'calc(50% + 12px)' : '';
12063
+ }, function (props) {
12064
+ return props.showLabelsLayout && (props.bothLabels || props.allStepsHaveLabels || props.secondaryLabel) ? 'absolute' : 'relative';
12065
+ });
12066
+ var StyledSummary = /*#__PURE__*/typedStyled$D.div(_templateObject5$2 || (_templateObject5$2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n position:relative;\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n color: ", ";\n span {\n display: flex;\n text-align: left;\n }\n svg {\n height: 0;\n }\n div > span:first-child {\n height: auto;\n margin: 0;\n }\n div span {\n margin: 3px 0;\n span:first-child {\n margin: 0\n }\n span:last-child {\n margin: 4px 0 0 0;\n } \n }\n"])), function (props) {
12067
+ return props.theme.typographyVisualStyles.bodySmall.desktop.fontSize;
12068
+ }, function (props) {
12069
+ return props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing;
12070
+ }, function (props) {
12071
+ return props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight;
12072
+ }, function (props) {
12073
+ return props.isInverse ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500;
12074
+ });
12075
+ // Stepper!
12076
+ var Stepper = /*#__PURE__*/React.forwardRef(function (props, ref) {
12077
+ var ariaLabel = props.ariaLabel,
12078
+ breakpoint = props.breakpoint,
12079
+ breakpointLayout = props.breakpointLayout,
12080
+ children = props.children,
12081
+ currentStep = props.currentStep,
12082
+ _props$layout = props.layout,
12083
+ layout = _props$layout === void 0 ? exports.StepperLayout.showLabels : _props$layout,
12084
+ stepLabel = props.stepLabel,
12085
+ isInverseProp = props.isInverse,
12086
+ testId = props.testId,
12087
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1p);
12088
+ var theme = React.useContext(ThemeContext);
12089
+ var i18n = React.useContext(I18nContext);
12090
+ var isInverse = useIsInverse(isInverseProp);
12091
+ // Controls the varying layouts with a set breakpoint number between a breakpointLayout type and / or a layout type.
12092
+ var _React$useState = React.useState(false),
12093
+ showLabelsLayout = _React$useState[0],
12094
+ setShowLabelsLayout = _React$useState[1];
12095
+ var _React$useState2 = React.useState(false),
12096
+ hideLabelsLayout = _React$useState2[0],
12097
+ setHideLabelsLayout = _React$useState2[1];
12098
+ var _React$useState3 = React.useState(false),
12099
+ summaryViewLayout = _React$useState3[0],
12100
+ setSummaryViewLayout = _React$useState3[1];
12101
+ React.useEffect(function () {
12102
+ setHideLabelsLayout(layout === exports.StepperLayout.hideLabels);
12103
+ setShowLabelsLayout(layout === exports.StepperLayout.showLabels);
12104
+ setSummaryViewLayout(layout === exports.StepperLayout.summaryView);
12105
+ }, [layout]);
12106
+ React.useEffect(function () {
12107
+ setHideLabelsLayout(breakpointLayout === exports.StepperLayout.hideLabels);
12108
+ setShowLabelsLayout(breakpointLayout === exports.StepperLayout.showLabels);
12109
+ setSummaryViewLayout(breakpointLayout === exports.StepperLayout.summaryView);
12110
+ }, [breakpointLayout]);
12111
+ var _React$useState4 = React.useState(window.innerWidth),
12112
+ windowWidth = _React$useState4[0],
12113
+ setWindowWidth = _React$useState4[1];
12114
+ React.useEffect(function () {
12115
+ function handleResize() {
12116
+ setWindowWidth(window.innerWidth);
12117
+ if (window.innerWidth < breakpoint && breakpoint) {
12118
+ setShowLabelsLayout(breakpointLayout === exports.StepperLayout.showLabels);
12119
+ setHideLabelsLayout(breakpointLayout === exports.StepperLayout.hideLabels);
12120
+ setSummaryViewLayout(breakpointLayout === exports.StepperLayout.summaryView);
12121
+ }
12122
+ if (window.innerWidth > breakpoint || !breakpoint) {
12123
+ setShowLabelsLayout(layout === exports.StepperLayout.showLabels);
12124
+ setHideLabelsLayout(layout === exports.StepperLayout.hideLabels);
12125
+ setSummaryViewLayout(layout === exports.StepperLayout.summaryView);
12126
+ }
12127
+ if (showLabelsLayout) {
12128
+ setHideLabelsLayout(false);
12129
+ setSummaryViewLayout(false);
12130
+ } else if (hideLabelsLayout) {
12131
+ setShowLabelsLayout(false);
12132
+ setSummaryViewLayout(false);
12133
+ } else if (summaryViewLayout) {
12134
+ setShowLabelsLayout(false);
12135
+ setHideLabelsLayout(false);
12136
+ }
12137
+ }
12138
+ window.addEventListener('resize', handleResize);
12139
+ handleResize();
12140
+ return function () {
12141
+ return window.removeEventListener('resize', handleResize);
12142
+ };
12143
+ }, [windowWidth]);
12144
+ var stepperChildren = React.Children.toArray(children);
12145
+ var numberOfSteps = stepperChildren.length;
12146
+ var allStepsHaveLabels = false;
12147
+ var allStepsHaveSecondaryLabels = false;
12148
+ for (var _iterator = _createForOfIteratorHelperLoose(stepperChildren), _step; !(_step = _iterator()).done;) {
12149
+ var stepChild = _step.value;
12150
+ if (React.isValidElement(stepChild)) {
12151
+ if (Object.keys(stepChild.props).includes('label')) {
12152
+ allStepsHaveLabels = true;
12153
+ }
12154
+ if (Object.keys(stepChild.props).includes('secondaryLabel')) {
12155
+ allStepsHaveSecondaryLabels = true;
12156
+ }
12157
+ }
12158
+ }
12159
+ var stepContent = React.Children.map(children, function (child, index) {
12160
+ if (child.type === Step) {
12161
+ var stepStatusStyles = currentStep >= index + 1 ? StepStatus.completed : currentStep >= index ? StepStatus.active : StepStatus.incomplete;
12162
+ var item = React.cloneElement(child, {
12163
+ isInverse: isInverse,
12164
+ index: index,
12165
+ layout: summaryViewLayout ? exports.StepperLayout.summaryView : hideLabelsLayout ? exports.StepperLayout.hideLabels : exports.StepperLayout.showLabels,
12166
+ stepLabel: stepLabel || i18n.stepper.stepLabel,
12167
+ stepStatus: stepStatusStyles
12168
+ });
12169
+ var stepAndSeparator = function stepAndSeparator() {
12170
+ return [item, index !== numberOfSteps - 1 && React.createElement(StyledSeparator, {
12171
+ key: "separator-" + index,
12172
+ isInverse: isInverse,
12173
+ bothLabels: allStepsHaveLabels && allStepsHaveSecondaryLabels,
12174
+ allStepsHaveLabels: allStepsHaveLabels,
12175
+ secondaryLabel: allStepsHaveSecondaryLabels,
12176
+ showLabelsLayout: showLabelsLayout,
12177
+ stepStatus: stepStatusStyles,
12178
+ theme: theme
12179
+ })];
12180
+ };
12181
+ return React.createElement(StyledLiWrapper, {
12182
+ "aria-current": currentStep === index ? 'step' : false,
12183
+ hasLabels: showLabelsLayout && (allStepsHaveLabels || allStepsHaveSecondaryLabels)
12184
+ }, stepAndSeparator());
12185
+ }
12186
+ });
12187
+ // When summaryView is set to true, this shows one step label and description at a time based on the active step below the Stepper component.
12188
+ var getSummaryStepLabels = function getSummaryStepLabels() {
12189
+ return React.Children.map(children, function (child, index) {
12190
+ var item = child;
12191
+ if (item.type === Step && currentStep === index) {
12192
+ return item;
12193
+ }
12194
+ });
12195
+ };
12196
+ // Final step description
12197
+ var completionLabel = props.completionLabel || i18n.stepper.completionLabel;
12198
+ return React.createElement(StyledStepper, Object.assign({}, rest, {
12199
+ "data-testid": testId,
12200
+ ref: ref
12201
+ }), React.createElement(StyledStepContent, {
12202
+ "aria-label": ariaLabel,
12203
+ theme: theme
12204
+ }, stepContent), summaryViewLayout && React.createElement(StyledSummary, {
12205
+ "data-testid": testId && testId + "-stepper-summary",
12206
+ isInverse: isInverse,
12207
+ theme: theme
12208
+ }, currentStep < numberOfSteps ? stepLabel ? stepLabel + " " + (currentStep + 1) + " " + i18n.stepper.stepOfLabel + " " + numberOfSteps : i18n.stepper.stepLabel + " \n " + (currentStep + 1) + " " + i18n.stepper.stepOfLabel + " " + numberOfSteps : completionLabel, getSummaryStepLabels()));
12209
+ });
12210
+
12211
+ var _excluded$1q = ["hasError", "index", "label", "layout", "secondaryLabel", "stepLabel", "testId", "isInverse", "stepStatus"];
12212
+ var _templateObject$E, _templateObject2$f, _templateObject3$c, _templateObject4$7, _templateObject5$3, _templateObject6$1;
12213
+ var StepStatus;
12214
+ (function (StepStatus) {
12215
+ StepStatus["active"] = "active";
12216
+ StepStatus["completed"] = "completed";
12217
+ StepStatus["incomplete"] = "incomplete";
12218
+ })(StepStatus || (StepStatus = {}));
12219
+ function buildStepCircleOutlineColors(props) {
12220
+ var isInverse = props.isInverse,
12221
+ stepStatus = props.stepStatus,
12222
+ hasError = props.hasError,
12223
+ theme = props.theme;
12224
+ if (isInverse && !hasError) {
12225
+ if (stepStatus === StepStatus.active) {
12226
+ return theme.colors.tertiary500;
12227
+ } else if (stepStatus === StepStatus.incomplete) {
12228
+ return theme.colors.primary400;
12229
+ }
12230
+ } else {
12231
+ if (!isInverse && !hasError) {
12232
+ if (stepStatus === StepStatus.active) {
12233
+ return theme.colors.primary500;
12234
+ } else if (stepStatus === StepStatus.incomplete) {
12235
+ return theme.colors.neutral300;
12236
+ }
12237
+ }
12238
+ }
12239
+ }
12240
+ function buildStepCircleBackgroundColors(props) {
12241
+ var isInverse = props.isInverse,
12242
+ stepStatus = props.stepStatus,
12243
+ hasError = props.hasError,
12244
+ theme = props.theme;
12245
+ if (isInverse) {
12246
+ if (stepStatus === StepStatus.completed && !hasError) {
12247
+ return theme.colors.tertiary500;
12248
+ } else if (hasError) {
12249
+ return theme.colors.danger500;
12250
+ }
12251
+ } else {
12252
+ if (stepStatus === StepStatus.completed && !hasError) {
12253
+ return theme.colors.primary500;
12254
+ } else if (hasError) {
12255
+ return theme.colors.danger500;
12256
+ }
12257
+ }
12258
+ }
12259
+ function buildStepLabelColors(props) {
12260
+ var label = props.label,
12261
+ secondaryLabel = props.secondaryLabel,
12262
+ theme = props.theme,
12263
+ isInverse = props.isInverse;
12264
+ if (isInverse) {
12265
+ if (label) {
12266
+ return theme.colors.neutral100;
12267
+ } else if (secondaryLabel) {
12268
+ return polished.transparentize(0.3, theme.colors.neutral100);
12269
+ }
12270
+ } else {
12271
+ if (label) {
12272
+ return theme.colors.neutral700;
12273
+ } else if (secondaryLabel) {
12274
+ return theme.colors.neutral500;
12275
+ }
12276
+ }
12277
+ }
12278
+ function buildStepSvgColors(props) {
12279
+ var theme = props.theme,
12280
+ hasError = props.hasError,
12281
+ isInverse = props.isInverse;
12282
+ if (isInverse) {
12283
+ if (hasError) {
12284
+ return theme.colors.neutral100;
12285
+ }
12286
+ return theme.colors.primary600;
12287
+ } else {
12288
+ return theme.colors.neutral100;
12289
+ }
12290
+ }
12291
+ var typedStyled$E = _styled;
12292
+ var HiddenLabelText$2 = /*#__PURE__*/typedStyled$E.span(_templateObject$E || (_templateObject$E = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", ";\n"])), HiddenStyles);
12293
+ var StyledStep = /*#__PURE__*/typedStyled$E.div(_templateObject2$f || (_templateObject2$f = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n justify-content: center;\n text-align: center;\n align-self: self-start;\n align-items: center;\n"])));
12294
+ var StyledStepIndicator = /*#__PURE__*/typedStyled$E.span(_templateObject3$c || (_templateObject3$c = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n width: 24px;\n height: 24px;\n box-shadow: inset 0 0 0 2px\n ", ";\n background: ", ";\n svg {\n color: ", ";\n width: ", "px;\n height: ", "px;\n }\n"])), function (props) {
12295
+ return props.stepStatus === StepStatus.incomplete && !props.hasError || props.stepStatus === StepStatus.active && !props.hasError ? buildStepCircleOutlineColors : 'none';
12296
+ }, buildStepCircleBackgroundColors, buildStepSvgColors, function (props) {
12297
+ return props.theme.iconSizes.xSmall;
12298
+ }, function (props) {
12299
+ return props.theme.iconSizes.xSmall;
12300
+ });
12301
+ var StyledStepTextWrapper = /*#__PURE__*/typedStyled$E.span(_templateObject4$7 || (_templateObject4$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n flex: 1;\n display: flex;\n align-self: center;\n flex-direction: column;\n position: relative;\n margin: 6px 8px 0;\n"])));
12302
+ var StyledLabel$2 = /*#__PURE__*/typedStyled$E.span(_templateObject5$3 || (_templateObject5$3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n color: ", ";\n font-weight: 600;\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n"])), buildStepLabelColors, function (props) {
12303
+ return props.theme.typographyVisualStyles.bodySmall.desktop.fontSize;
12304
+ }, function (props) {
12305
+ return props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing;
12306
+ }, function (props) {
12307
+ return props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight;
12308
+ });
12309
+ var StyledSecondaryLabel = /*#__PURE__*/typedStyled$E.span(_templateObject6$1 || (_templateObject6$1 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n color: ", ";\n font-size: ", ";\n letter-spacing: ", ";\n line-height: ", ";\n margin: 2px 12px 0 12px;\n"])), buildStepLabelColors, function (props) {
12310
+ return props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize;
12311
+ }, function (props) {
12312
+ return props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing;
12313
+ }, function (props) {
12314
+ return props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight;
12315
+ });
12316
+ var Step = /*#__PURE__*/React.forwardRef(function (props, ref) {
12317
+ var hasError = props.hasError,
12318
+ label = props.label,
12319
+ layout = props.layout,
12320
+ secondaryLabel = props.secondaryLabel,
12321
+ stepLabel = props.stepLabel,
12322
+ testId = props.testId,
12323
+ isInverseProp = props.isInverse,
12324
+ stepStatus = props.stepStatus,
12325
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1q);
12326
+ var theme = React.useContext(ThemeContext);
12327
+ var isInverse = useIsInverse(isInverseProp);
12328
+ return React.createElement(StyledStep, Object.assign({}, rest, {
12329
+ ref: ref,
12330
+ "data-testid": testId
12331
+ }), React.createElement(StyledStepIndicator, {
12332
+ hasError: hasError,
12333
+ isInverse: isInverse,
12334
+ stepStatus: stepStatus,
12335
+ theme: theme
12336
+ }, stepStatus === StepStatus.completed && !hasError && React.createElement(reactMagmaIcons.CheckIcon, {
12337
+ "aria-hidden": "true"
12338
+ }), hasError && React.createElement(reactMagmaIcons.CrossIcon, {
12339
+ "aria-hidden": "true"
12340
+ })), React.createElement(StyledStepTextWrapper, null, layout !== exports.StepperLayout.hideLabels && layout !== exports.StepperLayout.summaryView ? React.createElement(React.Fragment, null, layout === exports.StepperLayout.showLabels && React.createElement(HiddenLabelText$2, null, "" + (stepStatus === StepStatus.completed ? stepLabel + " " + stepStatus + ", " : '')), label && React.createElement(StyledLabel$2, {
12341
+ label: label,
12342
+ isInverse: isInverse,
12343
+ "data-testid": testId && testId + "-label",
12344
+ theme: theme
12345
+ }, label), secondaryLabel && React.createElement(StyledSecondaryLabel, {
12346
+ secondaryLabel: secondaryLabel,
12347
+ isInverse: isInverse,
12348
+ "data-testid": testId && testId + "-secondaryLabel",
12349
+ theme: theme
12350
+ }, secondaryLabel)) : layout !== exports.StepperLayout.summaryView && React.createElement(HiddenLabelText$2, null, "" + (stepStatus === StepStatus.completed ? stepLabel + " " + stepStatus + ", " : '') + (label || '') + (secondaryLabel ? ' ' : '') + (secondaryLabel || ''))));
12351
+ });
12352
+
12353
+ var _excluded$1r = ["children", "color", "labelText", "onClick", "onDelete", "isInverse", "size", "testId"];
11949
12354
  (function (TagColor) {
11950
12355
  TagColor["default"] = "default";
11951
12356
  TagColor["primary"] = "primary";
@@ -12146,7 +12551,7 @@ var Tag = /*#__PURE__*/React.forwardRef(function (props, ref) {
12146
12551
  isInverseProp = props.isInverse,
12147
12552
  _props$size = props.size,
12148
12553
  size = _props$size === void 0 ? exports.TagSize.medium : _props$size,
12149
- rest = _objectWithoutPropertiesLoose(props, _excluded$1p);
12554
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1r);
12150
12555
  var theme = React.useContext(ThemeContext);
12151
12556
  var isInverse = useIsInverse(isInverseProp);
12152
12557
  var i18n = React.useContext(I18nContext);
@@ -12201,7 +12606,7 @@ var ToastsContainer = /*#__PURE__*/React.forwardRef(function (props, ref) {
12201
12606
  }, children));
12202
12607
  });
12203
12608
 
12204
- var _excluded$1q = ["alertStyle", "id", "testId", "variant", "disableAutoDismiss", "children", "containerStyle", "toastDuration"];
12609
+ var _excluded$1s = ["alertStyle", "id", "testId", "variant", "disableAutoDismiss", "children", "containerStyle", "toastDuration"];
12205
12610
  var ToastWrapper = /*#__PURE__*/_styled$1("div", {
12206
12611
  target: "e1kwf3vk0",
12207
12612
  label: "ToastWrapper"
@@ -12233,7 +12638,7 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
12233
12638
  children = props.children,
12234
12639
  containerStyle = props.containerStyle,
12235
12640
  toastDuration = props.toastDuration,
12236
- other = _objectWithoutPropertiesLoose(props, _excluded$1q);
12641
+ other = _objectWithoutPropertiesLoose(props, _excluded$1s);
12237
12642
  var id = useGenerateId(defaultId);
12238
12643
  var lastFocus = React.useRef();
12239
12644
  var _React$useContext = React.useContext(ToastsContext),
@@ -12348,8 +12753,8 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
12348
12753
  }), children));
12349
12754
  });
12350
12755
 
12351
- var _excluded$1r = ["containerStyle", "checked", "defaultChecked", "disabled", "errorMessage", "id", "isTextVisuallyHidden", "labelStyle", "labelText", "onChange", "textPosition", "testId", "trackStyle", "thumbStyle"];
12352
- function _EMOTION_STRINGIFIED_CSS_ERROR__$y() { 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)."; }
12756
+ var _excluded$1t = ["containerStyle", "checked", "defaultChecked", "disabled", "errorMessage", "id", "isTextVisuallyHidden", "labelStyle", "labelText", "onChange", "textPosition", "testId", "trackStyle", "thumbStyle"];
12757
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$z() { 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)."; }
12353
12758
  (function (ToggleTextPosition) {
12354
12759
  ToggleTextPosition["left"] = "left";
12355
12760
  ToggleTextPosition["right"] = "right";
@@ -12384,7 +12789,7 @@ function buildToggleBorderColor(props) {
12384
12789
  }
12385
12790
  return props.theme.colors.neutral;
12386
12791
  }
12387
- var HiddenLabelText$2 = /*#__PURE__*/_styled$1("span", {
12792
+ var HiddenLabelText$3 = /*#__PURE__*/_styled$1("span", {
12388
12793
  target: "ehddq0c0",
12389
12794
  label: "HiddenLabelText"
12390
12795
  })(HiddenStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkDoC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
@@ -12412,11 +12817,11 @@ var Track$1 = /*#__PURE__*/_styled$1("span", {
12412
12817
  }, ";border-radius:50%;content:'';display:block;height:40px;left:-12px;opacity:0;margin-top:-22px;padding:50%;position:absolute;top:50%;transform:scale(1);transition:opacity 1s,transform 0.25s;width:40px;", function (props) {
12413
12818
  return props.isChecked && /*#__PURE__*/core.css("background:", props.theme.colors.success, ";left:12px;;label:Track;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoHQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
12414
12819
  }, "}", HiddenInput$2, ":not(:disabled):active + label &{&:before{opacity:0.4;transform:scale(0);transition:transform 0s;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwD0B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
12415
- var _ref$6 = {
12820
+ var _ref$7 = {
12416
12821
  name: "gnym0k-Thumb",
12417
12822
  styles: "left:24px;;label:Thumb;",
12418
12823
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
12419
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$y
12824
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$z
12420
12825
  };
12421
12826
  var Thumb = /*#__PURE__*/_styled$1("span", {
12422
12827
  target: "ehddq0c3",
@@ -12424,7 +12829,7 @@ var Thumb = /*#__PURE__*/_styled$1("span", {
12424
12829
  })("background:", function (props) {
12425
12830
  return props.isInverse && props.disabled ? polished.transparentize(0.6, props.theme.colors.neutral100) : props.theme.colors.neutral100;
12426
12831
  }, ";border-radius:100%;height:20px;left:0;margin-top:-10px;position:absolute;top:50%;transition:left 0.25s;width:20px;", function (props) {
12427
- return props.isChecked && _ref$6;
12832
+ return props.isChecked && _ref$7;
12428
12833
  }, "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkI0B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */");
12429
12834
  var IconContainer = /*#__PURE__*/_styled$1("span", {
12430
12835
  target: "ehddq0c4",
@@ -12443,7 +12848,7 @@ var SpanTextLeft$1 = /*#__PURE__*/_styled$1("span", {
12443
12848
  name: "1p2jtab",
12444
12849
  styles: "padding-right:10px;",
12445
12850
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
12446
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$y
12851
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$z
12447
12852
  });
12448
12853
  var SpanTextRight$1 = /*#__PURE__*/_styled$1("span", {
12449
12854
  target: "ehddq0c6",
@@ -12452,11 +12857,11 @@ var SpanTextRight$1 = /*#__PURE__*/_styled$1("span", {
12452
12857
  name: "m6sx0v",
12453
12858
  styles: "padding-left:10px;",
12454
12859
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiKkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { CheckIcon } from 'react-magma-icons';\r\nimport { FormGroupContext } from '../FormGroup';\r\nimport { InputMessage } from '../Input/InputMessage';\r\nimport { StyledLabel } from '../SelectionControls/StyledLabel';\r\nimport { StyledContainer } from '../SelectionControls/StyledContainer';\r\nimport { css } from '@emotion/core';\r\n// Using the base `styled` from `emotion` until import mapping is fixed: https://github.com/emotion-js/emotion/pull/1220\r\n// import styled from '../../theme/styled';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useGenerateId } from '../../utils';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nexport var ToggleTextPosition;\r\n(function (ToggleTextPosition) {\r\n    ToggleTextPosition[\"left\"] = \"left\";\r\n    ToggleTextPosition[\"right\"] = \"right\";\r\n})(ToggleTextPosition || (ToggleTextPosition = {}));\r\nexport function buildIconContainerColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            if (props.isChecked) {\r\n                return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n            return 'transparent';\r\n        }\r\n        return props.theme.colors.success200;\r\n    }\r\n    if (props.disabled) {\r\n        return transparentize(0.6, props.theme.colors.neutral);\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nfunction buildToggleBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.hasError) {\r\n            return props.theme.colors.danger200;\r\n        }\r\n        return transparentize(0.5, props.theme.colors.neutral100);\r\n    }\r\n    if (props.hasError) {\r\n        return props.theme.colors.danger;\r\n    }\r\n    if (props.isChecked) {\r\n        return props.theme.colors.success;\r\n    }\r\n    return props.theme.colors.neutral;\r\n}\r\nconst HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst HiddenInput = styled.input `\n  ${HiddenStyles};\n`;\r\nconst Track = styled.span `\n  background: ${props => props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral};\n  border: 2px solid;\n  border-color: ${props => buildToggleBorderColor(props)};\n  border-radius: 12px;\n  box-shadow: ${props => props.isInverse && props.hasError\r\n    ? `0 0 0 1px ${props.theme.colors.neutral100}`\r\n    : '0 0 0'};\n  cursor: pointer;\n  height: 24px;\n  position: relative;\n  width: 48px;\n\n  ${props => props.isChecked &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : props.theme.colors.success};\n      border-color: ${buildToggleBorderColor(props)};\n    `}\n\n  ${props => props.disabled &&\r\n    css `\n      background: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral300};\n      border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n      cursor: not-allowed;\n    `}\n\n  ${HiddenInput}:focus + label & {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 2px;\n  }\n\n  &:before {\n    // active state\n    background: ${props => props.theme.colors.neutral};\n    border-radius: 50%;\n    content: '';\n    display: block;\n    height: 40px;\n    left: -12px;\n    opacity: 0;\n    margin-top: -22px;\n    padding: 50%;\n    position: absolute;\n    top: 50%;\n    transform: scale(1);\n    transition: opacity 1s, transform 0.25s;\n    width: 40px;\n\n    ${props => props.isChecked &&\r\n    css `\n        background: ${props.theme.colors.success};\n        left: 12px;\n      `}\n  }\n\n  ${HiddenInput}:not(:disabled):active + label & {\n    &:before {\n      opacity: 0.4;\n      transform: scale(0);\n      transition: transform 0s;\n    }\n  }\n`;\r\nconst Thumb = styled.span `\n  background: ${props => props.isInverse && props.disabled\r\n    ? transparentize(0.6, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral100};\n  border-radius: 100%;\n  height: 20px;\n  left: 0;\n  margin-top: -10px;\n  position: absolute;\n  top: 50%;\n  transition: left 0.25s;\n  width: 20px;\n\n  ${props => props.isChecked &&\r\n    css `\n      left: 24px;\n    `}\n`;\r\nconst IconContainer = styled.span `\n  color: ${props => buildIconContainerColor(props)};\n  left: ${props => props.theme.spaceScale.spacing02};\n  position: absolute;\n  top: ${props => props.theme.spaceScale.spacing01};\n\n  svg {\n    display: block;\n  }\n`;\r\nconst SpanTextLeft = styled.span `\n  padding-right: 10px;\n`;\r\nconst SpanTextRight = styled.span `\n  padding-left: 10px;\n`;\r\nconst renderLabelText = (isTextVisuallyHidden, labelText, textPosition, labelStyle) => {\r\n    if (isTextVisuallyHidden) {\r\n        return React.createElement(HiddenLabelText, null, labelText);\r\n    }\r\n    return textPosition === ToggleTextPosition.left ? (React.createElement(SpanTextLeft, { style: labelStyle }, labelText)) : (React.createElement(SpanTextRight, { style: labelStyle }, labelText));\r\n};\r\nexport const Toggle = React.forwardRef((props, ref) => {\r\n    const { containerStyle, checked, defaultChecked, disabled, errorMessage, id: defaultId, isTextVisuallyHidden, labelStyle, labelText, onChange, textPosition, testId, trackStyle, thumbStyle, ...other } = props;\r\n    const [isChecked, updateIsChecked] = React.useState(Boolean(defaultChecked) || Boolean(checked));\r\n    const id = useGenerateId(defaultId);\r\n    const isControlled = typeof checked === 'boolean' ? true : false;\r\n    React.useEffect(() => {\r\n        if (typeof checked === 'boolean') {\r\n            updateIsChecked(checked);\r\n        }\r\n    }, [checked]);\r\n    function handleChange(event) {\r\n        const { checked: targetChecked } = event.target;\r\n        onChange && typeof onChange === 'function' && onChange(event);\r\n        if (!isControlled) {\r\n            updateIsChecked(targetChecked);\r\n        }\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const context = React.useContext(FormGroupContext);\r\n    const descriptionId = errorMessage ? `${id}__desc` : null;\r\n    const groupDescriptionId = context.descriptionId;\r\n    const describedBy = descriptionId && groupDescriptionId\r\n        ? `${groupDescriptionId} ${descriptionId}`\r\n        : descriptionId\r\n            ? descriptionId\r\n            : groupDescriptionId\r\n                ? groupDescriptionId\r\n                : null;\r\n    const hasError = context.hasError || !!errorMessage;\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(StyledContainer, null,\r\n            React.createElement(HiddenInput, Object.assign({}, other, { \"aria-checked\": isChecked, \"aria-describedby\": describedBy, id: id, \"data-testid\": testId, disabled: disabled, checked: isChecked, type: \"checkbox\", onChange: handleChange, ref: ref, role: \"switch\" })),\r\n            React.createElement(StyledLabel, { htmlFor: id, isInverse: isInverse, style: containerStyle },\r\n                textPosition !== ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.left, labelStyle),\r\n                React.createElement(Track, { isChecked: isChecked, \"data-testid\": \"toggle-track\", disabled: disabled, hasError: hasError, isInverse: isInverse, style: trackStyle, theme: theme },\r\n                    React.createElement(IconContainer, { disabled: disabled, theme: theme, isInverse: isInverse, isChecked: isChecked },\r\n                        React.createElement(CheckIcon, { size: theme.iconSizes.xSmall })),\r\n                    React.createElement(Thumb, { isChecked: isChecked, isInverse: isInverse, disabled: disabled, style: thumbStyle, theme: theme })),\r\n                textPosition === ToggleTextPosition.right &&\r\n                    renderLabelText(isTextVisuallyHidden, labelText, ToggleTextPosition.right, labelStyle))),\r\n        !!errorMessage && (React.createElement(InputMessage, { id: descriptionId, hasError: true, isInverse: isInverse }, errorMessage))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
12455
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$y
12860
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$z
12456
12861
  });
12457
12862
  var renderLabelText = function renderLabelText(isTextVisuallyHidden, labelText, textPosition, labelStyle) {
12458
12863
  if (isTextVisuallyHidden) {
12459
- return React.createElement(HiddenLabelText$2, null, labelText);
12864
+ return React.createElement(HiddenLabelText$3, null, labelText);
12460
12865
  }
12461
12866
  return textPosition === exports.ToggleTextPosition.left ? React.createElement(SpanTextLeft$1, {
12462
12867
  style: labelStyle
@@ -12479,7 +12884,7 @@ var Toggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
12479
12884
  testId = props.testId,
12480
12885
  trackStyle = props.trackStyle,
12481
12886
  thumbStyle = props.thumbStyle,
12482
- other = _objectWithoutPropertiesLoose(props, _excluded$1r);
12887
+ other = _objectWithoutPropertiesLoose(props, _excluded$1t);
12483
12888
  var _React$useState = React.useState(Boolean(defaultChecked) || Boolean(checked)),
12484
12889
  isChecked = _React$useState[0],
12485
12890
  updateIsChecked = _React$useState[1];
@@ -12547,7 +12952,7 @@ var Toggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
12547
12952
  }, errorMessage));
12548
12953
  });
12549
12954
 
12550
- var _excluded$1s = ["containerStyle", "errorMessage", "hasCharacterCounter", "helperMessage", "id", "isLabelVisuallyHidden", "labelPosition", "labelStyle", "labelText", "labelWidth", "maxCount", "maxLength", "messageStyle", "testId", "textareaStyle"];
12955
+ var _excluded$1u = ["containerStyle", "errorMessage", "hasCharacterCounter", "helperMessage", "id", "isLabelVisuallyHidden", "labelPosition", "labelStyle", "labelText", "labelWidth", "maxCount", "maxLength", "messageStyle", "testId", "textareaStyle"];
12551
12956
  var StyledTextArea = /*#__PURE__*/_styled$1("textarea", {
12552
12957
  target: "ez5uhpx0",
12553
12958
  label: "StyledTextArea"
@@ -12571,7 +12976,7 @@ var Textarea = /*#__PURE__*/React.forwardRef(function (props, ref) {
12571
12976
  maxLength = props.maxLength,
12572
12977
  testId = props.testId,
12573
12978
  textareaStyle = props.textareaStyle,
12574
- other = _objectWithoutPropertiesLoose(props, _excluded$1s);
12979
+ other = _objectWithoutPropertiesLoose(props, _excluded$1u);
12575
12980
  var theme = React.useContext(ThemeContext);
12576
12981
  var id = useGenerateId(defaultId);
12577
12982
  var descriptionId = errorMessage || helperMessage ? id + "__desc" : null;
@@ -12626,7 +13031,7 @@ var Textarea = /*#__PURE__*/React.forwardRef(function (props, ref) {
12626
13031
  })));
12627
13032
  });
12628
13033
 
12629
- var _excluded$1t = ["children"];
13034
+ var _excluded$1v = ["children"];
12630
13035
  var StyledAmPmToggle = /*#__PURE__*/_styled$1("button", {
12631
13036
  target: "e1x92wsu0",
12632
13037
  label: "StyledAmPmToggle"
@@ -12641,7 +13046,7 @@ var StyledAmPmToggle = /*#__PURE__*/_styled$1("button", {
12641
13046
  }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFtUG1Ub2dnbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd1QyIsImZpbGUiOiJBbVBtVG9nZ2xlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5jb25zdCBTdHlsZWRBbVBtVG9nZ2xlID0gc3R5bGVkLmJ1dHRvbiBgXG4gIGJhY2tncm91bmQ6IG5vbmU7XG4gIGJvcmRlcjogMDtcbiAgYm9yZGVyLXJhZGl1czogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib3JkZXJSYWRpdXNTbWFsbH07XG4gIG1hcmdpbi1sZWZ0OiAzcHg7XG4gIHBhZGRpbmc6IDAgM3B4O1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAwO1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlID8gcHJvcHMudGhlbWUuY29sb3JzLnRlcnRpYXJ5IDogcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQW1QbVRvZ2dsZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFtUG1Ub2dnbGUsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogXCJhbVBtVGltZUJ1dHRvblwiLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lLCB0eXBlOiBcImJ1dHRvblwiIH0pLCBjaGlsZHJlbikpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QW1QbVRvZ2dsZS5qcy5tYXAiXX0= */"));
12642
13047
  var AmPmToggle = /*#__PURE__*/React.forwardRef(function (props, ref) {
12643
13048
  var children = props.children,
12644
- other = _objectWithoutPropertiesLoose(props, _excluded$1t);
13049
+ other = _objectWithoutPropertiesLoose(props, _excluded$1v);
12645
13050
  var theme = React.useContext(ThemeContext);
12646
13051
  return React.createElement(StyledAmPmToggle, Object.assign({}, other, {
12647
13052
  "data-testid": "amPmTimeButton",
@@ -12799,11 +13204,11 @@ function useTimePicker(props) {
12799
13204
  };
12800
13205
  }
12801
13206
 
12802
- var _excluded$1u = ["containerStyle", "errorMessage", "helperMessage", "inputStyle", "labelPosition", "labelStyle", "labelText", "labelWidth", "minutesStep", "onChange"];
12803
- var _templateObject$D, _templateObject2$d;
12804
- function _EMOTION_STRINGIFIED_CSS_ERROR__$z() { 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)."; }
12805
- var typedStyled$D = _styled;
12806
- var InputsContainer = /*#__PURE__*/typedStyled$D.div(_templateObject$D || (_templateObject$D = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", ";\n height: ", ";\n padding: ", ";\n width: 144px;\n font-family: ", ";\n"])), inputWrapperStyles, function (props) {
13207
+ var _excluded$1w = ["containerStyle", "errorMessage", "helperMessage", "inputStyle", "labelPosition", "labelStyle", "labelText", "labelWidth", "minutesStep", "onChange"];
13208
+ var _templateObject$F, _templateObject2$g;
13209
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$A() { 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)."; }
13210
+ var typedStyled$F = _styled;
13211
+ var InputsContainer = /*#__PURE__*/typedStyled$F.div(_templateObject$F || (_templateObject$F = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", ";\n height: ", ";\n padding: ", ";\n width: 144px;\n font-family: ", ";\n"])), inputWrapperStyles, function (props) {
12807
13212
  return props.theme.spaceScale.spacing09;
12808
13213
  }, function (props) {
12809
13214
  return props.theme.spaceScale.spacing03;
@@ -12817,9 +13222,9 @@ var Divider = /*#__PURE__*/_styled$1("span", {
12817
13222
  name: "668i4v",
12818
13223
  styles: "display:inline-block;margin:0 2px;position:relative;top:-1px;",
12819
13224
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpbWVQaWNrZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9CNEIiLCJmaWxlIjoiVGltZVBpY2tlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBBbVBtVG9nZ2xlIH0gZnJvbSAnLi9BbVBtVG9nZ2xlJztcclxuaW1wb3J0IHsgU2NoZWR1bGVJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyB1c2VUaW1lUGlja2VyIH0gZnJvbSAnLi91c2VUaW1lUGlja2VyJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIgfSBmcm9tICcuLi9Gb3JtRmllbGRDb250YWluZXInO1xyXG5pbXBvcnQgeyBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IHR5cGVkU3R5bGVkID0gc3R5bGVkO1xyXG5jb25zdCBJbnB1dHNDb250YWluZXIgPSB0eXBlZFN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc307XG4gIGhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOX07XG4gIHBhZGRpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICB3aWR0aDogMTQ0cHg7XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbmA7XHJcbmNvbnN0IERpdmlkZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgbWFyZ2luOiAwIDJweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB0b3A6IC0xcHg7XG5gO1xyXG5jb25zdCBTdHlsZWROdW1JbnB1dCA9IHR5cGVkU3R5bGVkLmlucHV0IGBcbiAgYm9yZGVyOiAwO1xuICBib3JkZXItcmFkaXVzOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvcmRlclJhZGl1c1NtYWxsfTtcbiAgbWFyZ2luLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgdGV4dC1hbGlnbjogcmlnaHQ7XG4gIHdpZHRoOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA2fTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG5cbiAgJjo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG4gICAgLXdlYmtpdC1hcHBlYXJhbmNlOiBub25lO1xuICB9XG5cbiAgLW1vei1hcHBlYXJhbmNlOiB0ZXh0ZmllbGQ7XG5cbiAgJjo6cGxhY2Vob2xkZXIge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIH1cblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAwO1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy50ZXJ0aWFyeVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gICAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsOTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcblxuICAgICY6OnBsYWNlaG9sZGVyIHtcbiAgICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgVGltZVBpY2tlciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgY29uc3QgeyBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBpbnB1dFN0eWxlLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1pbnV0ZXNTdGVwLCBvbkNoYW5nZSwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCB7IGFtLCBhbVBtLCBhbVBtUmVmLCBkZXNjcmlwdGlvbklkLCBob3VyLCBob3VySWQsIGhvdXJSZWYsIGlkLCB0aW1lLCBtaW51dGUsIG1pbnV0ZUlkLCBtaW51dGVSZWYsIHRvZ2dsZUFtUG0sIGhhbmRsZUhvdXJDaGFuZ2UsIGhhbmRsZU1pbnV0ZUNoYW5nZSwgaGFuZGxlSG91cktleURvd24sIGhhbmRsZU1pbnV0ZUtleURvd24sIGhhbmRsZUFtUG1LZXlEb3duLCB9ID0gdXNlVGltZVBpY2tlcihwcm9wcyk7XHJcbiAgICBjb25zdCBob3Vyc0xhYmVsID0gYCR7bGFiZWxUZXh0fSwgJHtpMThuLnRpbWVQaWNrZXIuaG91cnNBcmlhTGFiZWx9YDtcclxuICAgIGNvbnN0IG1pbnV0ZXNMYWJlbCA9IGAke2xhYmVsVGV4dH0sICR7aTE4bi50aW1lUGlja2VyLm1pbnV0ZXNBcmlhTGFiZWx9YDtcclxuICAgIGNvbnN0IGFtUG1MYWJlbCA9IGAke2xhYmVsVGV4dH0sICR7YW1QbSA9PT0gYW1cclxuICAgICAgICA/IGkxOG4udGltZVBpY2tlci5hbUJ1dHRvbkFyaWFMYWJlbFxyXG4gICAgICAgIDogaTE4bi50aW1lUGlja2VyLnBtQnV0dG9uQXJpYUxhYmVsfWA7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoRm9ybUZpZWxkQ29udGFpbmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZTogZXJyb3JNZXNzYWdlLCBmaWVsZElkOiBpZCwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGxhYmVsVGV4dDogbGFiZWxUZXh0LCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRzQ29udGFpbmVyLCB7IGlzSW52ZXJzZTogaXNJbnZlcnNlLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNjaGVkdWxlSWNvbiwgeyBjb2xvcjogaXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbDcwMCwgc3R5bGU6IHsgbWFyZ2luUmlnaHQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTnVtSW5wdXQsIHsgXCJhcmlhLWxhYmVsXCI6IGhvdXJzTGFiZWwsIFwiYXJpYS1kZXNjcmliZWRieVwiOiBkZXNjcmlwdGlvbklkLCBcImRhdGEtdGVzdGlkXCI6IFwiaG91cnNUaW1lSW5wdXRcIiwgaWQ6IGhvdXJJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG1heExlbmd0aDogMiwgbWF4OiBcIjEyXCIsIG1pbjogXCIxXCIsIG9uQ2hhbmdlOiBoYW5kbGVIb3VyQ2hhbmdlLCBvbktleURvd246IGUgPT4gaGFuZGxlSG91cktleURvd24oZSwgaGFuZGxlSG91ckNoYW5nZSksIHBsYWNlaG9sZGVyOiBcIi0tXCIsIHJlZjogaG91clJlZiwgdGhlbWU6IHRoZW1lLCB0eXBlOiBcIm51bWJlclwiLCB2YWx1ZTogaG91ciB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEaXZpZGVyLCBudWxsLCBcIiA6IFwiKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROdW1JbnB1dCwgeyBcImFyaWEtbGFiZWxcIjogbWludXRlc0xhYmVsLCBcImRhdGEtdGVzdGlkXCI6IFwibWludXRlc1RpbWVJbnB1dFwiLCBpZDogbWludXRlSWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBtYXhMZW5ndGg6IDIsIG1heDogXCI1OVwiLCBtaW46IFwiMFwiLCBvbkNoYW5nZTogaGFuZGxlTWludXRlQ2hhbmdlLCBvbktleURvd246IGUgPT4gaGFuZGxlTWludXRlS2V5RG93bihlLCBoYW5kbGVNaW51dGVDaGFuZ2UpLCBwbGFjZWhvbGRlcjogXCItLVwiLCByZWY6IG1pbnV0ZVJlZiwgc3RlcDogbWludXRlc1N0ZXAgfHwgMSwgdGhlbWU6IHRoZW1lLCB0eXBlOiBcIm51bWJlclwiLCB2YWx1ZTogbWludXRlIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFtUG1Ub2dnbGUsIHsgXCJhcmlhLWxhYmVsXCI6IGFtUG1MYWJlbCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogYW1QbVJlZiwgb25DbGljazogdG9nZ2xlQW1QbSwgb25LZXlEb3duOiBoYW5kbGVBbVBtS2V5RG93biB9LCBhbVBtKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQW5ub3VuY2UsIG51bGwsIGFtUG0gPT09IGFtXHJcbiAgICAgICAgICAgICAgICAgICAgPyBpMThuLnRpbWVQaWNrZXIuYW1TZWxlY3RlZEFubm91bmNlXHJcbiAgICAgICAgICAgICAgICAgICAgOiBpMThuLnRpbWVQaWNrZXIucG1TZWxlY3RlZEFubm91bmNlKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJpbnB1dFwiLCB7IGlkOiBpZCwgcmVmOiByZWYsIHR5cGU6IFwiaGlkZGVuXCIsIHZhbHVlOiB0aW1lIH0pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UaW1lUGlja2VyLmpzLm1hcCJdfQ== */",
12820
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$z
13225
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$A
12821
13226
  });
12822
- var StyledNumInput = /*#__PURE__*/typedStyled$D.input(_templateObject2$d || (_templateObject2$d = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n border-radius: ", ";\n margin-right: ", ";\n padding: 0 ", ";\n text-align: right;\n width: ", ";\n color: ", ";\n background: transparent;\n\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n }\n\n -moz-appearance: textfield;\n\n &::placeholder {\n color: ", ";\n }\n\n &:focus {\n outline: 0;\n background: ", ";\n color: ", ";\n\n &::placeholder {\n color: ", ";\n }\n }\n"])), function (props) {
13227
+ var StyledNumInput = /*#__PURE__*/typedStyled$F.input(_templateObject2$g || (_templateObject2$g = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n border: 0;\n border-radius: ", ";\n margin-right: ", ";\n padding: 0 ", ";\n text-align: right;\n width: ", ";\n color: ", ";\n background: transparent;\n\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n }\n\n -moz-appearance: textfield;\n\n &::placeholder {\n color: ", ";\n }\n\n &:focus {\n outline: 0;\n background: ", ";\n color: ", ";\n\n &::placeholder {\n color: ", ";\n }\n }\n"])), function (props) {
12823
13228
  return props.theme.borderRadiusSmall;
12824
13229
  }, function (props) {
12825
13230
  return props.theme.spaceScale.spacing01;
@@ -12848,7 +13253,7 @@ var TimePicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
12848
13253
  labelText = props.labelText,
12849
13254
  labelWidth = props.labelWidth,
12850
13255
  minutesStep = props.minutesStep,
12851
- other = _objectWithoutPropertiesLoose(props, _excluded$1u);
13256
+ other = _objectWithoutPropertiesLoose(props, _excluded$1w);
12852
13257
  var isInverse = useIsInverse(props.isInverse);
12853
13258
  var _useTimePicker = useTimePicker(props),
12854
13259
  am = _useTimePicker.am,
@@ -12941,7 +13346,7 @@ var TimePicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
12941
13346
  });
12942
13347
 
12943
13348
  function getStyles(theme, isInverse) {
12944
- return /*#__PURE__*/core.css("@import url('https://fonts.googleapis.com/css2?family=Work+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,400;0,700;1,400;1,700&display=swap');*,*:before,*:after{box-sizing:border-box;}*:focus{outline:2px solid ", isInverse ? theme.colors.focusInverse : theme.colors.focus, ";outline-offset:2px;}html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;font-size:", theme.typeScale.size03.fontSize, ";line-height:", theme.typeScale.size03.lineHeight, ";scroll-behavior:smooth;}html,body{background:", isInverse ? theme.colors.primary600 : theme.colors.neutral100, ";color:", isInverse ? theme.colors.neutral100 : theme.colors.neutral, ";margin:0;padding:0;}body{font-family:", theme.bodyFont, ";font-style:normal;font-weight:400;font-size:", theme.typeScale.size03.fontSize, ";line-height:", theme.typeScale.size03.lineHeight, ";}a{color:", isInverse ? theme.colors.tertiary : theme.colors.primary, ";cursor:pointer;text-decoration:underline;&:hover,&:focus{color:", isInverse ? theme.colors.primary100 : theme.colors.primary400, ";}&:focus{outline:2px solid ", isInverse ? theme.colors.focusInverse : theme.colors.focus, ";outline-offset:2px;}}button,input,optgroup,select,textarea{font:inherit;margin:0;}svg:not(:root){overflow:hidden;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEdsb2JhbCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5mdW5jdGlvbiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkge1xyXG4gICAgcmV0dXJuIGNzcyBgXG4gICAgQGltcG9ydCB1cmwoJ2h0dHBzOi8vZm9udHMuZ29vZ2xlYXBpcy5jb20vY3NzMj9mYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMDswLDIwMDswLDMwMDswLDQwMDswLDUwMDswLDYwMDswLDcwMDswLDgwMDswLDkwMDsxLDEwMDsxLDIwMDsxLDMwMDsxLDQwMDsxLDUwMDsxLDYwMDsxLDcwMDsxLDgwMDsxLDkwMCZkaXNwbGF5PXN3YXAnKTtcbiAgICBAaW1wb3J0IHVybCgnaHR0cHM6Ly9mb250cy5nb29nbGVhcGlzLmNvbS9jc3MyP2ZhbWlseT1Ob3RvK1NlcmlmOml0YWwsd2dodEAwLDQwMDswLDcwMDsxLDQwMDsxLDcwMCZkaXNwbGF5PXN3YXAnKTtcblxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgIH1cblxuICAgIGh0bWwge1xuICAgICAgLW1zLXRleHQtc2l6ZS1hZGp1c3Q6IDEwMCU7XG4gICAgICAtd2Via2l0LXRleHQtc2l6ZS1hZGp1c3Q6IDEwMCU7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgICAgc2Nyb2xsLWJlaGF2aW9yOiBzbW9vdGg7XG4gICAgfVxuXG4gICAgaHRtbCxcbiAgICBib2R5IHtcbiAgICAgIGJhY2tncm91bmQ6ICR7aXNJbnZlcnNlXHJcbiAgICAgICAgPyB0aGVtZS5jb2xvcnMucHJpbWFyeTYwMFxyXG4gICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gICAgICBtYXJnaW46IDA7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cblxuICAgIGJvZHkge1xuICAgICAgZm9udC1mYW1pbHk6ICR7dGhlbWUuYm9keUZvbnR9O1xuICAgICAgZm9udC1zdHlsZTogbm9ybWFsO1xuICAgICAgZm9udC13ZWlnaHQ6IDQwMDtcbiAgICAgIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgICAgIGxpbmUtaGVpZ2h0OiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gICAgfVxuXG4gICAgYSB7XG4gICAgICBjb2xvcjogJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMudGVydGlhcnkgOiB0aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gICAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcblxuICAgICAgJjpob3ZlcixcbiAgICAgICY6Zm9jdXMge1xuICAgICAgICBjb2xvcjogJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMucHJpbWFyeTEwMCA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5NDAwfTtcbiAgICAgIH1cbiAgICAgICY6Zm9jdXMge1xuICAgICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgICAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2UgOiB0aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgICAgfVxuICAgIH1cblxuICAgIGJ1dHRvbixcbiAgICBpbnB1dCxcbiAgICBvcHRncm91cCxcbiAgICBzZWxlY3QsXG4gICAgdGV4dGFyZWEge1xuICAgICAgZm9udDogaW5oZXJpdDtcbiAgICAgIG1hcmdpbjogMDtcbiAgICB9XG5cbiAgICBzdmc6bm90KDpyb290KSB7XG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIH1cbiAgYDtcclxufVxyXG5leHBvcnQgY29uc3QgR2xvYmFsU3R5bGVzID0gKCkgPT4ge1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGhlbWVDb250ZXh0LkNvbnN1bWVyLCBudWxsLCB0aGVtZSA9PiBSZWFjdC5jcmVhdGVFbGVtZW50KEdsb2JhbCwgeyBzdHlsZXM6IGdldFN0eWxlcyh0aGVtZSwgaXNJbnZlcnNlKSB9KSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
13349
+ return /*#__PURE__*/core.css("@import url('https://fonts.googleapis.com/css2?family=Work+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,400;0,700;1,400;1,700&display=swap');*,*:before,*:after{box-sizing:border-box;}*:focus{outline:2px solid ", isInverse ? theme.colors.focusInverse : theme.colors.focus, ";outline-offset:2px;}html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;font-size:", theme.typeScale.size03.fontSize, ";line-height:", theme.typeScale.size03.lineHeight, ";scroll-behavior:smooth;}html,body{background:", isInverse ? theme.colors.primary600 : theme.colors.neutral100, ";color:", isInverse ? theme.colors.neutral100 : theme.colors.neutral, ";margin:0;padding:0;}body{font-family:", theme.bodyFont, ";font-style:normal;font-weight:400;font-size:", theme.typeScale.size03.fontSize, ";line-height:", theme.typeScale.size03.lineHeight, ";}a{color:", isInverse ? theme.colors.tertiary : theme.colors.primary, ";cursor:pointer;text-decoration:underline;&:hover,&:focus{color:", isInverse ? theme.colors.neutral100 : theme.colors.primary700, ";}&:focus{outline:2px solid ", isInverse ? theme.colors.focusInverse : theme.colors.focus, ";outline-offset:2px;}}button,input,optgroup,select,textarea{font:inherit;margin:0;}svg:not(:root){overflow:hidden;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEdsb2JhbCwgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5mdW5jdGlvbiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkge1xyXG4gICAgcmV0dXJuIGNzcyBgXG4gICAgQGltcG9ydCB1cmwoJ2h0dHBzOi8vZm9udHMuZ29vZ2xlYXBpcy5jb20vY3NzMj9mYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMDswLDIwMDswLDMwMDswLDQwMDswLDUwMDswLDYwMDswLDcwMDswLDgwMDswLDkwMDsxLDEwMDsxLDIwMDsxLDMwMDsxLDQwMDsxLDUwMDsxLDYwMDsxLDcwMDsxLDgwMDsxLDkwMCZkaXNwbGF5PXN3YXAnKTtcbiAgICBAaW1wb3J0IHVybCgnaHR0cHM6Ly9mb250cy5nb29nbGVhcGlzLmNvbS9jc3MyP2ZhbWlseT1Ob3RvK1NlcmlmOml0YWwsd2dodEAwLDQwMDswLDcwMDsxLDQwMDsxLDcwMCZkaXNwbGF5PXN3YXAnKTtcblxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgIH1cblxuICAgIGh0bWwge1xuICAgICAgLW1zLXRleHQtc2l6ZS1hZGp1c3Q6IDEwMCU7XG4gICAgICAtd2Via2l0LXRleHQtc2l6ZS1hZGp1c3Q6IDEwMCU7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgICAgc2Nyb2xsLWJlaGF2aW9yOiBzbW9vdGg7XG4gICAgfVxuXG4gICAgaHRtbCxcbiAgICBib2R5IHtcbiAgICAgIGJhY2tncm91bmQ6ICR7aXNJbnZlcnNlXHJcbiAgICAgICAgPyB0aGVtZS5jb2xvcnMucHJpbWFyeTYwMFxyXG4gICAgICAgIDogdGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gICAgICBtYXJnaW46IDA7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgIH1cblxuICAgIGJvZHkge1xuICAgICAgZm9udC1mYW1pbHk6ICR7dGhlbWUuYm9keUZvbnR9O1xuICAgICAgZm9udC1zdHlsZTogbm9ybWFsO1xuICAgICAgZm9udC13ZWlnaHQ6IDQwMDtcbiAgICAgIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgICAgIGxpbmUtaGVpZ2h0OiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gICAgfVxuXG4gICAgYSB7XG4gICAgICBjb2xvcjogJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMudGVydGlhcnkgOiB0aGVtZS5jb2xvcnMucHJpbWFyeX07XG4gICAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcblxuICAgICAgJjpob3ZlcixcbiAgICAgICY6Zm9jdXMge1xuICAgICAgICBjb2xvcjogJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMubmV1dHJhbDEwMCA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5NzAwfTtcbiAgICAgIH1cbiAgICAgICY6Zm9jdXMge1xuICAgICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgICAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2UgOiB0aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgICBvdXRsaW5lLW9mZnNldDogMnB4O1xuICAgICAgfVxuICAgIH1cblxuICAgIGJ1dHRvbixcbiAgICBpbnB1dCxcbiAgICBvcHRncm91cCxcbiAgICBzZWxlY3QsXG4gICAgdGV4dGFyZWEge1xuICAgICAgZm9udDogaW5oZXJpdDtcbiAgICAgIG1hcmdpbjogMDtcbiAgICB9XG5cbiAgICBzdmc6bm90KDpyb290KSB7XG4gICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIH1cbiAgYDtcclxufVxyXG5leHBvcnQgY29uc3QgR2xvYmFsU3R5bGVzID0gKCkgPT4ge1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGhlbWVDb250ZXh0LkNvbnN1bWVyLCBudWxsLCB0aGVtZSA9PiBSZWFjdC5jcmVhdGVFbGVtZW50KEdsb2JhbCwgeyBzdHlsZXM6IGdldFN0eWxlcyh0aGVtZSwgaXNJbnZlcnNlKSB9KSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
12945
13350
  }
12946
13351
  var GlobalStyles = function GlobalStyles() {
12947
13352
  var isInverse = useIsInverse();
@@ -12985,7 +13390,7 @@ function useMediaQuery(queryInput) {
12985
13390
  return match;
12986
13391
  }
12987
13392
 
12988
- var _excluded$1v = ["style", "containerStyle", "position"];
13393
+ var _excluded$1x = ["style", "containerStyle", "position"];
12989
13394
  (function (DrawerPosition) {
12990
13395
  DrawerPosition["top"] = "top";
12991
13396
  DrawerPosition["bottom"] = "bottom";
@@ -13010,7 +13415,7 @@ var Drawer = /*#__PURE__*/React.forwardRef(function (props, ref) {
13010
13415
  var style = props.style,
13011
13416
  containerStyle = props.containerStyle,
13012
13417
  position = props.position,
13013
- rest = _objectWithoutPropertiesLoose(props, _excluded$1v);
13418
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1x);
13014
13419
  var theme = React.useContext(ThemeContext);
13015
13420
  var drawerStyle = _extends({}, theme.drawer["default"], theme.drawer[exports.DrawerPosition[position]]);
13016
13421
  return React.createElement(Modal, Object.assign({
@@ -13113,7 +13518,7 @@ var GridItem = /*#__PURE__*/_styled$1("div", {
13113
13518
  return props.gridItemAlignSelf;
13114
13519
  }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkdyaWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlFbUMiLCJmaWxlIjoiR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmV4cG9ydCB2YXIgR3JpZERpc3BsYXk7XHJcbihmdW5jdGlvbiAoR3JpZERpc3BsYXkpIHtcclxuICAgIEdyaWREaXNwbGF5W1wiZ3JpZFwiXSA9IFwiZ3JpZFwiO1xyXG4gICAgR3JpZERpc3BsYXlbXCJpbmxpbmVHcmlkXCJdID0gXCJpbmxpbmUtZ3JpZFwiO1xyXG59KShHcmlkRGlzcGxheSB8fCAoR3JpZERpc3BsYXkgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRKdXN0aWZ5SXRlbXM7XHJcbihmdW5jdGlvbiAoR3JpZEp1c3RpZnlJdGVtcykge1xyXG4gICAgR3JpZEp1c3RpZnlJdGVtc1tcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEp1c3RpZnlJdGVtc1tcImVuZFwiXSA9IFwiZW5kXCI7XHJcbiAgICBHcmlkSnVzdGlmeUl0ZW1zW1wiY2VudGVyXCJdID0gXCJjZW50ZXJcIjtcclxuICAgIEdyaWRKdXN0aWZ5SXRlbXNbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbn0pKEdyaWRKdXN0aWZ5SXRlbXMgfHwgKEdyaWRKdXN0aWZ5SXRlbXMgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRKdXN0aWZ5Q29udGVudDtcclxuKGZ1bmN0aW9uIChHcmlkSnVzdGlmeUNvbnRlbnQpIHtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEp1c3RpZnlDb250ZW50W1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzcGFjZUFyb3VuZFwiXSA9IFwic3BhY2UtYXJvdW5kXCI7XHJcbiAgICBHcmlkSnVzdGlmeUNvbnRlbnRbXCJzcGFjZUJldHdlZW5cIl0gPSBcInNwYWNlLWJldHdlZW5cIjtcclxuICAgIEdyaWRKdXN0aWZ5Q29udGVudFtcInNwYWNlRXZlbmx5XCJdID0gXCJzcGFjZS1ldmVubHlcIjtcclxufSkoR3JpZEp1c3RpZnlDb250ZW50IHx8IChHcmlkSnVzdGlmeUNvbnRlbnQgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRBbGlnbkl0ZW1zO1xyXG4oZnVuY3Rpb24gKEdyaWRBbGlnbkl0ZW1zKSB7XHJcbiAgICBHcmlkQWxpZ25JdGVtc1tcInN0YXJ0XCJdID0gXCJzdGFydFwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJlbmRcIl0gPSBcImVuZFwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgR3JpZEFsaWduSXRlbXNbXCJzdHJldGNoXCJdID0gXCJzdHJldGNoXCI7XHJcbn0pKEdyaWRBbGlnbkl0ZW1zIHx8IChHcmlkQWxpZ25JdGVtcyA9IHt9KSk7XHJcbmV4cG9ydCB2YXIgR3JpZEFsaWduQ29udGVudDtcclxuKGZ1bmN0aW9uIChHcmlkQWxpZ25Db250ZW50KSB7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3RhcnRcIl0gPSBcInN0YXJ0XCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRBbGlnbkNvbnRlbnRbXCJjZW50ZXJcIl0gPSBcImNlbnRlclwiO1xyXG4gICAgR3JpZEFsaWduQ29udGVudFtcInN0cmV0Y2hcIl0gPSBcInN0cmV0Y2hcIjtcclxuICAgIEdyaWRBbGlnbkNvbnRlbnRbXCJzcGFjZUFyb3VuZFwiXSA9IFwic3BhY2UtYXJvdW5kXCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3BhY2VCZXR3ZWVuXCJdID0gXCJzcGFjZS1iZXR3ZWVuXCI7XHJcbiAgICBHcmlkQWxpZ25Db250ZW50W1wic3BhY2VFdmVubHlcIl0gPSBcInNwYWNlLWV2ZW5seVwiO1xyXG59KShHcmlkQWxpZ25Db250ZW50IHx8IChHcmlkQWxpZ25Db250ZW50ID0ge30pKTtcclxuZXhwb3J0IHZhciBHcmlkSXRlbUp1c3RpZnlTZWxmO1xyXG4oZnVuY3Rpb24gKEdyaWRJdGVtSnVzdGlmeVNlbGYpIHtcclxuICAgIEdyaWRJdGVtSnVzdGlmeVNlbGZbXCJzdGFydFwiXSA9IFwic3RhcnRcIjtcclxuICAgIEdyaWRJdGVtSnVzdGlmeVNlbGZbXCJlbmRcIl0gPSBcImVuZFwiO1xyXG4gICAgR3JpZEl0ZW1KdXN0aWZ5U2VsZltcImNlbnRlclwiXSA9IFwiY2VudGVyXCI7XHJcbiAgICBHcmlkSXRlbUp1c3RpZnlTZWxmW1wic3RyZXRjaFwiXSA9IFwic3RyZXRjaFwiO1xyXG59KShHcmlkSXRlbUp1c3RpZnlTZWxmIHx8IChHcmlkSXRlbUp1c3RpZnlTZWxmID0ge30pKTtcclxuZXhwb3J0IHZhciBHcmlkSXRlbUFsaWduU2VsZjtcclxuKGZ1bmN0aW9uIChHcmlkSXRlbUFsaWduU2VsZikge1xyXG4gICAgR3JpZEl0ZW1BbGlnblNlbGZbXCJzdGFydFwiXSA9IFwic3RhcnRcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wiZW5kXCJdID0gXCJlbmRcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wiY2VudGVyXCJdID0gXCJjZW50ZXJcIjtcclxuICAgIEdyaWRJdGVtQWxpZ25TZWxmW1wic3RyZXRjaFwiXSA9IFwic3RyZXRjaFwiO1xyXG59KShHcmlkSXRlbUFsaWduU2VsZiB8fCAoR3JpZEl0ZW1BbGlnblNlbGYgPSB7fSkpO1xyXG5leHBvcnQgdmFyIEdyaWRBdXRvRmxvdztcclxuKGZ1bmN0aW9uIChHcmlkQXV0b0Zsb3cpIHtcclxuICAgIEdyaWRBdXRvRmxvd1tcInJvd1wiXSA9IFwicm93XCI7XHJcbiAgICBHcmlkQXV0b0Zsb3dbXCJjb2x1bW5cIl0gPSBcImNvbHVtblwiO1xyXG4gICAgR3JpZEF1dG9GbG93W1wicm93RGVuc2VcIl0gPSBcInJvdy1kZW5zZVwiO1xyXG4gICAgR3JpZEF1dG9GbG93W1wiY29sdW1uRGVuc2VcIl0gPSBcImNvbHVtbi1kZW5zZVwiO1xyXG59KShHcmlkQXV0b0Zsb3cgfHwgKEdyaWRBdXRvRmxvdyA9IHt9KSk7XHJcbmV4cG9ydCBjb25zdCBHcmlkID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZERpc3BsYXkgfHwgR3JpZERpc3BsYXkuZ3JpZH07XG4gIGdyaWQtdGVtcGxhdGUtcm93czogJHtwcm9wcyA9PiBwcm9wcy5ncmlkVGVtcGxhdGVSb3dzfTtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAke3Byb3BzID0+IHByb3BzLmdyaWRUZW1wbGF0ZUNvbHVtbnN9O1xuICBncmlkLWFyZWE6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZFRlbXBsYXRlQXJlYXN9O1xuICBncmlkLWdhcDogJHtwcm9wcyA9PiBwcm9wcy5ncmlkR2FwfTtcbiAganVzdGlmeS1pdGVtczogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSnVzdGlmeUl0ZW1zfTtcbiAganVzdGlmeS1jb250ZW50OiAke3Byb3BzID0+IHByb3BzLmdyaWRKdXN0aWZ5Q29udGVudH07XG4gIGFsaWduLWl0ZW1zOiAke3Byb3BzID0+IHByb3BzLmdyaWRBbGlnbkl0ZW1zfTtcbiAgYWxpZ24tY29udGVudDogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQWxpZ25Db250ZW50fTtcbiAgZ3JpZC1hdXRvLWZsb3c6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZEF1dG9GbG93fTtcbmA7XHJcbmV4cG9ydCBjb25zdCBHcmlkSXRlbSA9IHN0eWxlZC5kaXYgYFxuICBncmlkLWNvbHVtbjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQ29sdW1ufTtcbiAgZ3JpZC1yb3c6ICR7cHJvcHMgPT4gcHJvcHMuZ3JpZFJvd307XG4gIGdyaWQtYXJlYTogJHtwcm9wcyA9PiBwcm9wcy5ncmlkQXJlYX07XG4gIGp1c3RpZnktc2VsZjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSXRlbUp1c3RpZnlTZWxmfTtcbiAgYWxpZ24tc2VsZjogJHtwcm9wcyA9PiBwcm9wcy5ncmlkSXRlbUFsaWduU2VsZn07XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1HcmlkLmpzLm1hcCJdfQ== */"));
13115
13520
 
13116
- var _excluded$1w = ["children", "color", "description", "testId", "hasStart", "icon", "iconAlign", "iconSize", "isInverse", "isOrdered", "isReversed", "listType", "spacingStyle", "visualStyle"];
13521
+ var _excluded$1y = ["children", "color", "description", "testId", "hasStart", "icon", "iconAlign", "iconSize", "isInverse", "isOrdered", "isReversed", "listType", "spacingStyle", "visualStyle"];
13117
13522
  (function (IconSizes) {
13118
13523
  IconSizes["small"] = "small";
13119
13524
  IconSizes["medium"] = "medium";
@@ -13181,7 +13586,7 @@ var List$1 = /*#__PURE__*/React.forwardRef(function (props, ref) {
13181
13586
  listType = props.listType,
13182
13587
  spacingStyle = props.spacingStyle,
13183
13588
  visualStyle = props.visualStyle,
13184
- rest = _objectWithoutPropertiesLoose(props, _excluded$1w);
13589
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1y);
13185
13590
  var theme = React.useContext(ThemeContext);
13186
13591
  var isInverse = useIsInverse(isInverseProp);
13187
13592
  return React.createElement(InverseContext.Provider, {
@@ -13250,7 +13655,7 @@ var ListItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
13250
13655
  }, icon), children));
13251
13656
  });
13252
13657
 
13253
- var _excluded$1x = ["borderStyle", "children", "testId", "isInverse"];
13658
+ var _excluded$1z = ["borderStyle", "children", "testId", "isInverse"];
13254
13659
  var BlockQuoteStyles = function BlockQuoteStyles(props) {
13255
13660
  return /*#__PURE__*/core.css("border-left:4px solid ", props.isInverse ? props.borderStyle || props.theme.colors.neutral100 : props.borderStyle || props.theme.colors.neutral300, ";padding:10px 0 4px 20px;margin:0;font-family:", props.theme.bodyFont, ";;label:BlockQuoteStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJsb2NrUXVvdGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1zQyIsImZpbGUiOiJCbG9ja1F1b3RlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IG1hZ21hIH0gZnJvbSAnLi4vLi4vdGhlbWUvbWFnbWEnO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgQmxvY2tRdW90ZVN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJvcmRlci1sZWZ0OiA0cHggc29saWRcbiAgICAke3Byb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy5ib3JkZXJTdHlsZSB8fCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy5ib3JkZXJTdHlsZSB8fCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMH07XG4gIHBhZGRpbmc6IDEwcHggMCA0cHggMjBweDtcbiAgbWFyZ2luOiAwO1xuICBmb250LWZhbWlseTogJHtwcm9wcy50aGVtZS5ib2R5Rm9udH07XG5gO1xyXG5jb25zdCBTdHlsZWRCbG9ja1F1b3RlID0gc3R5bGVkLmZpZ3VyZSBgXG4gICR7QmxvY2tRdW90ZVN0eWxlc307XG5gO1xyXG5leHBvcnQgY29uc3QgQmxvY2tRdW90ZSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYm9yZGVyU3R5bGUsIGNoaWxkcmVuLCB0ZXN0SWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnZlcnNlQ29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogeyBpc0ludmVyc2UgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQmxvY2tRdW90ZSwgT2JqZWN0LmFzc2lnbih7IGJvcmRlclN0eWxlOiBtYWdtYS5jb2xvcnNbYm9yZGVyU3R5bGVdIHx8IGJvcmRlclN0eWxlLCB0aGVtZTogdGhlbWUsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgXCJkYXRhLXRlc3RpZFwiOiBwcm9wcy50ZXN0SWQgfSwgcmVzdCksIGNoaWxkcmVuKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QmxvY2tRdW90ZS5qcy5tYXAiXX0= */"));
13256
13661
  };
@@ -13262,7 +13667,7 @@ var BlockQuote = /*#__PURE__*/React.forwardRef(function (props, ref) {
13262
13667
  var borderStyle = props.borderStyle,
13263
13668
  children = props.children,
13264
13669
  isInverseProp = props.isInverse,
13265
- rest = _objectWithoutPropertiesLoose(props, _excluded$1x);
13670
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1z);
13266
13671
  var theme = React.useContext(ThemeContext);
13267
13672
  var isInverse = useIsInverse(isInverseProp);
13268
13673
  return React.createElement(InverseContext.Provider, {
@@ -13278,7 +13683,7 @@ var BlockQuote = /*#__PURE__*/React.forwardRef(function (props, ref) {
13278
13683
  }, rest), children));
13279
13684
  });
13280
13685
 
13281
- var _excluded$1y = ["children", "color", "hasAttribution", "testId", "visualStyle"];
13686
+ var _excluded$1A = ["children", "color", "hasAttribution", "testId", "visualStyle"];
13282
13687
  var blockQuoteStyles = function blockQuoteStyles(props) {
13283
13688
  return /*#__PURE__*/core.css("margin:0;padding:8px 0;blockquote{margin:0;}", props.isInverse && /*#__PURE__*/core.css("color:", props.theme.colors.neutral100, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJsb2NrUXVvdGVJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjUSIsImZpbGUiOiJCbG9ja1F1b3RlSXRlbS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL2NvcmUnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeVZpc3VhbFN0eWxlLCBUeXBvZ3JhcGh5Q29sb3IsIFR5cG9ncmFwaHlDb21wb25lbnQsIH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuZXhwb3J0IGNvbnN0IGJsb2NrUXVvdGVTdHlsZXMgPSBwcm9wcyA9PiBjc3MgYFxuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDhweCAwO1xuICBibG9ja3F1b3RlIHtcbiAgICBtYXJnaW46IDA7XG4gIH1cbiAgLy9JbnZlcnNlXG4gICR7cHJvcHMuaXNJbnZlcnNlICYmXHJcbiAgICBjc3MgYFxuICAgIGNvbG9yOiAke3Byb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgYH1cbmA7XHJcbmNvbnN0IFN0eWxlZEJsb2NrUXVvdGVJdGVtID0gc3R5bGVkKFR5cG9ncmFwaHlDb21wb25lbnQpIGBcbiAgJHtibG9ja1F1b3RlU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJsb2NrUXVvdGVJdGVtID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29sb3IsIGhhc0F0dHJpYnV0aW9uLCB0ZXN0SWQsIHZpc3VhbFN0eWxlLCAuLi5yZXN0IH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQmxvY2tRdW90ZUl0ZW0sIE9iamVjdC5hc3NpZ24oeyBhczogaGFzQXR0cmlidXRpb24gPyAnZmlnY2FwdGlvbicgOiAnYmxvY2txdW90ZScsIGNvbG9yOiBoYXNBdHRyaWJ1dGlvblxyXG4gICAgICAgICAgICA/IGNvbG9yIHx8IFR5cG9ncmFwaHlDb2xvci5zdWJkdWVkXHJcbiAgICAgICAgICAgIDogY29sb3IgfHwgVHlwb2dyYXBoeUNvbG9yLmRlZmF1bHQsIHRoZW1lOiB0aGVtZSwgaGFzQXR0cmlidXRpb246IGhhc0F0dHJpYnV0aW9uLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogcHJvcHMudGVzdElkLCB2aXN1YWxTdHlsZTogaGFzQXR0cmlidXRpb25cclxuICAgICAgICAgICAgPyB2aXN1YWxTdHlsZSB8fCBUeXBvZ3JhcGh5VmlzdWFsU3R5bGUuYm9keU1lZGl1bVxyXG4gICAgICAgICAgICA6IHZpc3VhbFN0eWxlIHx8IFR5cG9ncmFwaHlWaXN1YWxTdHlsZS5ib2R5TGFyZ2UgfSwgcmVzdCksIGhhc0F0dHJpYnV0aW9uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgXCJcXHUyMDE1XFx1MDBBMFwiLFxyXG4gICAgICAgIGNoaWxkcmVuKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICBcIlxcdTIwMUNcIixcclxuICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICBcIlxcdTIwMURcIikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CbG9ja1F1b3RlSXRlbS5qcy5tYXAiXX0= */")), "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJsb2NrUXVvdGVJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNNkMiLCJmaWxlIjoiQmxvY2tRdW90ZUl0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHlWaXN1YWxTdHlsZSwgVHlwb2dyYXBoeUNvbG9yLCBUeXBvZ3JhcGh5Q29tcG9uZW50LCB9IGZyb20gJy4uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmV4cG9ydCBjb25zdCBibG9ja1F1b3RlU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiA4cHggMDtcbiAgYmxvY2txdW90ZSB7XG4gICAgbWFyZ2luOiAwO1xuICB9XG4gIC8vSW52ZXJzZVxuICAke3Byb3BzLmlzSW52ZXJzZSAmJlxyXG4gICAgY3NzIGBcbiAgICBjb2xvcjogJHtwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gIGB9XG5gO1xyXG5jb25zdCBTdHlsZWRCbG9ja1F1b3RlSXRlbSA9IHN0eWxlZChUeXBvZ3JhcGh5Q29tcG9uZW50KSBgXG4gICR7YmxvY2tRdW90ZVN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBCbG9ja1F1b3RlSXRlbSA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGNvbG9yLCBoYXNBdHRyaWJ1dGlvbiwgdGVzdElkLCB2aXN1YWxTdHlsZSwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEJsb2NrUXVvdGVJdGVtLCBPYmplY3QuYXNzaWduKHsgYXM6IGhhc0F0dHJpYnV0aW9uID8gJ2ZpZ2NhcHRpb24nIDogJ2Jsb2NrcXVvdGUnLCBjb2xvcjogaGFzQXR0cmlidXRpb25cclxuICAgICAgICAgICAgPyBjb2xvciB8fCBUeXBvZ3JhcGh5Q29sb3Iuc3ViZHVlZFxyXG4gICAgICAgICAgICA6IGNvbG9yIHx8IFR5cG9ncmFwaHlDb2xvci5kZWZhdWx0LCB0aGVtZTogdGhlbWUsIGhhc0F0dHJpYnV0aW9uOiBoYXNBdHRyaWJ1dGlvbiwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHByb3BzLnRlc3RJZCwgdmlzdWFsU3R5bGU6IGhhc0F0dHJpYnV0aW9uXHJcbiAgICAgICAgICAgID8gdmlzdWFsU3R5bGUgfHwgVHlwb2dyYXBoeVZpc3VhbFN0eWxlLmJvZHlNZWRpdW1cclxuICAgICAgICAgICAgOiB2aXN1YWxTdHlsZSB8fCBUeXBvZ3JhcGh5VmlzdWFsU3R5bGUuYm9keUxhcmdlIH0sIHJlc3QpLCBoYXNBdHRyaWJ1dGlvbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgIFwiXFx1MjAxNVxcdTAwQTBcIixcclxuICAgICAgICBjaGlsZHJlbikpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgXCJcXHUyMDFDXCIsXHJcbiAgICAgICAgY2hpbGRyZW4sXHJcbiAgICAgICAgXCJcXHUyMDFEXCIpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QmxvY2tRdW90ZUl0ZW0uanMubWFwIl19 */");
13284
13689
  };
@@ -13291,7 +13696,7 @@ var BlockQuoteItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
13291
13696
  color = props.color,
13292
13697
  hasAttribution = props.hasAttribution,
13293
13698
  visualStyle = props.visualStyle,
13294
- rest = _objectWithoutPropertiesLoose(props, _excluded$1y);
13699
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1A);
13295
13700
  var theme = React.useContext(ThemeContext);
13296
13701
  var isInverse = useIsInverse();
13297
13702
  return React.createElement(StyledBlockQuoteItem, Object.assign({
@@ -14416,7 +14821,7 @@ var TreeItemContext = /*#__PURE__*/React.createContext({
14416
14821
  parentDepth: 0
14417
14822
  });
14418
14823
 
14419
- var _excluded$1z = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "parentCheckedStatus", "style", "testId", "updateParentCheckStatus", "topLevel"];
14824
+ var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "parentCheckedStatus", "style", "testId", "updateParentCheckStatus", "topLevel"];
14420
14825
  var StyledTreeItem = /*#__PURE__*/_styled$1("li", {
14421
14826
  target: "e1xiryew0",
14422
14827
  label: "StyledTreeItem"
@@ -14443,7 +14848,7 @@ var StyledTreeItem = /*#__PURE__*/_styled$1("li", {
14443
14848
  }, " &:hover{background:", function (props) {
14444
14849
  return !props.isDisabled ? props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : polished.transparentize(0.95, props.theme.colors.neutral900) : undefined;
14445
14850
  }, "}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAeiC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/core';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14446
- var IconWrapper$7 = /*#__PURE__*/_styled$1("span", {
14851
+ var IconWrapper$8 = /*#__PURE__*/_styled$1("span", {
14447
14852
  target: "e1xiryew1",
14448
14853
  label: "IconWrapper"
14449
14854
  })("color:", function (props) {
@@ -14496,7 +14901,7 @@ var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
14496
14901
  labelStyle = props.labelStyle,
14497
14902
  style = props.style,
14498
14903
  testId = props.testId,
14499
- rest = _objectWithoutPropertiesLoose(props, _excluded$1z);
14904
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
14500
14905
  var theme = React.useContext(ThemeContext);
14501
14906
  var isInverse = useIsInverse();
14502
14907
  var _React$useContext = React.useContext(TreeViewContext),
@@ -14539,7 +14944,7 @@ var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
14539
14944
  handleClick(e, itemId);
14540
14945
  }
14541
14946
  }
14542
- }, hasIcons && React.createElement(IconWrapper$7, {
14947
+ }, hasIcons && React.createElement(IconWrapper$8, {
14543
14948
  isInverse: isInverse,
14544
14949
  theme: theme,
14545
14950
  isDisabled: isDisabled,
@@ -14647,10 +15052,10 @@ var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
14647
15052
  })));
14648
15053
  });
14649
15054
 
14650
- var _excluded$1A = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId"];
14651
- var _templateObject$E;
14652
- var typedStyled$E = _styled;
14653
- var StyledTreeView = /*#__PURE__*/typedStyled$E.ul(_templateObject$E || (_templateObject$E = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 0;\n margin: 0;\n color: ", ";\n ul {\n padding: 0;\n margin: 0;\n li {\n margin: 0;\n }\n }\n"])), function (props) {
15055
+ var _excluded$1C = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId"];
15056
+ var _templateObject$G;
15057
+ var typedStyled$G = _styled;
15058
+ var StyledTreeView = /*#__PURE__*/typedStyled$G.ul(_templateObject$G || (_templateObject$G = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 0;\n margin: 0;\n color: ", ";\n ul {\n padding: 0;\n margin: 0;\n li {\n margin: 0;\n }\n }\n"])), function (props) {
14654
15059
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral;
14655
15060
  });
14656
15061
  var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
@@ -14660,7 +15065,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
14660
15065
  isInverseProp = props.isInverse,
14661
15066
  selectable = props.selectable,
14662
15067
  testId = props.testId,
14663
- rest = _objectWithoutPropertiesLoose(props, _excluded$1A);
15068
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1C);
14664
15069
  var theme = React.useContext(ThemeContext);
14665
15070
  var isInverse = useIsInverse(isInverseProp);
14666
15071
  var _useTreeView = useTreeView(props),
@@ -14703,7 +15108,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
14703
15108
  }))));
14704
15109
  });
14705
15110
 
14706
- var _excluded$1B = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
15111
+ var _excluded$1D = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
14707
15112
  var ToggleButtonGroupContext = /*#__PURE__*/React.createContext({});
14708
15113
  var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
14709
15114
  var children = props.children,
@@ -14715,7 +15120,7 @@ var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
14715
15120
  size = props.size,
14716
15121
  value = props.value,
14717
15122
  testId = props.testId,
14718
- rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
15123
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
14719
15124
  var theme = React.useContext(ThemeContext);
14720
15125
  var defaultSelectedValues = value ? [value] : [];
14721
15126
  // Array of currently selected items
@@ -15008,6 +15413,8 @@ exports.SkipLink = SkipLink;
15008
15413
  exports.SkipLinkContent = SkipLinkContent;
15009
15414
  exports.Spacer = Spacer;
15010
15415
  exports.Spinner = Spinner;
15416
+ exports.Step = Step;
15417
+ exports.Stepper = Stepper;
15011
15418
  exports.StyledTooltip = StyledTooltip;
15012
15419
  exports.Tab = Tab;
15013
15420
  exports.TabPanel = TabPanel;