react-magma-dom 4.8.0-next.3 → 4.8.0-next.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/esm/index.js CHANGED
@@ -1,7 +1,7 @@
1
- import React__default, { createContext, forwardRef, useContext, createElement, Children, cloneElement, useState, useEffect, Fragment, useRef, useCallback, useLayoutEffect, useMemo, Component, isValidElement } from 'react';
1
+ import React__default, { createContext, forwardRef, useContext, createElement, Children, cloneElement, useState, useRef, useEffect, Fragment, useCallback, useLayoutEffect, useMemo, Component, isValidElement } from 'react';
2
2
  import _styled from '@emotion/styled/base';
3
3
  import { css, ClassNames, jsx, Global } from '@emotion/react';
4
- import { CloseIcon, InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, ChevronRightIcon, ClearIcon, CheckBoxIcon, CheckBoxOutlineBlankIcon, IndeterminateCheckBoxIcon, NorthIcon, SouthIcon, SortDoubleArrowIcon, ArrowDropDownIcon, WestIcon, EastIcon, ArrowBackIcon, ArrowForwardIcon, KeyboardIcon, EventIcon, ArrowDropUpIcon, ArrowRightIcon, ArrowLeftIcon, CheckIcon, ExpandMoreIcon, ExpandLessIcon, ArrowBackIosIcon, ArrowForwardIosIcon, RadioButtonCheckedIcon, RadioButtonUncheckedIcon, SearchIcon, CrossIcon, CancelIcon, ScheduleIcon, FolderIcon, ArticleIcon } from 'react-magma-icons';
4
+ import { CloseIcon, InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, ChevronRightIcon, ClearIcon, CheckBoxIcon, CheckBoxOutlineBlankIcon, IndeterminateCheckBoxIcon, NorthIcon, SouthIcon, SortDoubleArrowIcon, ArrowDropDownIcon, WestIcon, EastIcon, ArrowBackIcon, ArrowForwardIcon, KeyboardIcon, EventIcon, ArrowDropUpIcon, ArrowRightIcon, ArrowLeftIcon, CheckIcon, ExpandMoreIcon, ExpandLessIcon, ArrowBackIosIcon, ArrowForwardIosIcon, RadioButtonCheckedIcon, RadioButtonUncheckedIcon, SearchIcon, CancelIcon, ScheduleIcon, FolderIcon, ArticleIcon } from 'react-magma-icons';
5
5
  import ReactDOM__default, { flushSync as flushSync$1 } from 'react-dom';
6
6
  import isEqual from 'react-fast-compare';
7
7
  import 'warning';
@@ -2999,7 +2999,7 @@ var StyledSpinner = /*#__PURE__*/_styled("span", {
2999
2999
  return props.size;
3000
3000
  }, ";width:", function (props) {
3001
3001
  return props.size;
3002
- }, ";@keyframes spinner-border{to{transform:rotate(360deg);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLa0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBzdHJpbmdJbmNsdWRlc1VuaXQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zcGFuIGBcbiAgYW5pbWF0aW9uOiBzcGlubmVyLWJvcmRlciAwLjc1cyBsaW5lYXIgaW5maW5pdGU7XG4gIGJvcmRlcjogMnB4IHNvbGlkICR7cHJvcHMgPT4gcHJvcHMuY29sb3J9O1xuICBib3JkZXItcmlnaHQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnNpemV9O1xuICB3aWR0aDogJHtwcm9wcyA9PiBwcm9wcy5zaXplfTtcblxuICBAa2V5ZnJhbWVzIHNwaW5uZXItYm9yZGVyIHtcbiAgICB0byB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFNwaW5uZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjb2xvciwgbm9Sb2xlLCBzaXplLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgY29uc3Qgc2l6ZVN0cmluZyA9IHNpemVcclxuICAgICAgICA/IHR5cGVvZiBzaXplID09PSAnbnVtYmVyJyB8fFxyXG4gICAgICAgICAgICAodHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICYmICFzdHJpbmdJbmNsdWRlc1VuaXQoc2l6ZSkpXHJcbiAgICAgICAgICAgID8gYCR7c2l6ZX1weGBcclxuICAgICAgICAgICAgOiBzaXplXHJcbiAgICAgICAgOiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGlubmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsID8gYXJpYUxhYmVsIDogaTE4bi5zcGlubmVyLmFyaWFMYWJlbCwgY29sb3I6IGNvbG9yXHJcbiAgICAgICAgICAgID8gY29sb3JcclxuICAgICAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5XHJcbiAgICAgICAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5LCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgcmVmOiByZWYsIHJvbGU6ICFub1JvbGUgJiYgJ2ltZycsIFwiYXJpYS1oaWRkZW5cIjogbm9Sb2xlLCBzaXplOiBzaXplU3RyaW5nIH0pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
3002
+ }, ";@keyframes spinner-border{to{transform:rotate(360deg);}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLa0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHN0cmluZ0luY2x1ZGVzVW5pdCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zcGFuIGBcbiAgYW5pbWF0aW9uOiBzcGlubmVyLWJvcmRlciAwLjc1cyBsaW5lYXIgaW5maW5pdGU7XG4gIGJvcmRlcjogMnB4IHNvbGlkICR7cHJvcHMgPT4gcHJvcHMuY29sb3J9O1xuICBib3JkZXItcmlnaHQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnNpemV9O1xuICB3aWR0aDogJHtwcm9wcyA9PiBwcm9wcy5zaXplfTtcblxuICBAa2V5ZnJhbWVzIHNwaW5uZXItYm9yZGVyIHtcbiAgICB0byB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFNwaW5uZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjb2xvciwgbm9Sb2xlLCBzaXplLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgY29uc3Qgc2l6ZVN0cmluZyA9IHNpemVcclxuICAgICAgICA/IHR5cGVvZiBzaXplID09PSAnbnVtYmVyJyB8fFxyXG4gICAgICAgICAgICAodHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICYmICFzdHJpbmdJbmNsdWRlc1VuaXQoc2l6ZSkpXHJcbiAgICAgICAgICAgID8gYCR7c2l6ZX1weGBcclxuICAgICAgICAgICAgOiBzaXplXHJcbiAgICAgICAgOiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGlubmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsID8gYXJpYUxhYmVsIDogaTE4bi5zcGlubmVyLmFyaWFMYWJlbCwgY29sb3I6IGNvbG9yXHJcbiAgICAgICAgICAgID8gY29sb3JcclxuICAgICAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5XHJcbiAgICAgICAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5LCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgcmVmOiByZWYsIHJvbGU6IG5vUm9sZSA/IHVuZGVmaW5lZCA6ICdpbWcnLCBcImFyaWEtaGlkZGVuXCI6IG5vUm9sZSwgc2l6ZTogc2l6ZVN0cmluZyB9KSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
3003
3003
  var Spinner = /*#__PURE__*/forwardRef(function (props, ref) {
3004
3004
  var ariaLabel = props['aria-label'],
3005
3005
  color = props.color,
@@ -3015,7 +3015,7 @@ var Spinner = /*#__PURE__*/forwardRef(function (props, ref) {
3015
3015
  color: color ? color : props.isInverse ? theme.colors.tertiary : theme.colors.primary,
3016
3016
  "data-testid": testId,
3017
3017
  ref: ref,
3018
- role: !noRole && 'img',
3018
+ role: noRole ? undefined : 'img',
3019
3019
  "aria-hidden": noRole,
3020
3020
  size: sizeString
3021
3021
  }));
@@ -3437,7 +3437,7 @@ var Circle = /*#__PURE__*/_styled("circle", {
3437
3437
  } : {
3438
3438
  name: "1mlt7hr",
3439
3439
  styles: "transition:stroke-dashoffset 0.35s",
3440
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHNkIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHBlcmNlbnRhZ2UgLSAyKTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgICAgIGlmIChwZXJjZW50YWdlIDw9IDApIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuICgpID0+IGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgfSwgW3BlcmNlbnRhZ2UsIGlzQWN0aXZlXSk7XHJcbiAgICBjb25zdCBub3JtYWxpemVkUmFkaXVzID0gcmFkaXVzIC0gc3Ryb2tlV2lkdGggKiAyO1xyXG4gICAgY29uc3QgY2lyY3VtZmVyZW5jZSA9IG5vcm1hbGl6ZWRSYWRpdXMgKiAyICogTWF0aC5QSTtcclxuICAgIGNvbnN0IHN0cm9rZURhc2hvZmZzZXQgPSBjaXJjdW1mZXJlbmNlIC0gKHBlcmNlbnRhZ2UgLyAxMDApICogY2lyY3VtZmVyZW5jZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN2ZywgeyBoZWlnaHQ6IHJhZGl1cyAqIDIsIHdpZHRoOiByYWRpdXMgKiAyIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2lyY2xlLCB7IGN4OiByYWRpdXMsIGN5OiByYWRpdXMsIGZpbGw6IFwidHJhbnNwYXJlbnRcIiwgcjogbm9ybWFsaXplZFJhZGl1cywgc3Ryb2tlOiBjb2xvciA/IGNvbG9yIDogdGhlbWUuY29sb3JzLm5ldXRyYWwsIHN0cm9rZVdpZHRoOiBzdHJva2VXaWR0aCwgc3Ryb2tlRGFzaGFycmF5OiBgJHtjaXJjdW1mZXJlbmNlfSAke2NpcmN1bWZlcmVuY2V9YCwgc3Ryb2tlRGFzaG9mZnNldDogc3Ryb2tlRGFzaG9mZnNldCB9KSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */",
3440
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHNkIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIGNvbnN0IG1vdW50ZWRSZWYgPSBSZWFjdC51c2VSZWYodHJ1ZSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IHRydWU7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHByZXZQZXJjZW50YWdlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBpZiAoIW1vdW50ZWRSZWYuY3VycmVudCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHByZXZQZXJjZW50YWdlO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBpZiAocHJldlBlcmNlbnRhZ2UgPD0gMikge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIDA7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBwcmV2UGVyY2VudGFnZSAtIDI7XHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAoKSA9PiB7XHJcbiAgICAgICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IGZhbHNlO1xyXG4gICAgICAgICAgICBpZiAoaW50ZXJ2YWwpIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgIH0sIFtpc0FjdGl2ZSwgZHVyYXRpb25dKTtcclxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSYWRpdXMgPSByYWRpdXMgLSBzdHJva2VXaWR0aCAqIDI7XHJcbiAgICBjb25zdCBjaXJjdW1mZXJlbmNlID0gbm9ybWFsaXplZFJhZGl1cyAqIDIgKiBNYXRoLlBJO1xyXG4gICAgY29uc3Qgc3Ryb2tlRGFzaG9mZnNldCA9IGNpcmN1bWZlcmVuY2UgLSAocGVyY2VudGFnZSAvIDEwMCkgKiBjaXJjdW1mZXJlbmNlO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3ZnLCB7IGhlaWdodDogcmFkaXVzICogMiwgd2lkdGg6IHJhZGl1cyAqIDIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjbGUsIHsgY3g6IHJhZGl1cywgY3k6IHJhZGl1cywgZmlsbDogXCJ0cmFuc3BhcmVudFwiLCByOiBub3JtYWxpemVkUmFkaXVzLCBzdHJva2U6IGNvbG9yID8/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLCBzdHJva2VXaWR0aDogc3Ryb2tlV2lkdGgsIHN0cm9rZURhc2hhcnJheTogYCR7Y2lyY3VtZmVyZW5jZX0gJHtjaXJjdW1mZXJlbmNlfWAsIHN0cm9rZURhc2hvZmZzZXQ6IHN0cm9rZURhc2hvZmZzZXQgfSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
3441
3441
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
3442
3442
  });
3443
3443
  var Svg = /*#__PURE__*/_styled("svg", {
@@ -3449,7 +3449,7 @@ var Svg = /*#__PURE__*/_styled("svg", {
3449
3449
  } : {
3450
3450
  name: "126fkb5",
3451
3451
  styles: "transform:rotate(-90deg);transform-origin:50% 50%",
3452
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNdUIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHBlcmNlbnRhZ2UgLSAyKTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgICAgIGlmIChwZXJjZW50YWdlIDw9IDApIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuICgpID0+IGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgfSwgW3BlcmNlbnRhZ2UsIGlzQWN0aXZlXSk7XHJcbiAgICBjb25zdCBub3JtYWxpemVkUmFkaXVzID0gcmFkaXVzIC0gc3Ryb2tlV2lkdGggKiAyO1xyXG4gICAgY29uc3QgY2lyY3VtZmVyZW5jZSA9IG5vcm1hbGl6ZWRSYWRpdXMgKiAyICogTWF0aC5QSTtcclxuICAgIGNvbnN0IHN0cm9rZURhc2hvZmZzZXQgPSBjaXJjdW1mZXJlbmNlIC0gKHBlcmNlbnRhZ2UgLyAxMDApICogY2lyY3VtZmVyZW5jZTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN2ZywgeyBoZWlnaHQ6IHJhZGl1cyAqIDIsIHdpZHRoOiByYWRpdXMgKiAyIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2lyY2xlLCB7IGN4OiByYWRpdXMsIGN5OiByYWRpdXMsIGZpbGw6IFwidHJhbnNwYXJlbnRcIiwgcjogbm9ybWFsaXplZFJhZGl1cywgc3Ryb2tlOiBjb2xvciA/IGNvbG9yIDogdGhlbWUuY29sb3JzLm5ldXRyYWwsIHN0cm9rZVdpZHRoOiBzdHJva2VXaWR0aCwgc3Ryb2tlRGFzaGFycmF5OiBgJHtjaXJjdW1mZXJlbmNlfSAke2NpcmN1bWZlcmVuY2V9YCwgc3Ryb2tlRGFzaG9mZnNldDogc3Ryb2tlRGFzaG9mZnNldCB9KSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */",
3452
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNdUIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIGNvbnN0IG1vdW50ZWRSZWYgPSBSZWFjdC51c2VSZWYodHJ1ZSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IHRydWU7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHByZXZQZXJjZW50YWdlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBpZiAoIW1vdW50ZWRSZWYuY3VycmVudCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHByZXZQZXJjZW50YWdlO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBpZiAocHJldlBlcmNlbnRhZ2UgPD0gMikge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIDA7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBwcmV2UGVyY2VudGFnZSAtIDI7XHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAoKSA9PiB7XHJcbiAgICAgICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IGZhbHNlO1xyXG4gICAgICAgICAgICBpZiAoaW50ZXJ2YWwpIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgIH0sIFtpc0FjdGl2ZSwgZHVyYXRpb25dKTtcclxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSYWRpdXMgPSByYWRpdXMgLSBzdHJva2VXaWR0aCAqIDI7XHJcbiAgICBjb25zdCBjaXJjdW1mZXJlbmNlID0gbm9ybWFsaXplZFJhZGl1cyAqIDIgKiBNYXRoLlBJO1xyXG4gICAgY29uc3Qgc3Ryb2tlRGFzaG9mZnNldCA9IGNpcmN1bWZlcmVuY2UgLSAocGVyY2VudGFnZSAvIDEwMCkgKiBjaXJjdW1mZXJlbmNlO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3ZnLCB7IGhlaWdodDogcmFkaXVzICogMiwgd2lkdGg6IHJhZGl1cyAqIDIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjbGUsIHsgY3g6IHJhZGl1cywgY3k6IHJhZGl1cywgZmlsbDogXCJ0cmFuc3BhcmVudFwiLCByOiBub3JtYWxpemVkUmFkaXVzLCBzdHJva2U6IGNvbG9yID8/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLCBzdHJva2VXaWR0aDogc3Ryb2tlV2lkdGgsIHN0cm9rZURhc2hhcnJheTogYCR7Y2lyY3VtZmVyZW5jZX0gJHtjaXJjdW1mZXJlbmNlfWAsIHN0cm9rZURhc2hvZmZzZXQ6IHN0cm9rZURhc2hvZmZzZXQgfSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
3453
3453
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
3454
3454
  });
3455
3455
  var ProgressRing = /*#__PURE__*/forwardRef(function (props, ref) {
@@ -3466,23 +3466,33 @@ var ProgressRing = /*#__PURE__*/forwardRef(function (props, ref) {
3466
3466
  var _React$useState = useState(100),
3467
3467
  percentage = _React$useState[0],
3468
3468
  setPercentage = _React$useState[1];
3469
+ var mountedRef = useRef(true);
3469
3470
  useEffect(function () {
3471
+ mountedRef.current = true;
3470
3472
  var intervalDuration = duration / 50;
3471
3473
  var interval = null;
3472
3474
  if (isActive) {
3473
3475
  interval = setInterval(function () {
3474
- setPercentage(percentage - 2);
3476
+ setPercentage(function (prevPercentage) {
3477
+ if (!mountedRef.current) {
3478
+ clearInterval(interval);
3479
+ return prevPercentage;
3480
+ }
3481
+ if (prevPercentage <= 2) {
3482
+ clearInterval(interval);
3483
+ return 0;
3484
+ }
3485
+ return prevPercentage - 2;
3486
+ });
3475
3487
  }, intervalDuration);
3476
- if (percentage <= 0) {
3477
- clearInterval(interval);
3478
- }
3479
- } else {
3480
- clearInterval(interval);
3481
3488
  }
3482
3489
  return function () {
3483
- return clearInterval(interval);
3490
+ mountedRef.current = false;
3491
+ if (interval) {
3492
+ clearInterval(interval);
3493
+ }
3484
3494
  };
3485
- }, [percentage, isActive]);
3495
+ }, [isActive, duration]);
3486
3496
  var normalizedRadius = radius - strokeWidth * 2;
3487
3497
  var circumference = normalizedRadius * 2 * Math.PI;
3488
3498
  var strokeDashoffset = circumference - percentage / 100 * circumference;
@@ -3498,7 +3508,7 @@ var ProgressRing = /*#__PURE__*/forwardRef(function (props, ref) {
3498
3508
  cy: radius,
3499
3509
  fill: "transparent",
3500
3510
  r: normalizedRadius,
3501
- stroke: color ? color : theme.colors.neutral,
3511
+ stroke: color != null ? color : theme.colors.neutral,
3502
3512
  strokeWidth: strokeWidth,
3503
3513
  strokeDasharray: circumference + " " + circumference,
3504
3514
  strokeDashoffset: strokeDashoffset
@@ -4914,7 +4924,7 @@ var InputIconPosition;
4914
4924
  InputIconPosition["right"] = "right";
4915
4925
  })(InputIconPosition || (InputIconPosition = {}));
4916
4926
  var inputWrapperStyles = function inputWrapperStyles(props) {
4917
- return /*#__PURE__*/css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? curriedTransparentize(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:-1px;}", props.hasError && /*#__PURE__*/css("border-color:", props.isInverse ? props.theme.colors.danger300 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyDQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgEQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0EQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4927
+ return /*#__PURE__*/css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? curriedTransparentize(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:-1px;}", props.hasError && /*#__PURE__*/css("border-color:", props.isInverse ? props.theme.colors.danger300 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyDQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgEQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0EQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4918
4928
  };
4919
4929
  function getInputPadding(props) {
4920
4930
  var inputSize = props.inputSize,
@@ -4966,7 +4976,7 @@ function getInputPadding(props) {
4966
4976
  return padding;
4967
4977
  }
4968
4978
  var inputBaseStyles = function inputBaseStyles(props) {
4969
- return /*#__PURE__*/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__*/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, ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqJQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(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__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmLQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoI8C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4979
+ return /*#__PURE__*/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__*/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, ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqJQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(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__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmLQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoI8C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4970
4980
  };
4971
4981
  var InputContainer = /*#__PURE__*/_styled("div", {
4972
4982
  target: "e1jxjjn77",
@@ -4977,17 +4987,17 @@ var InputContainer = /*#__PURE__*/_styled("div", {
4977
4987
  } : {
4978
4988
  name: "zjik7",
4979
4989
  styles: "display:flex",
4980
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiMkC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
4990
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiMkC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
4981
4991
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
4982
4992
  });
4983
4993
  var InputWrapper = /*#__PURE__*/_styled("div", {
4984
4994
  target: "e1jxjjn76",
4985
4995
  label: "InputWrapper"
4986
- })(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoMuC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4996
+ })(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoMuC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4987
4997
  var StyledInput = /*#__PURE__*/_styled("input", {
4988
4998
  target: "e1jxjjn75",
4989
4999
  label: "StyledInput"
4990
- })(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuMiC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5000
+ })(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuMiC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
4991
5001
  var IconWrapper$3 = /*#__PURE__*/_styled("span", {
4992
5002
  target: "e1jxjjn74",
4993
5003
  label: "IconWrapper"
@@ -5004,8 +5014,8 @@ var IconWrapper$3 = /*#__PURE__*/_styled("span", {
5004
5014
  return props.theme.spaceScale.spacing03;
5005
5015
  };
5006
5016
  }, ";", function (props) {
5007
- return props.inputSize === 'large' && /*#__PURE__*/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;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5008
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0MgC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5017
+ return props.inputSize === 'large' && /*#__PURE__*/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;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5018
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0MgC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5009
5019
  function getIconButtonSVGSize(props) {
5010
5020
  var isClickable = props.isClickable,
5011
5021
  iconPosition = props.iconPosition,
@@ -5095,7 +5105,7 @@ var IconButtonContainer = /*#__PURE__*/_styled("span", {
5095
5105
  return getIconButtonSVGSize(props);
5096
5106
  }, ";width:", function (props) {
5097
5107
  return getIconButtonSVGSize(props);
5098
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8S+C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5108
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8S+C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5099
5109
  var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
5100
5110
  target: "e1jxjjn72",
5101
5111
  label: "PasswordButtonContainer"
@@ -5103,7 +5113,7 @@ var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
5103
5113
  return props.size === InputSize.large ? -props.buttonWidth - 8 + "px" : -props.buttonWidth - 6 + "px";
5104
5114
  }, ",\n ", function (props) {
5105
5115
  return props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
5106
- }, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T4C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5116
+ }, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T4C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5107
5117
  function getClearablePosition(props) {
5108
5118
  if (props.iconPosition === 'right' && props.icon) {
5109
5119
  if (props.inputSize === 'large') {
@@ -5123,7 +5133,7 @@ var IsClearableContainer = /*#__PURE__*/_styled("span", {
5123
5133
  return getClearablePosition(props);
5124
5134
  }, ",\n ", function (props) {
5125
5135
  return props.inputSize === InputSize.large ? props.theme.spaceScale.spacing03 : '7px';
5126
- }, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoVyC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5136
+ }, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoVyC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5127
5137
  function getIconSize$1(size, theme, iconPosition) {
5128
5138
  switch (size) {
5129
5139
  case 'large':
@@ -5164,7 +5174,7 @@ var HelpLinkContainer = /*#__PURE__*/_styled("span", {
5164
5174
  return getHelpIconButtonSize(props);
5165
5175
  }, ";}inset-inline-end:", function (props) {
5166
5176
  return isLeftOrHidden(props) ? 'auto' : '0';
5167
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgX6C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5177
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgX6C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\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\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\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: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\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 = styled.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 getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\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\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\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.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 isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\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, setReference, isLabelVisuallyHidden, labelPosition, ...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 &&\r\n            onDateChange &&\r\n            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(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, 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.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : 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.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\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\r\n                    ? InputSize.large\r\n                    : 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\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
5168
5178
  var InputBase = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
5169
5179
  var children = props.children,
5170
5180
  containerStyle = props.containerStyle,
@@ -5278,7 +5288,6 @@ var InputBase = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
5278
5288
  theme: theme,
5279
5289
  iconPosition: iconPosition,
5280
5290
  inputSize: inputSize,
5281
- onIconClick: onIconClick,
5282
5291
  icon: icon
5283
5292
  }, createElement(IconButton, {
5284
5293
  "aria-label": i18n.input.isClearableAriaLabel,
@@ -9889,7 +9898,7 @@ var StyledFormFieldContainer$2 = /*#__PURE__*/_styled(FormFieldContainer, {
9889
9898
  minHeight = _getLabelStyles.minHeight,
9890
9899
  justifyContent = _getLabelStyles.justifyContent;
9891
9900
  return "\n margin-block: " + marginBlock + ";\n margin-inline: " + marginInline + ";\n max-width: " + maxWidth + ";\n min-height: " + minHeight + ";\n justify-content: " + justifyContent + ";\n ";
9892
- }, " display:flex;align-items:center;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzREIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgZ2V0SGVscEljb25CdXR0b25TaXplLCBJbnB1dEJhc2UsIElucHV0U2l6ZSwgaXNMZWZ0T3JIaWRkZW4sIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5jb25zdCBnZXRMYWJlbFN0eWxlcyA9IChwcm9wcykgPT4ge1xyXG4gICAgY29uc3QgbWFyZ2luQmxvY2sgPSBpc0xlZnRPckhpZGRlbihwcm9wcylcclxuICAgICAgICA/ICcwJ1xyXG4gICAgICAgIDogYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gO1xyXG4gICAgY29uc3QgbWFyZ2luSW5saW5lID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWBcclxuICAgICAgICA6ICcwJztcclxuICAgIGNvbnN0IG1heFdpZHRoID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyAnYXV0bydcclxuICAgICAgICA6IGBjYWxjKDEwMCUgLSAke2dldEhlbHBJY29uQnV0dG9uU2l6ZShwcm9wcyl9IC0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30pYDtcclxuICAgIGxldCBtaW5IZWlnaHQ7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgbWluSGVpZ2h0ID1cclxuICAgICAgICAgICAgcHJvcHMuSW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgICAgICAgICAgICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTFcclxuICAgICAgICAgICAgICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICBtaW5IZWlnaHQgPSAnYXV0byc7XHJcbiAgICB9XHJcbiAgICBjb25zdCBqdXN0aWZ5Q29udGVudCA9IGlzTGVmdE9ySGlkZGVuKHByb3BzKSA/ICdlbmQnIDogJ3N0YXJ0JztcclxuICAgIHJldHVybiB7IG1hcmdpbkJsb2NrLCBtYXJnaW5JbmxpbmUsIG1heFdpZHRoLCBtaW5IZWlnaHQsIGp1c3RpZnlDb250ZW50IH07XHJcbn07XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG5cbiAgbGFiZWwge1xuICAgICR7cHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBtYXJnaW5CbG9jaywgbWFyZ2luSW5saW5lLCBtYXhXaWR0aCwgbWluSGVpZ2h0LCBqdXN0aWZ5Q29udGVudCB9ID0gZ2V0TGFiZWxTdHlsZXMocHJvcHMpO1xyXG4gICAgcmV0dXJuIGBcbiAgICAgICAgbWFyZ2luLWJsb2NrOiAke21hcmdpbkJsb2NrfTtcbiAgICAgICAgbWFyZ2luLWlubGluZTogJHttYXJnaW5JbmxpbmV9O1xuICAgICAgICBtYXgtd2lkdGg6ICR7bWF4V2lkdGh9O1xuICAgICAgICBtaW4taGVpZ2h0OiAke21pbkhlaWdodH07XG4gICAgICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgICBgO1xyXG59fVxuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZSwgaGFzQ2hhcmFjdGVyQ291bnRlciA9IHRydWUsIGhlbHBlck1lc3NhZ2UsIGljb25Qb3NpdGlvbiwgaWQ6IGRlZmF1bHRJZCwgaW5wdXRTaXplID0gSW5wdXRTaXplLm1lZGl1bSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1heENvdW50LCBtYXhMZW5ndGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCB2YWx1ZSwgc2V0UmVmZXJlbmNlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGRlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSB8fCBtYXhDb3VudCB8fCBtYXhMZW5ndGhcclxuICAgICAgICA/IGAke2lkfV9fZGVzY2BcclxuICAgICAgICA6IG51bGw7XHJcbiAgICBjb25zdCBtYXhDaGFyYWN0ZXJzID0gdHlwZW9mIG1heENvdW50ID09PSAnbnVtYmVyJyA/IG1heENvdW50IDogbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgbWF4TGVuZ3RoTnVtID0gIWhhc0NoYXJhY3RlckNvdW50ZXIgJiYgbWF4TGVuZ3RoID8gbWF4TGVuZ3RoIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCBbY2hhcmFjdGVyTGVuZ3RoLCBzZXRDaGFyYWN0ZXJMZW5ndGhdID0gdXNlU3RhdGUodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIH0sIFt2YWx1ZV0pO1xyXG4gICAgZnVuY3Rpb24gaGFuZGxlQ2hhbmdlKGV2ZW50KSB7XHJcbiAgICAgICAgcHJvcHMub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIHByb3BzLm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIHByb3BzLm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoZXZlbnQudGFyZ2V0LnZhbHVlLmxlbmd0aCk7XHJcbiAgICB9XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVDbGVhcigpIHtcclxuICAgICAgICBwcm9wcy5vbkNsZWFyICYmIHR5cGVvZiBwcm9wcy5vbkNsZWFyID09PSAnZnVuY3Rpb24nICYmIHByb3BzLm9uQ2xlYXIoKTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoMCk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyLCB7IGNvbnRhaW5lclN0eWxlOiBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlOiBlcnJvck1lc3NhZ2UsIGZpZWxkSWQ6IGlkLCBoYXNDaGFyYWN0ZXJDb3VudGVyOiBoYXNDaGFyYWN0ZXJDb3VudGVyLCBoZWxwZXJNZXNzYWdlOiBoZWxwZXJNZXNzYWdlLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuOiBpc0xhYmVsVmlzdWFsbHlIaWRkZW4sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpbnB1dFNpemU6IGlucHV0U2l6ZSwgaW5wdXRMZW5ndGg6IGNoYXJhY3Rlckxlbmd0aCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFRleHQsIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIG1heExlbmd0aDogbWF4TGVuZ3RoLCBtYXhDb3VudDogbWF4Q291bnQsIG1lc3NhZ2VTdHlsZTogbWVzc2FnZVN0eWxlLCB0ZXN0SWQ6IHRlc3RJZCAmJiBgJHt0ZXN0SWR9LWZvcm1GaWVsZENvbnRhaW5lcmAsIHRoZW1lOiB0aGVtZSwgSW5wdXRTaXplOiBpbnB1dFNpemUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0QmFzZSwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGRlc2NyaXB0aW9uSWQgPz8gcHJvcHNbJ2FyaWEtZGVzY3JpYmVkYnknXSwgXCJhcmlhLWludmFsaWRcIjogISFlcnJvck1lc3NhZ2UsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSB8fFxyXG4gICAgICAgICAgICAgICAgKGhhc0NoYXJhY3RlckNvdW50ZXIgJiYgY2hhcmFjdGVyTGVuZ3RoID4gbWF4Q2hhcmFjdGVycyksIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBpZDogaWQsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBpbnB1dExlbmd0aDogY2hhcmFjdGVyTGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4TGVuZ3RoOiBtYXhMZW5ndGhOdW0sIG9uQ2hhbmdlOiBoYW5kbGVDaGFuZ2UsIG9uQ2xlYXI6IGhhbmRsZUNsZWFyLCBvbkRhdGVDaGFuZ2U6IHByb3BzLm9uRGF0ZUNoYW5nZSwgcmVmOiByZWYsIHNldFJlZmVyZW5jZTogc2V0UmVmZXJlbmNlLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9KSwgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
9901
+ }, " display:flex;align-items:center;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzREIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBvbWl0LCB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgZ2V0SGVscEljb25CdXR0b25TaXplLCBJbnB1dEJhc2UsIElucHV0U2l6ZSwgaXNMZWZ0T3JIaWRkZW4sIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5jb25zdCBnZXRMYWJlbFN0eWxlcyA9IChwcm9wcykgPT4ge1xyXG4gICAgY29uc3QgbWFyZ2luQmxvY2sgPSBpc0xlZnRPckhpZGRlbihwcm9wcylcclxuICAgICAgICA/ICcwJ1xyXG4gICAgICAgIDogYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gO1xyXG4gICAgY29uc3QgbWFyZ2luSW5saW5lID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWBcclxuICAgICAgICA6ICcwJztcclxuICAgIGNvbnN0IG1heFdpZHRoID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyAnYXV0bydcclxuICAgICAgICA6IGBjYWxjKDEwMCUgLSAke2dldEhlbHBJY29uQnV0dG9uU2l6ZShwcm9wcyl9IC0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30pYDtcclxuICAgIGxldCBtaW5IZWlnaHQ7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgbWluSGVpZ2h0ID1cclxuICAgICAgICAgICAgcHJvcHMuSW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgICAgICAgICAgICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTFcclxuICAgICAgICAgICAgICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICBtaW5IZWlnaHQgPSAnYXV0byc7XHJcbiAgICB9XHJcbiAgICBjb25zdCBqdXN0aWZ5Q29udGVudCA9IGlzTGVmdE9ySGlkZGVuKHByb3BzKSA/ICdlbmQnIDogJ3N0YXJ0JztcclxuICAgIHJldHVybiB7IG1hcmdpbkJsb2NrLCBtYXJnaW5JbmxpbmUsIG1heFdpZHRoLCBtaW5IZWlnaHQsIGp1c3RpZnlDb250ZW50IH07XHJcbn07XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG5cbiAgbGFiZWwge1xuICAgICR7cHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBtYXJnaW5CbG9jaywgbWFyZ2luSW5saW5lLCBtYXhXaWR0aCwgbWluSGVpZ2h0LCBqdXN0aWZ5Q29udGVudCB9ID0gZ2V0TGFiZWxTdHlsZXMocHJvcHMpO1xyXG4gICAgcmV0dXJuIGBcbiAgICAgICAgbWFyZ2luLWJsb2NrOiAke21hcmdpbkJsb2NrfTtcbiAgICAgICAgbWFyZ2luLWlubGluZTogJHttYXJnaW5JbmxpbmV9O1xuICAgICAgICBtYXgtd2lkdGg6ICR7bWF4V2lkdGh9O1xuICAgICAgICBtaW4taGVpZ2h0OiAke21pbkhlaWdodH07XG4gICAgICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgICBgO1xyXG59fVxuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZSwgaGFzQ2hhcmFjdGVyQ291bnRlciA9IHRydWUsIGhlbHBlck1lc3NhZ2UsIGljb25Qb3NpdGlvbiwgaWQ6IGRlZmF1bHRJZCwgaW5wdXRTaXplID0gSW5wdXRTaXplLm1lZGl1bSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1heENvdW50LCBtYXhMZW5ndGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCB2YWx1ZSwgc2V0UmVmZXJlbmNlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGRlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSB8fCBtYXhDb3VudCB8fCBtYXhMZW5ndGhcclxuICAgICAgICA/IGAke2lkfV9fZGVzY2BcclxuICAgICAgICA6IG51bGw7XHJcbiAgICBjb25zdCBtYXhDaGFyYWN0ZXJzID0gdHlwZW9mIG1heENvdW50ID09PSAnbnVtYmVyJyA/IG1heENvdW50IDogbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgbWF4TGVuZ3RoTnVtID0gIWhhc0NoYXJhY3RlckNvdW50ZXIgJiYgbWF4TGVuZ3RoID8gbWF4TGVuZ3RoIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCBbY2hhcmFjdGVyTGVuZ3RoLCBzZXRDaGFyYWN0ZXJMZW5ndGhdID0gdXNlU3RhdGUodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIH0sIFt2YWx1ZV0pO1xyXG4gICAgZnVuY3Rpb24gaGFuZGxlQ2hhbmdlKGV2ZW50KSB7XHJcbiAgICAgICAgcHJvcHMub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIHByb3BzLm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIHByb3BzLm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoZXZlbnQudGFyZ2V0LnZhbHVlLmxlbmd0aCk7XHJcbiAgICB9XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVDbGVhcigpIHtcclxuICAgICAgICBwcm9wcy5vbkNsZWFyICYmIHR5cGVvZiBwcm9wcy5vbkNsZWFyID09PSAnZnVuY3Rpb24nICYmIHByb3BzLm9uQ2xlYXIoKTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoMCk7XHJcbiAgICB9XHJcbiAgICBjb25zdCB2YWxpZElucHV0QmFzZVByb3BzID0gb21pdChbXHJcbiAgICAgICAgJ29uRGF0ZUNoYW5nZScsXHJcbiAgICAgICAgJ29uSW5wdXRDaGFuZ2UnLFxyXG4gICAgICAgICdvbklucHV0Qmx1cicsXHJcbiAgICAgICAgJ29uSW5wdXRGb2N1cycsXHJcbiAgICAgICAgJ29uQ2xlYXInLFxyXG4gICAgXSwgb3RoZXIpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgeyBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZTogZXJyb3JNZXNzYWdlLCBmaWVsZElkOiBpZCwgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaW5wdXRTaXplOiBpbnB1dFNpemUsIGlucHV0TGVuZ3RoOiBjaGFyYWN0ZXJMZW5ndGgsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGU6IGxhYmVsU3R5bGUsIGxhYmVsVGV4dDogbGFiZWxUZXh0LCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBtYXhMZW5ndGg6IG1heExlbmd0aCwgbWF4Q291bnQ6IG1heENvdW50LCBtZXNzYWdlU3R5bGU6IG1lc3NhZ2VTdHlsZSwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1mb3JtRmllbGRDb250YWluZXJgLCB0aGVtZTogdGhlbWUsIElucHV0U2l6ZTogaW5wdXRTaXplIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dEJhc2UsIE9iamVjdC5hc3NpZ24oe30sIHZhbGlkSW5wdXRCYXNlUHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGRlc2NyaXB0aW9uSWQgPyBkZXNjcmlwdGlvbklkIDogcHJvcHNbJ2FyaWEtZGVzY3JpYmVkYnknXSwgXCJhcmlhLWludmFsaWRcIjogISFlcnJvck1lc3NhZ2UsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSB8fFxyXG4gICAgICAgICAgICAgICAgKGhhc0NoYXJhY3RlckNvdW50ZXIgJiYgY2hhcmFjdGVyTGVuZ3RoID4gbWF4Q2hhcmFjdGVycyksIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBpZDogaWQsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBpbnB1dExlbmd0aDogY2hhcmFjdGVyTGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4TGVuZ3RoOiBtYXhMZW5ndGhOdW0sIG9uQ2hhbmdlOiBoYW5kbGVDaGFuZ2UsIG9uQ2xlYXI6IGhhbmRsZUNsZWFyLCBvbkRhdGVDaGFuZ2U6IHByb3BzLm9uRGF0ZUNoYW5nZSwgcmVmOiByZWYsIHNldFJlZmVyZW5jZTogc2V0UmVmZXJlbmNlLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9KSwgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
9893
9902
  var Input = /*#__PURE__*/forwardRef(function (props, ref) {
9894
9903
  var children = props.children,
9895
9904
  containerStyle = props.containerStyle,
@@ -9933,6 +9942,7 @@ var Input = /*#__PURE__*/forwardRef(function (props, ref) {
9933
9942
  props.onClear && typeof props.onClear === 'function' && props.onClear();
9934
9943
  setCharacterLength(0);
9935
9944
  }
9945
+ var validInputBaseProps = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus', 'onClear'], other);
9936
9946
  return createElement(StyledFormFieldContainer$2, {
9937
9947
  containerStyle: containerStyle,
9938
9948
  errorMessage: errorMessage,
@@ -9954,8 +9964,8 @@ var Input = /*#__PURE__*/forwardRef(function (props, ref) {
9954
9964
  testId: testId && testId + "-formFieldContainer",
9955
9965
  theme: theme,
9956
9966
  InputSize: inputSize
9957
- }, createElement(InputBase, Object.assign({}, other, {
9958
- "aria-describedby": descriptionId != null ? descriptionId : props['aria-describedby'],
9967
+ }, createElement(InputBase, Object.assign({}, validInputBaseProps, {
9968
+ "aria-describedby": descriptionId ? descriptionId : props['aria-describedby'],
9959
9969
  "aria-invalid": !!errorMessage,
9960
9970
  hasError: !!errorMessage || hasCharacterCounter && characterLength > maxCharacters,
9961
9971
  iconPosition: iconPosition,
@@ -23103,7 +23113,7 @@ function instanceOfNavChildrenTab(object) {
23103
23113
  var StyledTab$1 = /*#__PURE__*/_styled("a", {
23104
23114
  target: "e1p8nst20",
23105
23115
  label: "StyledTab"
23106
- })(TabStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdlRhYi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6Ik5hdlRhYi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBOYXZUYWJzQ29udGV4dCB9IGZyb20gJy4vTmF2VGFicyc7XHJcbmltcG9ydCB7IFN0eWxlZFRhYnNDaGlsZCwgU3R5bGVkSWNvbiwgVGFiU3R5bGVzLCBUYWJzSWNvblBvc2l0aW9uLCB9IGZyb20gJy4uL1RhYnMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBvbWl0LCByZXNvbHZlUHJvcHMsIHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNvbXBvbmVudFRhYihvYmplY3QpIHtcclxuICAgIHJldHVybiAnY29tcG9uZW50JyBpbiBvYmplY3QgJiYgISgnY2hpbGRyZW4nIGluIG9iamVjdCk7XHJcbn1cclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKG9iamVjdCkge1xyXG4gICAgcmV0dXJuICEoJ2NvbXBvbmVudCcgaW4gb2JqZWN0KSAmJiAnY2hpbGRyZW4nIGluIG9iamVjdDtcclxufVxyXG5jb25zdCBTdHlsZWRUYWIgPSBzdHlsZWQuYSBgXG4gICR7VGFiU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IFN0eWxlZEN1c3RvbVRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGNvbXBvbmVudCwgaWNvbiwgc3R5bGUsIG9uQ2xpY2ssIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgaWYgKFJlYWN0LmlzVmFsaWRFbGVtZW50KGNvbXBvbmVudCkgJiYgUmVhY3QuaXNWYWxpZEVsZW1lbnQoY29tcG9uZW50KSkge1xyXG4gICAgICAgIGNvbnN0IGNsb25lRWxlbWVudCA9IChlbGVtZW50LCBuZXdQcm9wcykgPT4ge1xyXG4gICAgICAgICAgICByZXR1cm4ganN4KGVsZW1lbnQudHlwZSwge1xyXG4gICAgICAgICAgICAgICAga2V5OiBlbGVtZW50LmtleSxcclxuICAgICAgICAgICAgICAgIHJlZjogZWxlbWVudC5yZWYsXHJcbiAgICAgICAgICAgICAgICAuLi5lbGVtZW50LnByb3BzLFxyXG4gICAgICAgICAgICAgICAgLi4ubmV3UHJvcHMsXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH07XHJcbiAgICAgICAgY29uc3Qgb3RoZXIgPSBvbWl0KFsnaWNvblBvc2l0aW9uJywgJ2lzSW52ZXJzZScsICdpc0FjdGl2ZScsICdpc0Z1bGxXaWR0aCddLCByZXN0KTtcclxuICAgICAgICByZXR1cm4gY2xvbmVFbGVtZW50KGNvbXBvbmVudCwge1xyXG4gICAgICAgICAgICAuLi5vdGhlcixcclxuICAgICAgICAgICAgY3NzOiBUYWJTdHlsZXMocHJvcHMpLFxyXG4gICAgICAgICAgICAuLi5zdHlsZSxcclxuICAgICAgICAgICAgb25DbGljayxcclxuICAgICAgICAgICAgcmVmLFxyXG4gICAgICAgICAgICBjaGlsZHJlbjogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgICAgICBpY29uLFxyXG4gICAgICAgICAgICAgICAgY29tcG9uZW50LnByb3BzLmNoaWxkcmVuKSksXHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcbn0pO1xyXG4vLyBVc2luZyBhbnkgdHlwZSBiZWNhdXNlIHdlIGRvIG5vdCBrbm93IHRoZSBlbGVtZW50IHR5cGUgb2YgYSBjdXN0b20gdGFiXHJcbmV4cG9ydCBjb25zdCBOYXZUYWIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgZm9yd2FyZFJlZikgPT4ge1xyXG4gICAgbGV0IGNoaWxkcmVuO1xyXG4gICAgbGV0IGNvbXBvbmVudDtcclxuICAgIGNvbnN0IGNvbnRleHRQcm9wcyA9IFJlYWN0LnVzZUNvbnRleHQoTmF2VGFic0NvbnRleHQpO1xyXG4gICAgY29uc3QgcmVzb2x2ZWRQcm9wcyA9IHJlc29sdmVQcm9wcyhjb250ZXh0UHJvcHMsIHByb3BzKTtcclxuICAgIGNvbnN0IHsgaXNBY3RpdmUsIGljb24sIGlzRm9jdXNlZCwgdGVzdElkLCB0bywgLi4ub3RoZXIgfSA9IHJlc29sdmVkUHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGlmIChpbnN0YW5jZU9mTmF2Q29tcG9uZW50VGFiKHByb3BzKSkge1xyXG4gICAgICAgIGNvbXBvbmVudCA9IHByb3BzLmNvbXBvbmVudDtcclxuICAgIH1cclxuICAgIGVsc2UgaWYgKGluc3RhbmNlT2ZOYXZDaGlsZHJlblRhYihwcm9wcykpIHtcclxuICAgICAgICBjaGlsZHJlbiA9IHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgY29uc3QgaXNJY29uT25seSA9ICFjaGlsZHJlbjtcclxuICAgIGNvbnN0IHsgb3JpZW50YXRpb24sIGJvcmRlclBvc2l0aW9uLCBpY29uUG9zaXRpb24sIGlzSW52ZXJzZSwgaXNGdWxsV2lkdGgsIHRleHRUcmFuc2Zvcm0sIH0gPSByZXNvbHZlZFByb3BzO1xyXG4gICAgY29uc3QgdGFiSWNvblBvc2l0aW9uID0gaWNvblBvc2l0aW9uXHJcbiAgICAgICAgPyBpY29uUG9zaXRpb25cclxuICAgICAgICA6IG9yaWVudGF0aW9uID09PSAndmVydGljYWwnXHJcbiAgICAgICAgICAgID8gVGFic0ljb25Qb3NpdGlvbi5sZWZ0XHJcbiAgICAgICAgICAgIDogVGFic0ljb25Qb3NpdGlvbi50b3A7XHJcbiAgICBjb25zdCBzdHlsZWRUYWJSZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IHJlZiA9IHVzZUZvcmtlZFJlZihmb3J3YXJkUmVmLCBzdHlsZWRUYWJSZWYpO1xyXG4gICAgLy8gU2V0cyBmb2N1cyBvbiBOYXZUYWIgZm9yIGFjY2Vzc2liaWxpdHlcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKGlzRm9jdXNlZCkge1xyXG4gICAgICAgICAgICBzdHlsZWRUYWJSZWYuY3VycmVudD8uZm9jdXMoKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVGFic0NoaWxkLCB7IGJvcmRlclBvc2l0aW9uOiBib3JkZXJQb3NpdGlvbiwgXCJkYXRhLXRlc3RpZFwiOiBcInRhYkNvbnRhaW5lclwiLCBpc0FjdGl2ZTogaXNBY3RpdmUsIGlzRnVsbFdpZHRoOiBpc0Z1bGxXaWR0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG9yaWVudGF0aW9uOiBvcmllbnRhdGlvbiwgdGhlbWU6IHRoZW1lIH0sIGNvbXBvbmVudCA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEN1c3RvbVRhYiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJhcmlhLWN1cnJlbnRcIjogaXNBY3RpdmUgPyAncGFnZScgOiBmYWxzZSwgY29tcG9uZW50OiBjb21wb25lbnQsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiwgaWNvbjogaWNvbiAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJY29uLCB7IHRoZW1lOiB0aGVtZSwgaWNvblBvc2l0aW9uOiB0YWJJY29uUG9zaXRpb24gfSwgaWNvbikpLCBpc0FjdGl2ZTogaXNBY3RpdmUsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpc0Z1bGxXaWR0aDogaXNGdWxsV2lkdGgsIG9yaWVudGF0aW9uOiBvcmllbnRhdGlvbiwgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSB9KSkpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVGFiLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtY3VycmVudFwiOiBpc0FjdGl2ZSA/ICdwYWdlJyA6IGZhbHNlLCByZWY6IHJlZiwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhyZWY6IHRvLCBpc0FjdGl2ZTogaXNBY3RpdmUsIGlzRnVsbFdpZHRoOiBpc0Z1bGxXaWR0aCwgaWNvblBvc2l0aW9uOiB0YWJJY29uUG9zaXRpb24sIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBvcmllbnRhdGlvbjogb3JpZW50YXRpb24sIHRleHRUcmFuc2Zvcm06IHRleHRUcmFuc2Zvcm0sIHRoZW1lOiB0aGVtZSB9KSxcclxuICAgICAgICBpY29uICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEljb24sIHsgdGhlbWU6IHRoZW1lLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiwgaXNJY29uT25seTogaXNJY29uT25seSB9LCBpY29uKSksXHJcbiAgICAgICAgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9TmF2VGFiLmpzLm1hcCJdfQ== */"));
23116
+ })(TabStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdlRhYi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6Ik5hdlRhYi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBOYXZUYWJzQ29udGV4dCB9IGZyb20gJy4vTmF2VGFicyc7XHJcbmltcG9ydCB7IFN0eWxlZFRhYnNDaGlsZCwgU3R5bGVkSWNvbiwgVGFiU3R5bGVzLCBUYWJzSWNvblBvc2l0aW9uLCB9IGZyb20gJy4uL1RhYnMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBvbWl0LCByZXNvbHZlUHJvcHMsIHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNvbXBvbmVudFRhYihvYmplY3QpIHtcclxuICAgIHJldHVybiAnY29tcG9uZW50JyBpbiBvYmplY3QgJiYgISgnY2hpbGRyZW4nIGluIG9iamVjdCk7XHJcbn1cclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKG9iamVjdCkge1xyXG4gICAgcmV0dXJuICEoJ2NvbXBvbmVudCcgaW4gb2JqZWN0KSAmJiAnY2hpbGRyZW4nIGluIG9iamVjdDtcclxufVxyXG5jb25zdCBTdHlsZWRUYWIgPSBzdHlsZWQuYSBgXG4gICR7VGFiU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IFN0eWxlZEN1c3RvbVRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGNvbXBvbmVudCwgaWNvbiwgc3R5bGUsIG9uQ2xpY2ssIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgaWYgKFJlYWN0LmlzVmFsaWRFbGVtZW50KGNvbXBvbmVudCkgJiYgUmVhY3QuaXNWYWxpZEVsZW1lbnQoY29tcG9uZW50KSkge1xyXG4gICAgICAgIGNvbnN0IGNsb25lRWxlbWVudCA9IChlbGVtZW50LCBuZXdQcm9wcykgPT4ge1xyXG4gICAgICAgICAgICByZXR1cm4ganN4KGVsZW1lbnQudHlwZSwge1xyXG4gICAgICAgICAgICAgICAga2V5OiBlbGVtZW50LmtleSxcclxuICAgICAgICAgICAgICAgIHJlZjogZWxlbWVudC5yZWYsXHJcbiAgICAgICAgICAgICAgICAuLi5lbGVtZW50LnByb3BzLFxyXG4gICAgICAgICAgICAgICAgLi4ubmV3UHJvcHMsXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH07XHJcbiAgICAgICAgY29uc3Qgb3RoZXIgPSBvbWl0KFsnaWNvblBvc2l0aW9uJywgJ2lzSW52ZXJzZScsICdpc0FjdGl2ZScsICdpc0Z1bGxXaWR0aCcsICdib3JkZXJQb3NpdGlvbicsICdvcmllbnRhdGlvbicsICd0ZXh0VHJhbnNmb3JtJ10sIHJlc3QpO1xyXG4gICAgICAgIHJldHVybiBjbG9uZUVsZW1lbnQoY29tcG9uZW50LCB7XHJcbiAgICAgICAgICAgIC4uLm90aGVyLFxyXG4gICAgICAgICAgICBjc3M6IFRhYlN0eWxlcyhwcm9wcyksXHJcbiAgICAgICAgICAgIC4uLnN0eWxlLFxyXG4gICAgICAgICAgICBvbkNsaWNrLFxyXG4gICAgICAgICAgICByZWYsXHJcbiAgICAgICAgICAgIGNoaWxkcmVuOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgICAgIGljb24sXHJcbiAgICAgICAgICAgICAgICBjb21wb25lbnQucHJvcHMuY2hpbGRyZW4pKSxcclxuICAgICAgICB9KTtcclxuICAgIH1cclxufSk7XHJcbi8vIFVzaW5nIGFueSB0eXBlIGJlY2F1c2Ugd2UgZG8gbm90IGtub3cgdGhlIGVsZW1lbnQgdHlwZSBvZiBhIGN1c3RvbSB0YWJcclxuZXhwb3J0IGNvbnN0IE5hdlRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCBmb3J3YXJkUmVmKSA9PiB7XHJcbiAgICBsZXQgY2hpbGRyZW47XHJcbiAgICBsZXQgY29tcG9uZW50O1xyXG4gICAgY29uc3QgY29udGV4dFByb3BzID0gUmVhY3QudXNlQ29udGV4dChOYXZUYWJzQ29udGV4dCk7XHJcbiAgICBjb25zdCByZXNvbHZlZFByb3BzID0gcmVzb2x2ZVByb3BzKGNvbnRleHRQcm9wcywgcHJvcHMpO1xyXG4gICAgY29uc3QgeyBpc0FjdGl2ZSwgaWNvbiwgaXNGb2N1c2VkLCB0ZXN0SWQsIHRvLCAuLi5vdGhlciB9ID0gcmVzb2x2ZWRQcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgaWYgKGluc3RhbmNlT2ZOYXZDb21wb25lbnRUYWIocHJvcHMpKSB7XHJcbiAgICAgICAgY29tcG9uZW50ID0gcHJvcHMuY29tcG9uZW50O1xyXG4gICAgfVxyXG4gICAgZWxzZSBpZiAoaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKHByb3BzKSkge1xyXG4gICAgICAgIGNoaWxkcmVuID0gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICBjb25zdCBpc0ljb25Pbmx5ID0gIWNoaWxkcmVuO1xyXG4gICAgY29uc3QgeyBvcmllbnRhdGlvbiwgYm9yZGVyUG9zaXRpb24sIGljb25Qb3NpdGlvbiwgaXNJbnZlcnNlLCBpc0Z1bGxXaWR0aCwgdGV4dFRyYW5zZm9ybSwgfSA9IHJlc29sdmVkUHJvcHM7XHJcbiAgICBjb25zdCB0YWJJY29uUG9zaXRpb24gPSBpY29uUG9zaXRpb25cclxuICAgICAgICA/IGljb25Qb3NpdGlvblxyXG4gICAgICAgIDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcclxuICAgICAgICAgICAgPyBUYWJzSWNvblBvc2l0aW9uLmxlZnRcclxuICAgICAgICAgICAgOiBUYWJzSWNvblBvc2l0aW9uLnRvcDtcclxuICAgIGNvbnN0IHN0eWxlZFRhYlJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRSZWYsIHN0eWxlZFRhYlJlZik7XHJcbiAgICAvLyBTZXRzIGZvY3VzIG9uIE5hdlRhYiBmb3IgYWNjZXNzaWJpbGl0eVxyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoaXNGb2N1c2VkKSB7XHJcbiAgICAgICAgICAgIHN0eWxlZFRhYlJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJzQ2hpbGQsIHsgYm9yZGVyUG9zaXRpb246IGJvcmRlclBvc2l0aW9uLCBcImRhdGEtdGVzdGlkXCI6IFwidGFiQ29udGFpbmVyXCIsIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNGdWxsV2lkdGg6IGlzRnVsbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgb3JpZW50YXRpb246IG9yaWVudGF0aW9uLCB0aGVtZTogdGhlbWUgfSwgY29tcG9uZW50ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ3VzdG9tVGFiLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtY3VycmVudFwiOiBpc0FjdGl2ZSA/ICdwYWdlJyA6IGZhbHNlLCBjb21wb25lbnQ6IGNvbXBvbmVudCwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGljb25Qb3NpdGlvbjogdGFiSWNvblBvc2l0aW9uLCBpY29uOiBpY29uICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEljb24sIHsgdGhlbWU6IHRoZW1lLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiB9LCBpY29uKSksIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlzRnVsbFdpZHRoOiBpc0Z1bGxXaWR0aCwgb3JpZW50YXRpb246IG9yaWVudGF0aW9uLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWIsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1jdXJyZW50XCI6IGlzQWN0aXZlID8gJ3BhZ2UnIDogZmFsc2UsIHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaHJlZjogdG8sIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNGdWxsV2lkdGg6IGlzRnVsbFdpZHRoLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG9yaWVudGF0aW9uOiBvcmllbnRhdGlvbiwgdGV4dFRyYW5zZm9ybTogdGV4dFRyYW5zZm9ybSwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgIGljb24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSWNvbiwgeyB0aGVtZTogdGhlbWUsIGljb25Qb3NpdGlvbjogdGFiSWNvblBvc2l0aW9uLCBpc0ljb25Pbmx5OiBpc0ljb25Pbmx5IH0sIGljb24pKSxcclxuICAgICAgICBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1OYXZUYWIuanMubWFwIl19 */"));
23107
23117
  var StyledCustomTab = /*#__PURE__*/forwardRef(function (props, ref) {
23108
23118
  var component = props.component,
23109
23119
  icon = props.icon,
@@ -23117,7 +23127,7 @@ var StyledCustomTab = /*#__PURE__*/forwardRef(function (props, ref) {
23117
23127
  ref: element.ref
23118
23128
  }, element.props, newProps));
23119
23129
  };
23120
- var other = omit(['iconPosition', 'isInverse', 'isActive', 'isFullWidth'], rest);
23130
+ var other = omit(['iconPosition', 'isInverse', 'isActive', 'isFullWidth', 'borderPosition', 'orientation', 'textTransform'], rest);
23121
23131
  return cloneElement(component, _extends({}, other, {
23122
23132
  css: TabStyles(props)
23123
23133
  }, style, {
@@ -26312,7 +26322,7 @@ function buildStepSvgColors(props) {
26312
26322
  var HiddenLabelText$2 = /*#__PURE__*/_styled("span", {
26313
26323
  target: "e1vnah7r5",
26314
26324
  label: "HiddenLabelText"
26315
- })(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAqF2C","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26325
+ })(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAqF2C","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26316
26326
  var StyledStep = /*#__PURE__*/_styled("div", {
26317
26327
  target: "e1vnah7r4",
26318
26328
  label: "StyledStep"
@@ -26324,7 +26334,7 @@ var StyledStep = /*#__PURE__*/_styled("div", {
26324
26334
  return !props.isVerticalOrientation && 'center';
26325
26335
  }, ";&:last-child>span{margin-bottom:", function (props) {
26326
26336
  return props.isVerticalOrientation && 0;
26327
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAwF8B","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26337
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAwF8B","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26328
26338
  var StyledStepIndicator = /*#__PURE__*/_styled("span", {
26329
26339
  target: "e1vnah7r3",
26330
26340
  label: "StyledStepIndicator"
@@ -26334,13 +26344,13 @@ var StyledStepIndicator = /*#__PURE__*/_styled("span", {
26334
26344
  return props.theme.iconSizes.xSmall;
26335
26345
  }, "px;height:", function (props) {
26336
26346
  return props.theme.iconSizes.xSmall;
26337
- }, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAoGwC","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26347
+ }, "px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAoGwC","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26338
26348
  var StyledStepTextWrapper = /*#__PURE__*/_styled("span", {
26339
26349
  target: "e1vnah7r2",
26340
26350
  label: "StyledStepTextWrapper"
26341
26351
  })("flex:1;display:flex;align-self:center;flex-direction:column;position:relative;margin:", function (props) {
26342
26352
  return props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0';
26343
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAuH0C","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26353
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAuH0C","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26344
26354
  var StyledLabel$2 = /*#__PURE__*/_styled("span", {
26345
26355
  target: "e1vnah7r1",
26346
26356
  label: "StyledLabel"
@@ -26350,7 +26360,7 @@ var StyledLabel$2 = /*#__PURE__*/_styled("span", {
26350
26360
  return props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing;
26351
26361
  }, ";line-height:", function (props) {
26352
26362
  return props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight;
26353
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AA+HgC","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26363
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AA+HgC","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26354
26364
  var StyledSecondaryLabel = /*#__PURE__*/_styled("span", {
26355
26365
  target: "e1vnah7r0",
26356
26366
  label: "StyledSecondaryLabel"
@@ -26362,7 +26372,7 @@ var StyledSecondaryLabel = /*#__PURE__*/_styled("span", {
26362
26372
  return props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight;
26363
26373
  }, ";margin:", function (props) {
26364
26374
  return props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px';
26365
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAsIyC","file":"Step.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CheckIcon, CrossIcon } from 'react-magma-icons';\r\nimport styled from '@emotion/styled';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CrossIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26375
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Step.tsx"],"names":[],"mappings":"AAsIyC","file":"Step.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { CheckIcon, CloseIcon } from 'react-magma-icons';\r\nimport { transparentize } from 'polished';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HiddenStyles } from '../../utils/UtilityStyles';\r\nimport { StepperLayout, StepperOrientation } from './Stepper';\r\nexport var StepStatus;\r\n(function (StepStatus) {\r\n    StepStatus[\"active\"] = \"active\";\r\n    StepStatus[\"completed\"] = \"completed\";\r\n    StepStatus[\"incomplete\"] = \"incomplete\";\r\n})(StepStatus || (StepStatus = {}));\r\nfunction buildStepCircleOutlineColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse && !hasError) {\r\n        if (stepStatus === StepStatus.active) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (stepStatus === StepStatus.incomplete) {\r\n            return theme.colors.primary400;\r\n        }\r\n    }\r\n    else {\r\n        if (!isInverse && !hasError) {\r\n            if (stepStatus === StepStatus.active) {\r\n                return theme.colors.primary500;\r\n            }\r\n            else if (stepStatus === StepStatus.incomplete) {\r\n                return theme.colors.neutral300;\r\n            }\r\n        }\r\n    }\r\n}\r\nfunction buildStepCircleBackgroundColors(props) {\r\n    const { isInverse, stepStatus, hasError, theme } = props;\r\n    if (isInverse) {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.tertiary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n    else {\r\n        if (stepStatus === StepStatus.completed && !hasError) {\r\n            return theme.colors.primary500;\r\n        }\r\n        else if (hasError) {\r\n            return theme.colors.danger500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepLabelColors(props) {\r\n    const { label, secondaryLabel, theme, isInverse } = props;\r\n    if (isInverse) {\r\n        if (label) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return transparentize(0.3, theme.colors.neutral100);\r\n        }\r\n    }\r\n    else {\r\n        if (label) {\r\n            return theme.colors.neutral700;\r\n        }\r\n        else if (secondaryLabel) {\r\n            return theme.colors.neutral500;\r\n        }\r\n    }\r\n}\r\nfunction buildStepSvgColors(props) {\r\n    const { theme, hasError, isInverse } = props;\r\n    if (isInverse) {\r\n        if (hasError) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        return theme.colors.primary600;\r\n    }\r\n    else {\r\n        return theme.colors.neutral100;\r\n    }\r\n}\r\nexport const HiddenLabelText = styled.span `\n  ${HiddenStyles};\n`;\r\nconst StyledStep = styled.div `\n  display: flex;\n  flex-direction: ${props => !props.isVerticalOrientation && 'column'};\n  justify-content: center;\n  text-align: ${props => !props.isVerticalOrientation && 'center'};\n  align-self: self-start;\n  align-items: ${props => !props.isVerticalOrientation && 'center'};\n\n  &:last-child > span {\n    margin-bottom: ${props => props.isVerticalOrientation && 0};\n  }\n`;\r\nconst StyledStepIndicator = styled.span `\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    ${props => (props.stepStatus === StepStatus.incomplete && !props.hasError) ||\r\n    (props.stepStatus === StepStatus.active && !props.hasError)\r\n    ? buildStepCircleOutlineColors\r\n    : 'none'};\n  background: ${buildStepCircleBackgroundColors};\n  svg {\n    color: ${buildStepSvgColors};\n    width: ${props => props.theme.iconSizes.xSmall}px;\n    height: ${props => props.theme.iconSizes.xSmall}px;\n  }\n`;\r\nconst StyledStepTextWrapper = styled.span `\n  flex: 1;\n  display: flex;\n  align-self: center;\n  flex-direction: column;\n  position: relative;\n  margin: ${props => props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0'};\n`;\r\nconst StyledLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-weight: 600;\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`;\r\nconst StyledSecondaryLabel = styled.span `\n  color: ${buildStepLabelColors};\n  font-size: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.fontSize};\n  letter-spacing: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.letterSpacing};\n  line-height: ${props => props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight};\n  margin: ${props => props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px'};\n`;\r\nexport const Step = React.forwardRef((props, ref) => {\r\n    const { hasError, index, label, layout, orientation = StepperOrientation.horizontal, secondaryLabel, stepLabel, testId, isInverse: isInverseProp, stepStatus, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const isVerticalOrientation = orientation === StepperOrientation.vertical;\r\n    return (React.createElement(StyledStep, Object.assign({}, rest, { ref: ref, \"data-testid\": testId, isVerticalOrientation: isVerticalOrientation }),\r\n        React.createElement(StyledStepIndicator, { hasError: hasError, isInverse: isInverse, stepStatus: stepStatus, theme: theme },\r\n            stepStatus === StepStatus.completed && !hasError && (React.createElement(CheckIcon, { \"aria-hidden\": \"true\" })),\r\n            hasError && React.createElement(CloseIcon, { \"aria-hidden\": \"true\" })),\r\n        React.createElement(StyledStepTextWrapper, { isVerticalOrientation: isVerticalOrientation }, layout !== StepperLayout.hideLabels &&\r\n            layout !== StepperLayout.summaryView ? (React.createElement(React.Fragment, null,\r\n            layout === StepperLayout.showLabels && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n                ? `${stepLabel} ${stepStatus}, `\r\n                : ''}`)),\r\n            label && (React.createElement(StyledLabel, { label: label, isInverse: isInverse, \"data-testid\": testId && `${testId}-label`, theme: theme }, label)),\r\n            secondaryLabel && (React.createElement(StyledSecondaryLabel, { secondaryLabel: secondaryLabel, isInverse: isInverse, \"data-testid\": testId && `${testId}-secondaryLabel`, theme: theme, isVerticalOrientation: isVerticalOrientation }, secondaryLabel)))) : (layout !== StepperLayout.summaryView && (React.createElement(HiddenLabelText, null, `${stepStatus === StepStatus.completed\r\n            ? `${stepLabel} ${stepStatus}, `\r\n            : ''}${label || ''}${secondaryLabel ? ' ' : ''}${secondaryLabel || ''}`))))));\r\n});\r\n//# sourceMappingURL=Step.js.map"]} */"));
26366
26376
  var Step = /*#__PURE__*/forwardRef(function (props, ref) {
26367
26377
  var hasError = props.hasError,
26368
26378
  label = props.label,
@@ -26389,7 +26399,7 @@ var Step = /*#__PURE__*/forwardRef(function (props, ref) {
26389
26399
  theme: theme
26390
26400
  }, stepStatus === StepStatus.completed && !hasError && createElement(CheckIcon, {
26391
26401
  "aria-hidden": "true"
26392
- }), hasError && createElement(CrossIcon, {
26402
+ }), hasError && createElement(CloseIcon, {
26393
26403
  "aria-hidden": "true"
26394
26404
  })), createElement(StyledStepTextWrapper, {
26395
26405
  isVerticalOrientation: isVerticalOrientation
@@ -26744,11 +26754,11 @@ var ToastWrapper = /*#__PURE__*/_styled("div", {
26744
26754
  return 0 - props.bottomOffsetForContainer;
26745
26755
  }, "px);transition:bottom 0.3s;z-index:999;@media (max-width: 600px){bottom:", function (props) {
26746
26756
  return props.bottomOffsetForToast + 10;
26747
- }, "px;left:10px;right:10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNZ0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBBbGVydEJhc2UsIHRyYW5zaXRpb25EdXJhdGlvbiB9IGZyb20gJy4uL0FsZXJ0QmFzZSc7XHJcbmltcG9ydCB7IGdldFRyYXBFbGVtZW50cyB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgVG9hc3RzQ29udGV4dCB9IGZyb20gJy4vVG9hc3RzQ29udGFpbmVyJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCBUb2FzdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmJvdHRvbU9mZnNldEZvclRvYXN0ICsgMjB9cHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGxlZnQ6IDIwcHg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgbWF4LXdpZHRoOiA2MDBweDtcbiAgbWluLXdpZHRoOiAzMjBweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVkoJHtwcm9wcyA9PiAwIC0gcHJvcHMuYm90dG9tT2Zmc2V0Rm9yQ29udGFpbmVyfXB4KTtcbiAgdHJhbnNpdGlvbjogYm90dG9tIDAuM3M7XG4gIHotaW5kZXg6IDk5OTtcblxuICBAbWVkaWEgKG1heC13aWR0aDogNjAwcHgpIHtcbiAgICBib3R0b206ICR7cHJvcHMgPT4gcHJvcHMuYm90dG9tT2Zmc2V0Rm9yVG9hc3QgKyAxMH1weDtcbiAgICBsZWZ0OiAxMHB4O1xuICAgIHJpZ2h0OiAxMHB4O1xuICB9XG5gO1xyXG5jb25zdCBERUZBVUxUX1RPQVNUX0RVUkFUSU9OID0gNTAwMDtcclxuY29uc3QgVE9BU1RfSEVJR0hUID0gNjU7XHJcbmV4cG9ydCBjb25zdCBUb2FzdCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHRpbWVyQXV0b0hpZGUgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IFtpc0Rpc21pc3NlZCwgc2V0SXNEaXNtaXNzZWRdID0gUmVhY3QudXNlU3RhdGUoZmFsc2UpO1xyXG4gICAgY29uc3QgW2lzUGF1c2VkLCBzZXRJc1BhdXNlZF0gPSBSZWFjdC51c2VTdGF0ZShmYWxzZSk7XHJcbiAgICBjb25zdCBbdGltZXJUaW1lUmVtYWluaW5nLCBzZXRUaW1lclRpbWVSZW1haW5pbmddID0gUmVhY3QudXNlU3RhdGUoKTtcclxuICAgIGNvbnN0IHsgYWxlcnRTdHlsZSwgaWQ6IGRlZmF1bHRJZCwgdGVzdElkLCB2YXJpYW50LCBkaXNhYmxlQXV0b0Rpc21pc3MsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgdG9hc3REdXJhdGlvbiwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaWQgPSB1c2VHZW5lcmF0ZUlkKGRlZmF1bHRJZCk7XHJcbiAgICBjb25zdCBsYXN0Rm9jdXMgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IHsgYm90dG9tT2Zmc2V0LCB0b2FzdHNBcnJheSB9ID0gUmVhY3QudXNlQ29udGV4dChUb2FzdHNDb250ZXh0KTtcclxuICAgIGNvbnN0IHRpbWVyU3RhcnRUaW1lID0gRGF0ZS5ub3coKTtcclxuICAgIGNvbnN0IGNvbnRhaW5lckVsZW1lbnQgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGZ1bmN0aW9uIGRpc21pc3NUb2FzdCgpIHtcclxuICAgICAgICBzZXRJc0Rpc21pc3NlZCh0cnVlKTtcclxuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAgICAgaWYgKHRvYXN0c0FycmF5LmN1cnJlbnQpIHtcclxuICAgICAgICAgICAgICAgIHRvYXN0c0FycmF5LmN1cnJlbnQgPSB0b2FzdHNBcnJheS5jdXJyZW50LmZpbHRlcih0b2FzdElkID0+IHRvYXN0SWQgIT09IGNvbnRhaW5lckVsZW1lbnQuY3VycmVudCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9LCAwKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGNsZWFyVGltZW91dEFuZERpc21pc3MoKSB7XHJcbiAgICAgICAgY2xlYXJUaW1lb3V0KHRpbWVyQXV0b0hpZGUuY3VycmVudCk7XHJcbiAgICAgICAgZGlzbWlzc1RvYXN0KCk7XHJcbiAgICAgICAgaWYgKGxhc3RGb2N1cy5jdXJyZW50KSB7XHJcbiAgICAgICAgICAgIGxhc3RGb2N1cy5jdXJyZW50LmZvY3VzKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gc2V0QXV0b0hpZGVUaW1lcihkdXJhdGlvbiA9IERFRkFVTFRfVE9BU1RfRFVSQVRJT04pIHtcclxuICAgICAgICBjbGVhclRpbWVvdXQodGltZXJBdXRvSGlkZS5jdXJyZW50KTtcclxuICAgICAgICBjb25zdCB0b3RhbER1cmF0aW9uID0gZHVyYXRpb24gKyB0cmFuc2l0aW9uRHVyYXRpb247XHJcbiAgICAgICAgdGltZXJBdXRvSGlkZS5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIGRpc21pc3NUb2FzdCgpO1xyXG4gICAgICAgIH0sIHRvdGFsRHVyYXRpb24pO1xyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gaGFuZGxlUGF1c2UoKSB7XHJcbiAgICAgICAgY29uc3QgZHVyYXRpb24gPSB0aW1lclRpbWVSZW1haW5pbmdcclxuICAgICAgICAgICAgPyB0aW1lclRpbWVSZW1haW5pbmdcclxuICAgICAgICAgICAgOiB0b2FzdER1cmF0aW9uXHJcbiAgICAgICAgICAgICAgICA/IHRvYXN0RHVyYXRpb25cclxuICAgICAgICAgICAgICAgIDogREVGQVVMVF9UT0FTVF9EVVJBVElPTjtcclxuICAgICAgICBjb25zdCB0aW1lUmVtYWluaW5nID0gZHVyYXRpb24gLSAoRGF0ZS5ub3coKSAtIHRpbWVyU3RhcnRUaW1lKTtcclxuICAgICAgICBjbGVhclRpbWVvdXQodGltZXJBdXRvSGlkZS5jdXJyZW50KTtcclxuICAgICAgICBzZXRUaW1lclRpbWVSZW1haW5pbmcodGltZVJlbWFpbmluZyk7XHJcbiAgICAgICAgc2V0SXNQYXVzZWQodHJ1ZSk7XHJcbiAgICB9XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVSZXN1bWUoKSB7XHJcbiAgICAgICAgc2V0QXV0b0hpZGVUaW1lcih0aW1lclRpbWVSZW1haW5pbmcpO1xyXG4gICAgICAgIHNldElzUGF1c2VkKGZhbHNlKTtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZU1vdXNlRW50ZXIoZXZlbnQpIHtcclxuICAgICAgICBwcm9wcy5vbk1vdXNlRW50ZXIgJiZcclxuICAgICAgICAgICAgdHlwZW9mIHByb3BzLm9uTW91c2VFbnRlciA9PT0gJ2Z1bmN0aW9uJyAmJlxyXG4gICAgICAgICAgICBwcm9wcy5vbk1vdXNlRW50ZXIoZXZlbnQpO1xyXG4gICAgICAgIGlmICghcHJvcHMuZGlzYWJsZUF1dG9EaXNtaXNzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVBhdXNlKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gaGFuZGxlTW91c2VMZWF2ZShldmVudCkge1xyXG4gICAgICAgIHByb3BzLm9uTW91c2VMZWF2ZSAmJlxyXG4gICAgICAgICAgICB0eXBlb2YgcHJvcHMub25Nb3VzZUxlYXZlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIHByb3BzLm9uTW91c2VMZWF2ZShldmVudCk7XHJcbiAgICAgICAgaWYgKCFwcm9wcy5kaXNhYmxlQXV0b0Rpc21pc3MpIHtcclxuICAgICAgICAgICAgaGFuZGxlUmVzdW1lKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gY2FsY3VsYXRlQW5kU2V0Qm90dG9tT2Zmc2V0Rm9yVG9hc3QoKSB7XHJcbiAgICAgICAgdXBkYXRlQm90dG9tT2Zmc2V0Rm9yVG9hc3QodHlwZW9mIHRvYXN0c0FycmF5LmN1cnJlbnRbMF0gPT09ICd1bmRlZmluZWQnXHJcbiAgICAgICAgICAgID8gMFxyXG4gICAgICAgICAgICA6IHRvYXN0c0FycmF5LmN1cnJlbnQuaW5kZXhPZihjb250YWluZXJFbGVtZW50LmN1cnJlbnQpICogVE9BU1RfSEVJR0hUKTtcclxuICAgIH1cclxuICAgIGNvbnN0IFtib3R0b21PZmZzZXRGb3JUb2FzdCwgdXBkYXRlQm90dG9tT2Zmc2V0Rm9yVG9hc3RdID0gUmVhY3QudXNlU3RhdGUoMCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGxhc3RGb2N1cy5jdXJyZW50ID0gZG9jdW1lbnQuYWN0aXZlRWxlbWVudDtcclxuICAgICAgICBpZiAoIXByb3BzLmRpc2FibGVBdXRvRGlzbWlzcykge1xyXG4gICAgICAgICAgICBzZXRBdXRvSGlkZVRpbWVyKHByb3BzLnRvYXN0RHVyYXRpb24pO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gKCkgPT4ge1xyXG4gICAgICAgICAgICBjbGVhclRpbWVvdXQodGltZXJBdXRvSGlkZS5jdXJyZW50KTtcclxuICAgICAgICB9O1xyXG4gICAgfSwgW10pO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoIWRpc2FibGVBdXRvRGlzbWlzcykge1xyXG4gICAgICAgICAgICBjb25zdCBmb2N1c2FibGVFbGVtZW50cyA9IGdldFRyYXBFbGVtZW50cyhjb250YWluZXJFbGVtZW50KTtcclxuICAgICAgICAgICAgZm9jdXNhYmxlRWxlbWVudHMuZm9yRWFjaChlbGVtZW50ID0+IHtcclxuICAgICAgICAgICAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignZm9jdXMnLCBoYW5kbGVQYXVzZSk7XHJcbiAgICAgICAgICAgICAgICBlbGVtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ2JsdXInLCBoYW5kbGVSZXN1bWUpO1xyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICh0b2FzdHNBcnJheSkge1xyXG4gICAgICAgICAgICB0b2FzdHNBcnJheS5jdXJyZW50ID0gdG9hc3RzQXJyYXkuY3VycmVudC5pbmNsdWRlcyhjb250YWluZXJFbGVtZW50LmN1cnJlbnQpXHJcbiAgICAgICAgICAgICAgICA/IHRvYXN0c0FycmF5LmN1cnJlbnRcclxuICAgICAgICAgICAgICAgIDogdG9hc3RzQXJyYXkuY3VycmVudC5jb25jYXQoW2NvbnRhaW5lckVsZW1lbnQuY3VycmVudF0pO1xyXG4gICAgICAgICAgICBjYWxjdWxhdGVBbmRTZXRCb3R0b21PZmZzZXRGb3JUb2FzdCgpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIFJlYWN0LnVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgY2FsY3VsYXRlQW5kU2V0Qm90dG9tT2Zmc2V0Rm9yVG9hc3QoKTtcclxuICAgIH0sIFt0b2FzdHNBcnJheS5jdXJyZW50XSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVG9hc3RXcmFwcGVyLCB7IGJvdHRvbU9mZnNldEZvclRvYXN0OiBib3R0b21PZmZzZXRGb3JUb2FzdCwgYm90dG9tT2Zmc2V0Rm9yQ29udGFpbmVyOiBib3R0b21PZmZzZXQsIG9uTW91c2VFbnRlcjogaGFuZGxlTW91c2VFbnRlciwgb25Nb3VzZUxlYXZlOiBoYW5kbGVNb3VzZUxlYXZlLCByZWY6IGNvbnRhaW5lckVsZW1lbnQsIHN0eWxlOiBjb250YWluZXJTdHlsZSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFsZXJ0QmFzZSwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgZm9yY2VEaXNtaXNzOiBjbGVhclRpbWVvdXRBbmREaXNtaXNzLCBoYXNUaW1lclJpbmc6ICFkaXNhYmxlQXV0b0Rpc21pc3MsIGlkOiBpZCwgaXNEaXNtaXNzaWJsZTogdHJ1ZSwgaXNEaXNtaXNzZWQ6IGlzRGlzbWlzc2VkLCBpc1BhdXNlZDogaXNQYXVzZWQsIGlzVG9hc3Q6IHRydWUsIG9uRGlzbWlzczogcHJvcHMub25EaXNtaXNzLCByZWY6IHJlZiwgc3R5bGU6IHsgLi4uYWxlcnRTdHlsZSB9LCB0b2FzdER1cmF0aW9uOiB0b2FzdER1cmF0aW9uID8gdG9hc3REdXJhdGlvbiA6IERFRkFVTFRfVE9BU1RfRFVSQVRJT04sIHZhcmlhbnQ6IHZhcmlhbnQgfSksIGNoaWxkcmVuKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
26757
+ }, "px;left:10px;right:10px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAKgC","file":"index.tsx","sourcesContent":["import styled from '@emotion/styled';\r\nimport * as React from 'react';\r\nimport { getTrapElements, useGenerateId } from '../../utils';\r\nimport { AlertBase, transitionDuration, } from '../AlertBase';\r\nimport { ToastsContext } from './ToastsContainer';\r\nconst ToastWrapper = styled.div `\n  bottom: ${props => props.bottomOffsetForToast + 20}px;\n  display: flex;\n  left: 20px;\n  justify-content: flex-start;\n  max-width: 600px;\n  min-width: 320px;\n  position: fixed;\n  transform: translateY(${props => 0 - props.bottomOffsetForContainer}px);\n  transition: bottom 0.3s;\n  z-index: 999;\n\n  @media (max-width: 600px) {\n    bottom: ${props => props.bottomOffsetForToast + 10}px;\n    left: 10px;\n    right: 10px;\n  }\n`;\r\nconst DEFAULT_TOAST_DURATION = 5000;\r\nconst TOAST_HEIGHT = 65;\r\nexport const Toast = React.forwardRef((props, ref) => {\r\n    const timerAutoHide = React.useRef(null);\r\n    const [isDismissed, setIsDismissed] = React.useState(false);\r\n    const [isPaused, setIsPaused] = React.useState(false);\r\n    const [timerTimeRemaining, setTimerTimeRemaining] = React.useState();\r\n    const mountedRef = React.useRef(true);\r\n    const { alertStyle, id: defaultId, testId, variant, disableAutoDismiss, children, containerStyle, toastDuration, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const lastFocus = React.useRef();\r\n    const { bottomOffset, toastsArray } = React.useContext(ToastsContext);\r\n    const timerStartTime = Date.now();\r\n    const containerElement = React.useRef();\r\n    function dismissToast() {\r\n        if (!mountedRef.current)\r\n            return;\r\n        setIsDismissed(true);\r\n        setTimeout(() => {\r\n            if (toastsArray.current) {\r\n                toastsArray.current = toastsArray.current.filter(toastId => toastId !== containerElement.current);\r\n            }\r\n        }, 0);\r\n    }\r\n    function clearTimeoutAndDismiss() {\r\n        clearTimeout(timerAutoHide.current);\r\n        dismissToast();\r\n        if (lastFocus.current) {\r\n            lastFocus.current.focus();\r\n        }\r\n    }\r\n    function setAutoHideTimer(duration = DEFAULT_TOAST_DURATION) {\r\n        clearTimeout(timerAutoHide.current);\r\n        const totalDuration = duration + transitionDuration;\r\n        timerAutoHide.current = setTimeout(() => {\r\n            if (mountedRef.current) {\r\n                dismissToast();\r\n            }\r\n        }, totalDuration);\r\n    }\r\n    function handlePause() {\r\n        const duration = timerTimeRemaining\r\n            ? timerTimeRemaining\r\n            : toastDuration\r\n                ? toastDuration\r\n                : DEFAULT_TOAST_DURATION;\r\n        const timeRemaining = duration - (Date.now() - timerStartTime);\r\n        clearTimeout(timerAutoHide.current);\r\n        setTimerTimeRemaining(timeRemaining);\r\n        setIsPaused(true);\r\n    }\r\n    function handleResume() {\r\n        setAutoHideTimer(timerTimeRemaining);\r\n        setIsPaused(false);\r\n    }\r\n    function handleMouseEnter(event) {\r\n        props.onMouseEnter &&\r\n            typeof props.onMouseEnter === 'function' &&\r\n            props.onMouseEnter(event);\r\n        if (!props.disableAutoDismiss) {\r\n            handlePause();\r\n        }\r\n    }\r\n    function handleMouseLeave(event) {\r\n        props.onMouseLeave &&\r\n            typeof props.onMouseLeave === 'function' &&\r\n            props.onMouseLeave(event);\r\n        if (!props.disableAutoDismiss) {\r\n            handleResume();\r\n        }\r\n    }\r\n    function calculateAndSetBottomOffsetForToast() {\r\n        updateBottomOffsetForToast(typeof toastsArray.current[0] === 'undefined'\r\n            ? 0\r\n            : toastsArray.current.indexOf(containerElement.current) * TOAST_HEIGHT);\r\n    }\r\n    const [bottomOffsetForToast, updateBottomOffsetForToast] = React.useState(0);\r\n    React.useEffect(() => {\r\n        lastFocus.current = document.activeElement;\r\n        if (!props.disableAutoDismiss) {\r\n            setAutoHideTimer(props.toastDuration);\r\n        }\r\n        return () => {\r\n            clearTimeout(timerAutoHide.current);\r\n            mountedRef.current = false;\r\n        };\r\n    }, [props.disableAutoDismiss, props.toastDuration]);\r\n    React.useEffect(() => {\r\n        if (!props.disableAutoDismiss) {\r\n            const focusableElements = getTrapElements(containerElement);\r\n            focusableElements.forEach(element => {\r\n                element.addEventListener('focus', handlePause);\r\n                element.addEventListener('blur', handleResume);\r\n            });\r\n            return () => {\r\n                focusableElements.forEach(element => {\r\n                    element.removeEventListener('focus', handlePause);\r\n                    element.removeEventListener('blur', handleResume);\r\n                });\r\n            };\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        if (toastsArray) {\r\n            toastsArray.current = toastsArray.current.includes(containerElement.current)\r\n                ? toastsArray.current\r\n                : toastsArray.current.concat([containerElement.current]);\r\n            calculateAndSetBottomOffsetForToast();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        calculateAndSetBottomOffsetForToast();\r\n    }, [toastsArray.current]);\r\n    return (React.createElement(ToastWrapper, { bottomOffsetForToast: bottomOffsetForToast, bottomOffsetForContainer: bottomOffset, onMouseEnter: handleMouseEnter, onMouseLeave: handleMouseLeave, ref: containerElement, style: containerStyle, \"data-testid\": testId },\r\n        React.createElement(AlertBase, Object.assign({}, other, { forceDismiss: clearTimeoutAndDismiss, hasTimerRing: !disableAutoDismiss, id: id, isDismissible: true, isDismissed: isDismissed, isPaused: isPaused, isToast: true, onDismiss: props.onDismiss, ref: ref, style: { ...alertStyle }, toastDuration: toastDuration ? toastDuration : DEFAULT_TOAST_DURATION, variant: variant }), children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
26748
26758
  var DEFAULT_TOAST_DURATION = 5000;
26749
26759
  var TOAST_HEIGHT = 65;
26750
26760
  var Toast = /*#__PURE__*/forwardRef(function (props, ref) {
26751
- var timerAutoHide = useRef();
26761
+ var timerAutoHide = useRef(null);
26752
26762
  var _React$useState = useState(false),
26753
26763
  isDismissed = _React$useState[0],
26754
26764
  setIsDismissed = _React$useState[1];
@@ -26758,6 +26768,7 @@ var Toast = /*#__PURE__*/forwardRef(function (props, ref) {
26758
26768
  var _React$useState3 = useState(),
26759
26769
  timerTimeRemaining = _React$useState3[0],
26760
26770
  setTimerTimeRemaining = _React$useState3[1];
26771
+ var mountedRef = useRef(true);
26761
26772
  var alertStyle = props.alertStyle,
26762
26773
  defaultId = props.id,
26763
26774
  testId = props.testId,
@@ -26775,6 +26786,7 @@ var Toast = /*#__PURE__*/forwardRef(function (props, ref) {
26775
26786
  var timerStartTime = Date.now();
26776
26787
  var containerElement = useRef();
26777
26788
  function dismissToast() {
26789
+ if (!mountedRef.current) return;
26778
26790
  setIsDismissed(true);
26779
26791
  setTimeout(function () {
26780
26792
  if (toastsArray.current) {
@@ -26798,7 +26810,9 @@ var Toast = /*#__PURE__*/forwardRef(function (props, ref) {
26798
26810
  clearTimeout(timerAutoHide.current);
26799
26811
  var totalDuration = duration + transitionDuration;
26800
26812
  timerAutoHide.current = setTimeout(function () {
26801
- dismissToast();
26813
+ if (mountedRef.current) {
26814
+ dismissToast();
26815
+ }
26802
26816
  }, totalDuration);
26803
26817
  }
26804
26818
  function handlePause() {
@@ -26837,15 +26851,22 @@ var Toast = /*#__PURE__*/forwardRef(function (props, ref) {
26837
26851
  }
26838
26852
  return function () {
26839
26853
  clearTimeout(timerAutoHide.current);
26854
+ mountedRef.current = false;
26840
26855
  };
26841
- }, []);
26856
+ }, [props.disableAutoDismiss, props.toastDuration]);
26842
26857
  useEffect(function () {
26843
- if (!disableAutoDismiss) {
26858
+ if (!props.disableAutoDismiss) {
26844
26859
  var focusableElements = getTrapElements(containerElement);
26845
26860
  focusableElements.forEach(function (element) {
26846
26861
  element.addEventListener('focus', handlePause);
26847
26862
  element.addEventListener('blur', handleResume);
26848
26863
  });
26864
+ return function () {
26865
+ focusableElements.forEach(function (element) {
26866
+ element.removeEventListener('focus', handlePause);
26867
+ element.removeEventListener('blur', handleResume);
26868
+ });
26869
+ };
26849
26870
  }
26850
26871
  }, []);
26851
26872
  useEffect(function () {
@@ -27490,15 +27511,30 @@ var TimePicker = /*#__PURE__*/forwardRef(function (props, ref) {
27490
27511
  }));
27491
27512
  });
27492
27513
 
27514
+ 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)."; }
27515
+ var _ref$6 = process.env.NODE_ENV === "production" ? {
27516
+ name: "1vymn85-getGlobalImports",
27517
+ styles: "@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,100..900;1,100..900&family=Work+Sans:ital,wght@0,100..900;1,100..900&display=swap');{};label:getGlobalImports;"
27518
+ } : {
27519
+ name: "1vymn85-getGlobalImports",
27520
+ styles: "@import url('https://fonts.googleapis.com/css2?family=Noto+Serif:ital,wght@0,100..900;1,100..900&family=Work+Sans:ital,wght@0,100..900;1,100..900&display=swap');{};label:getGlobalImports;",
27521
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWwsIGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vVGhlbWVDb250ZXh0JztcclxuZnVuY3Rpb24gZ2V0R2xvYmFsSW1wb3J0cygpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgIEBpbXBvcnQgdXJsKCdodHRwczovL2ZvbnRzLmdvb2dsZWFwaXMuY29tL2NzczI/ZmFtaWx5PU5vdG8rU2VyaWY6aXRhbCx3Z2h0QDAsMTAwLi45MDA7MSwxMDAuLjkwMCZmYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMC4uOTAwOzEsMTAwLi45MDAmZGlzcGxheT1zd2FwJyk7XG4gIGA7XHJcbn1cclxuZnVuY3Rpb24gZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogLTFweDtcbiAgICB9XG5cbiAgICBodG1sIHtcbiAgICAgIC1tcy10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgLXdlYmtpdC10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgZm9udC1zaXplOiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICAgIHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuICAgIH1cblxuICAgIGh0bWwsXG4gICAgYm9keSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2lzSW52ZXJzZVxyXG4gICAgICAgID8gdGhlbWUuY29sb3JzLnByaW1hcnk2MDBcclxuICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwIDogdGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICAgICAgbWFyZ2luOiAwO1xuICAgICAgcGFkZGluZzogMDtcbiAgICB9XG5cbiAgICBib2R5IHtcbiAgICAgIGZvbnQtZmFtaWx5OiAke3RoZW1lLmJvZHlGb250fTtcbiAgICAgIGZvbnQtc3R5bGU6IG5vcm1hbDtcbiAgICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgIH1cblxuICAgIGEge1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5IDogdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG5cbiAgICAgICY6aG92ZXIsXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB9XG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICAgJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlIDogdGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBidXR0b24sXG4gICAgaW5wdXQsXG4gICAgb3B0Z3JvdXAsXG4gICAgc2VsZWN0LFxuICAgIHRleHRhcmVhIHtcbiAgICAgIGZvbnQ6IGluaGVyaXQ7XG4gICAgICBtYXJnaW46IDA7XG4gICAgfVxuXG4gICAgc3ZnOm5vdCg6cm9vdCkge1xuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICB9XG4gIGA7XHJcbn1cclxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IHtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRoZW1lQ29udGV4dC5Db25zdW1lciwgbnVsbCwgdGhlbWUgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRHbG9iYWxJbXBvcnRzKCkgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
27522
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$A
27523
+ };
27524
+ function getGlobalImports() {
27525
+ return _ref$6;
27526
+ }
27493
27527
  function getStyles(theme, isInverse) {
27494
- return /*#__PURE__*/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:-1px;}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;};label:getStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWwsIGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vVGhlbWVDb250ZXh0JztcclxuZnVuY3Rpb24gZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgIEBpbXBvcnQgdXJsKCdodHRwczovL2ZvbnRzLmdvb2dsZWFwaXMuY29tL2NzczI/ZmFtaWx5PVdvcmsrU2FuczppdGFsLHdnaHRAMCwxMDA7MCwyMDA7MCwzMDA7MCw0MDA7MCw1MDA7MCw2MDA7MCw3MDA7MCw4MDA7MCw5MDA7MSwxMDA7MSwyMDA7MSwzMDA7MSw0MDA7MSw1MDA7MSw2MDA7MSw3MDA7MSw4MDA7MSw5MDAmZGlzcGxheT1zd2FwJyk7XG4gICAgQGltcG9ydCB1cmwoJ2h0dHBzOi8vZm9udHMuZ29vZ2xlYXBpcy5jb20vY3NzMj9mYW1pbHk9Tm90bytTZXJpZjppdGFsLHdnaHRAMCw0MDA7MCw3MDA7MSw0MDA7MSw3MDAmZGlzcGxheT1zd2FwJyk7XG5cbiAgICAqLFxuICAgICo6YmVmb3JlLFxuICAgICo6YWZ0ZXIge1xuICAgICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICB9XG5cbiAgICAqOmZvY3VzIHtcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2UgOiB0aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IC0xcHg7XG4gICAgfVxuXG4gICAgaHRtbCB7XG4gICAgICAtbXMtdGV4dC1zaXplLWFkanVzdDogMTAwJTtcbiAgICAgIC13ZWJraXQtdGV4dC1zaXplLWFkanVzdDogMTAwJTtcbiAgICAgIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgICAgIGxpbmUtaGVpZ2h0OiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gICAgICBzY3JvbGwtYmVoYXZpb3I6IHNtb290aDtcbiAgICB9XG5cbiAgICBodG1sLFxuICAgIGJvZHkge1xuICAgICAgYmFja2dyb3VuZDogJHtpc0ludmVyc2VcclxuICAgICAgICA/IHRoZW1lLmNvbG9ycy5wcmltYXJ5NjAwXHJcbiAgICAgICAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbDEwMH07XG4gICAgICBjb2xvcjogJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMubmV1dHJhbDEwMCA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgICAgIG1hcmdpbjogMDtcbiAgICAgIHBhZGRpbmc6IDA7XG4gICAgfVxuXG4gICAgYm9keSB7XG4gICAgICBmb250LWZhbWlseTogJHt0aGVtZS5ib2R5Rm9udH07XG4gICAgICBmb250LXN0eWxlOiBub3JtYWw7XG4gICAgICBmb250LXdlaWdodDogNDAwO1xuICAgICAgZm9udC1zaXplOiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICB9XG5cbiAgICBhIHtcbiAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy50ZXJ0aWFyeSA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5fTtcbiAgICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICAgIHRleHQtZGVjb3JhdGlvbjogdW5kZXJsaW5lO1xuXG4gICAgICAmOmhvdmVyLFxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwIDogdGhlbWUuY29sb3JzLnByaW1hcnk3MDB9O1xuICAgICAgfVxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICAgIG91dGxpbmUtb2Zmc2V0OiAycHg7XG4gICAgICB9XG4gICAgfVxuXG4gICAgYnV0dG9uLFxuICAgIGlucHV0LFxuICAgIG9wdGdyb3VwLFxuICAgIHNlbGVjdCxcbiAgICB0ZXh0YXJlYSB7XG4gICAgICBmb250OiBpbmhlcml0O1xuICAgICAgbWFyZ2luOiAwO1xuICAgIH1cblxuICAgIHN2Zzpub3QoOnJvb3QpIHtcbiAgICAgIG92ZXJmbG93OiBoaWRkZW47XG4gICAgfVxuICBgO1xyXG59XHJcbmV4cG9ydCBjb25zdCBHbG9iYWxTdHlsZXMgPSAoKSA9PiB7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUaGVtZUNvbnRleHQuQ29uc3VtZXIsIG51bGwsIHRoZW1lID0+IFJlYWN0LmNyZWF0ZUVsZW1lbnQoR2xvYmFsLCB7IHN0eWxlczogZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIH0pKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdfQ== */"));
27528
+ return /*#__PURE__*/css("*,*:before,*:after{box-sizing:border-box;}*:focus{outline:2px solid ", isInverse ? theme.colors.focusInverse : theme.colors.focus, ";outline-offset:-1px;}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;};label:getStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWwsIGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vVGhlbWVDb250ZXh0JztcclxuZnVuY3Rpb24gZ2V0R2xvYmFsSW1wb3J0cygpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgIEBpbXBvcnQgdXJsKCdodHRwczovL2ZvbnRzLmdvb2dsZWFwaXMuY29tL2NzczI/ZmFtaWx5PU5vdG8rU2VyaWY6aXRhbCx3Z2h0QDAsMTAwLi45MDA7MSwxMDAuLjkwMCZmYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMC4uOTAwOzEsMTAwLi45MDAmZGlzcGxheT1zd2FwJyk7XG4gIGA7XHJcbn1cclxuZnVuY3Rpb24gZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogLTFweDtcbiAgICB9XG5cbiAgICBodG1sIHtcbiAgICAgIC1tcy10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgLXdlYmtpdC10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgZm9udC1zaXplOiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICAgIHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuICAgIH1cblxuICAgIGh0bWwsXG4gICAgYm9keSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2lzSW52ZXJzZVxyXG4gICAgICAgID8gdGhlbWUuY29sb3JzLnByaW1hcnk2MDBcclxuICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwIDogdGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICAgICAgbWFyZ2luOiAwO1xuICAgICAgcGFkZGluZzogMDtcbiAgICB9XG5cbiAgICBib2R5IHtcbiAgICAgIGZvbnQtZmFtaWx5OiAke3RoZW1lLmJvZHlGb250fTtcbiAgICAgIGZvbnQtc3R5bGU6IG5vcm1hbDtcbiAgICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgIH1cblxuICAgIGEge1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5IDogdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG5cbiAgICAgICY6aG92ZXIsXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB9XG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICAgJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlIDogdGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBidXR0b24sXG4gICAgaW5wdXQsXG4gICAgb3B0Z3JvdXAsXG4gICAgc2VsZWN0LFxuICAgIHRleHRhcmVhIHtcbiAgICAgIGZvbnQ6IGluaGVyaXQ7XG4gICAgICBtYXJnaW46IDA7XG4gICAgfVxuXG4gICAgc3ZnOm5vdCg6cm9vdCkge1xuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICB9XG4gIGA7XHJcbn1cclxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IHtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRoZW1lQ29udGV4dC5Db25zdW1lciwgbnVsbCwgdGhlbWUgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRHbG9iYWxJbXBvcnRzKCkgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
27495
27529
  }
27496
27530
  var GlobalStyles = function GlobalStyles() {
27497
27531
  var isInverse = useIsInverse();
27498
27532
  return createElement(ThemeContext.Consumer, null, function (theme) {
27499
- return createElement(Global, {
27533
+ return createElement(Fragment, null, createElement(Global, {
27534
+ styles: getGlobalImports()
27535
+ }), createElement(Global, {
27500
27536
  styles: getStyles(theme, isInverse)
27501
- });
27537
+ }));
27502
27538
  });
27503
27539
  };
27504
27540
 
@@ -29474,7 +29510,7 @@ function setBackgroundColor(props) {
29474
29510
  }
29475
29511
  }
29476
29512
  var ToggleButtonStyles = function ToggleButtonStyles(props) {
29477
- return /*#__PURE__*/css("background:", setBackgroundColor(props), ";&:not(:disabled):focus{background:", setBackgroundColor(props), ";outline-offset:-2px;}&:hover{background:", setBackgroundColor(props), ";};label:ToggleButtonStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEIrQyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgVG9nZ2xlQnV0dG9uR3JvdXBDb250ZXh0IH0gZnJvbSAnLi4vVG9nZ2xlQnV0dG9uR3JvdXAvVG9nZ2xlQnV0dG9uR3JvdXAnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbi8vU2V0cyB0aGUgaWNvbiB3aWR0aCBmb3IgaWNvbiBvbmx5IFRvZ2dsZSBCdXR0b25zXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRJY29uV2lkdGgocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5zaXplID09PSBCdXR0b25TaXplLnNtYWxsKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA3O1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUubGFyZ2UpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTE7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbn1cclxuLy9TZXRzIHRoZSBiYWNrZ3JvdW5kIGNvbG9yIGZvciB0aGUgVG9nZ2xlIEJ1dHRvblxyXG5leHBvcnQgZnVuY3Rpb24gc2V0QmFja2dyb3VuZENvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNTZWxlY3RlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMCk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IFRvZ2dsZUJ1dHRvblN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICY6bm90KDpkaXNhYmxlZCk6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG4gIH1cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiA9IHN0eWxlZChJY29uQnV0dG9uKSBgXG4gICR7VG9nZ2xlQnV0dG9uU3R5bGVzfVxuICBtaW4td2lkdGg6IGF1dG87XG4gIHdpZHRoOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyBzZXRJY29uV2lkdGggOiAnJyl9O1xuICBzcGFuIHtcbiAgICBwYWRkaW5nOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyAwIDogJycpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uVGV4dCA9IHN0eWxlZChCdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG5gO1xyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyAnYXJpYS1sYWJlbCc6IGFyaWFMYWJlbCwgY2hpbGRyZW4sIGRpc2FibGVkLCBpY29uLCBpc0NoZWNrZWQgPSBmYWxzZSwgaXNJbnZlcnNlLCBvbkNsaWNrLCB0ZXN0SWQsIHZhbHVlLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChUb2dnbGVCdXR0b25Hcm91cENvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0RlZmF1bHRDaGVja2VkID0gKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMgJiZcclxuICAgICAgICB2YWx1ZSAmJlxyXG4gICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXM/LmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB8fFxyXG4gICAgICAgIGlzQ2hlY2tlZDtcclxuICAgIGNvbnN0IFtpc1NlbGVjdGVkLCBzZXRJc1NlbGVjdGVkXSA9IFJlYWN0LnVzZVN0YXRlKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRJc1NlbGVjdGVkKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgfSwgW2lzQ2hlY2tlZF0pO1xyXG4gICAgY29uc3QgaW52ZXJzZUNoZWNrID0gY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlO1xyXG4gICAgY29uc3Qgcm9sZUNoZWNrID0gY29udGV4dC5leGNsdXNpdmUgPyAncmFkaW8nIDogJ3N3aXRjaCc7XHJcbiAgICBjb25zdCBoYW5kbGVDbGljayA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LmVuZm9yY2VkICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMubGVuZ3RoID09PSAxICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZChpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIC8vIGZsaXAgdGhlIHZhbHVlIG9mIGlzU2VsZWN0ZWRcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCghaXNTZWxlY3RlZCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uQ2xpY2sgJiYgdHlwZW9mIG9uQ2xpY2sgPT09ICdmdW5jdGlvbicgJiYgb25DbGljayhldmVudCk7XHJcbiAgICAgICAgY29udGV4dC5vbkNoYW5nZSAmJlxyXG4gICAgICAgICAgICB0eXBlb2YgY29udGV4dC5vbkNoYW5nZSA9PT0gJ2Z1bmN0aW9uJyAmJlxyXG4gICAgICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgIH07XHJcbiAgICBjb25zdCBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LnNlbGVjdGVkVmFsdWVzLmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQodHJ1ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGZhbHNlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgaWNvbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvbkljb24sIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGhhc0xhYmVsOiBjaGlsZHJlbiA/IHRydWUgOiBmYWxzZSwgaWNvbjogaWNvbiwgaWQ6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpbnZlcnNlQ2hlY2ssIG9uQ2xpY2s6IGNvbnRleHQuZXhjbHVzaXZlID8gaGFuZGxlQ2xpY2tFeGNsdXNpdmUgOiBoYW5kbGVDbGljaywgcmVmOiByZWYsIGVuZm9yY2VkOiBjb250ZXh0LmVuZm9yY2VkLCByb2xlOiByb2xlQ2hlY2ssIGlzU2VsZWN0ZWQ6IGlzU2VsZWN0ZWQsIGV4Y2x1c2l2ZTogY29udGV4dC5leGNsdXNpdmUsIHNpemU6IHByb3BzLnNpemUgfHwgY29udGV4dC5zaXplLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUb2dnbGVCdXR0b25UZXh0LCB7IFwiYXJpYS1jaGVja2VkXCI6IGlzU2VsZWN0ZWQsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGRpc2FibGVkOiBkaXNhYmxlZCwgdGhlbWU6IHRoZW1lLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSwgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VG9nZ2xlQnV0dG9uLmpzLm1hcCJdfQ== */"));
29513
+ return /*#__PURE__*/css("background:", setBackgroundColor(props), ";&:not(:disabled):focus{background:", setBackgroundColor(props), ";outline-offset:-2px;}&:hover{background:", setBackgroundColor(props), ";};label:ToggleButtonStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkIrQyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
29478
29514
  };
29479
29515
  var StyledToggleButtonIcon = /*#__PURE__*/_styled(IconButton, {
29480
29516
  target: "e1iyqz1w1",
@@ -29483,11 +29519,11 @@ var StyledToggleButtonIcon = /*#__PURE__*/_styled(IconButton, {
29483
29519
  return !props.hasLabel ? setIconWidth : '';
29484
29520
  }, ";span{padding:", function (props) {
29485
29521
  return !props.hasLabel ? 0 : '';
29486
- }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NrRCIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgVG9nZ2xlQnV0dG9uR3JvdXBDb250ZXh0IH0gZnJvbSAnLi4vVG9nZ2xlQnV0dG9uR3JvdXAvVG9nZ2xlQnV0dG9uR3JvdXAnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbi8vU2V0cyB0aGUgaWNvbiB3aWR0aCBmb3IgaWNvbiBvbmx5IFRvZ2dsZSBCdXR0b25zXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRJY29uV2lkdGgocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5zaXplID09PSBCdXR0b25TaXplLnNtYWxsKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA3O1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUubGFyZ2UpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTE7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbn1cclxuLy9TZXRzIHRoZSBiYWNrZ3JvdW5kIGNvbG9yIGZvciB0aGUgVG9nZ2xlIEJ1dHRvblxyXG5leHBvcnQgZnVuY3Rpb24gc2V0QmFja2dyb3VuZENvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNTZWxlY3RlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMCk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IFRvZ2dsZUJ1dHRvblN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICY6bm90KDpkaXNhYmxlZCk6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG4gIH1cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiA9IHN0eWxlZChJY29uQnV0dG9uKSBgXG4gICR7VG9nZ2xlQnV0dG9uU3R5bGVzfVxuICBtaW4td2lkdGg6IGF1dG87XG4gIHdpZHRoOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyBzZXRJY29uV2lkdGggOiAnJyl9O1xuICBzcGFuIHtcbiAgICBwYWRkaW5nOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyAwIDogJycpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uVGV4dCA9IHN0eWxlZChCdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG5gO1xyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyAnYXJpYS1sYWJlbCc6IGFyaWFMYWJlbCwgY2hpbGRyZW4sIGRpc2FibGVkLCBpY29uLCBpc0NoZWNrZWQgPSBmYWxzZSwgaXNJbnZlcnNlLCBvbkNsaWNrLCB0ZXN0SWQsIHZhbHVlLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChUb2dnbGVCdXR0b25Hcm91cENvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0RlZmF1bHRDaGVja2VkID0gKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMgJiZcclxuICAgICAgICB2YWx1ZSAmJlxyXG4gICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXM/LmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB8fFxyXG4gICAgICAgIGlzQ2hlY2tlZDtcclxuICAgIGNvbnN0IFtpc1NlbGVjdGVkLCBzZXRJc1NlbGVjdGVkXSA9IFJlYWN0LnVzZVN0YXRlKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRJc1NlbGVjdGVkKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgfSwgW2lzQ2hlY2tlZF0pO1xyXG4gICAgY29uc3QgaW52ZXJzZUNoZWNrID0gY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlO1xyXG4gICAgY29uc3Qgcm9sZUNoZWNrID0gY29udGV4dC5leGNsdXNpdmUgPyAncmFkaW8nIDogJ3N3aXRjaCc7XHJcbiAgICBjb25zdCBoYW5kbGVDbGljayA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LmVuZm9yY2VkICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMubGVuZ3RoID09PSAxICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZChpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIC8vIGZsaXAgdGhlIHZhbHVlIG9mIGlzU2VsZWN0ZWRcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCghaXNTZWxlY3RlZCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uQ2xpY2sgJiYgdHlwZW9mIG9uQ2xpY2sgPT09ICdmdW5jdGlvbicgJiYgb25DbGljayhldmVudCk7XHJcbiAgICAgICAgY29udGV4dC5vbkNoYW5nZSAmJlxyXG4gICAgICAgICAgICB0eXBlb2YgY29udGV4dC5vbkNoYW5nZSA9PT0gJ2Z1bmN0aW9uJyAmJlxyXG4gICAgICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgIH07XHJcbiAgICBjb25zdCBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LnNlbGVjdGVkVmFsdWVzLmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQodHJ1ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGZhbHNlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgaWNvbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvbkljb24sIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGhhc0xhYmVsOiBjaGlsZHJlbiA/IHRydWUgOiBmYWxzZSwgaWNvbjogaWNvbiwgaWQ6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpbnZlcnNlQ2hlY2ssIG9uQ2xpY2s6IGNvbnRleHQuZXhjbHVzaXZlID8gaGFuZGxlQ2xpY2tFeGNsdXNpdmUgOiBoYW5kbGVDbGljaywgcmVmOiByZWYsIGVuZm9yY2VkOiBjb250ZXh0LmVuZm9yY2VkLCByb2xlOiByb2xlQ2hlY2ssIGlzU2VsZWN0ZWQ6IGlzU2VsZWN0ZWQsIGV4Y2x1c2l2ZTogY29udGV4dC5leGNsdXNpdmUsIHNpemU6IHByb3BzLnNpemUgfHwgY29udGV4dC5zaXplLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUb2dnbGVCdXR0b25UZXh0LCB7IFwiYXJpYS1jaGVja2VkXCI6IGlzU2VsZWN0ZWQsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGRpc2FibGVkOiBkaXNhYmxlZCwgdGhlbWU6IHRoZW1lLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSwgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VG9nZ2xlQnV0dG9uLmpzLm1hcCJdfQ== */"));
29522
+ }, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUNrRCIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
29487
29523
  var StyledToggleButtonText = /*#__PURE__*/_styled(Button, {
29488
29524
  target: "e1iyqz1w0",
29489
29525
  label: "StyledToggleButtonText"
29490
- })(ToggleButtonStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEM4QyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgVG9nZ2xlQnV0dG9uR3JvdXBDb250ZXh0IH0gZnJvbSAnLi4vVG9nZ2xlQnV0dG9uR3JvdXAvVG9nZ2xlQnV0dG9uR3JvdXAnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbi8vU2V0cyB0aGUgaWNvbiB3aWR0aCBmb3IgaWNvbiBvbmx5IFRvZ2dsZSBCdXR0b25zXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRJY29uV2lkdGgocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5zaXplID09PSBCdXR0b25TaXplLnNtYWxsKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA3O1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUubGFyZ2UpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTE7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbn1cclxuLy9TZXRzIHRoZSBiYWNrZ3JvdW5kIGNvbG9yIGZvciB0aGUgVG9nZ2xlIEJ1dHRvblxyXG5leHBvcnQgZnVuY3Rpb24gc2V0QmFja2dyb3VuZENvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNTZWxlY3RlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMCk7XHJcbiAgICB9XHJcbn1cclxuZXhwb3J0IGNvbnN0IFRvZ2dsZUJ1dHRvblN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICY6bm90KDpkaXNhYmxlZCk6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICR7c2V0QmFja2dyb3VuZENvbG9yKHByb3BzKX07XG4gICAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG4gIH1cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiA9IHN0eWxlZChJY29uQnV0dG9uKSBgXG4gICR7VG9nZ2xlQnV0dG9uU3R5bGVzfVxuICBtaW4td2lkdGg6IGF1dG87XG4gIHdpZHRoOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyBzZXRJY29uV2lkdGggOiAnJyl9O1xuICBzcGFuIHtcbiAgICBwYWRkaW5nOiAke3Byb3BzID0+ICghcHJvcHMuaGFzTGFiZWwgPyAwIDogJycpfTtcbiAgfVxuYDtcclxuY29uc3QgU3R5bGVkVG9nZ2xlQnV0dG9uVGV4dCA9IHN0eWxlZChCdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG5gO1xyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyAnYXJpYS1sYWJlbCc6IGFyaWFMYWJlbCwgY2hpbGRyZW4sIGRpc2FibGVkLCBpY29uLCBpc0NoZWNrZWQgPSBmYWxzZSwgaXNJbnZlcnNlLCBvbkNsaWNrLCB0ZXN0SWQsIHZhbHVlLCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChUb2dnbGVCdXR0b25Hcm91cENvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0RlZmF1bHRDaGVja2VkID0gKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMgJiZcclxuICAgICAgICB2YWx1ZSAmJlxyXG4gICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXM/LmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB8fFxyXG4gICAgICAgIGlzQ2hlY2tlZDtcclxuICAgIGNvbnN0IFtpc1NlbGVjdGVkLCBzZXRJc1NlbGVjdGVkXSA9IFJlYWN0LnVzZVN0YXRlKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRJc1NlbGVjdGVkKGlzRGVmYXVsdENoZWNrZWQpO1xyXG4gICAgfSwgW2lzQ2hlY2tlZF0pO1xyXG4gICAgY29uc3QgaW52ZXJzZUNoZWNrID0gY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlO1xyXG4gICAgY29uc3Qgcm9sZUNoZWNrID0gY29udGV4dC5leGNsdXNpdmUgPyAncmFkaW8nIDogJ3N3aXRjaCc7XHJcbiAgICBjb25zdCBoYW5kbGVDbGljayA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LmVuZm9yY2VkICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMubGVuZ3RoID09PSAxICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZChpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIC8vIGZsaXAgdGhlIHZhbHVlIG9mIGlzU2VsZWN0ZWRcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCghaXNTZWxlY3RlZCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uQ2xpY2sgJiYgdHlwZW9mIG9uQ2xpY2sgPT09ICdmdW5jdGlvbicgJiYgb25DbGljayhldmVudCk7XHJcbiAgICAgICAgY29udGV4dC5vbkNoYW5nZSAmJlxyXG4gICAgICAgICAgICB0eXBlb2YgY29udGV4dC5vbkNoYW5nZSA9PT0gJ2Z1bmN0aW9uJyAmJlxyXG4gICAgICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgIH07XHJcbiAgICBjb25zdCBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250ZXh0LnNlbGVjdGVkVmFsdWVzLmluY2x1ZGVzKHZhbHVlLnRvU3RyaW5nKCkpKSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQodHJ1ZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGZhbHNlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgaWNvbiA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvbkljb24sIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGhhc0xhYmVsOiBjaGlsZHJlbiA/IHRydWUgOiBmYWxzZSwgaWNvbjogaWNvbiwgaWQ6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpbnZlcnNlQ2hlY2ssIG9uQ2xpY2s6IGNvbnRleHQuZXhjbHVzaXZlID8gaGFuZGxlQ2xpY2tFeGNsdXNpdmUgOiBoYW5kbGVDbGljaywgcmVmOiByZWYsIGVuZm9yY2VkOiBjb250ZXh0LmVuZm9yY2VkLCByb2xlOiByb2xlQ2hlY2ssIGlzU2VsZWN0ZWQ6IGlzU2VsZWN0ZWQsIGV4Y2x1c2l2ZTogY29udGV4dC5leGNsdXNpdmUsIHNpemU6IHByb3BzLnNpemUgfHwgY29udGV4dC5zaXplLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgY2hpbGRyZW4pKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUb2dnbGVCdXR0b25UZXh0LCB7IFwiYXJpYS1jaGVja2VkXCI6IGlzU2VsZWN0ZWQsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGRpc2FibGVkOiBkaXNhYmxlZCwgdGhlbWU6IHRoZW1lLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSwgY2hpbGRyZW4pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VG9nZ2xlQnV0dG9uLmpzLm1hcCJdfQ== */"));
29526
+ })(ToggleButtonStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkM4QyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
29491
29527
  var ToggleButton = /*#__PURE__*/forwardRef(function (props, ref) {
29492
29528
  var _context$selectedValu;
29493
29529
  var ariaLabel = props['aria-label'],