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/components/Modal/Modal.d.ts +1 -2
- package/dist/esm/index.js +86 -50
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +81 -81
- package/dist/react-magma-dom.cjs.development.js +81 -48
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
|
@@ -1905,7 +1905,7 @@ var StyledSpinner = /*#__PURE__*/_styled("span", {
|
|
|
1905
1905
|
return props.size;
|
|
1906
1906
|
}, ";width:", function (props) {
|
|
1907
1907
|
return props.size;
|
|
1908
|
-
}, ";@keyframes spinner-border{to{transform:rotate(360deg);}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1908
|
+
}, ";@keyframes spinner-border{to{transform:rotate(360deg);}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLa0MiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHN0cmluZ0luY2x1ZGVzVW5pdCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuY29uc3QgU3R5bGVkU3Bpbm5lciA9IHN0eWxlZC5zcGFuIGBcbiAgYW5pbWF0aW9uOiBzcGlubmVyLWJvcmRlciAwLjc1cyBsaW5lYXIgaW5maW5pdGU7XG4gIGJvcmRlcjogMnB4IHNvbGlkICR7cHJvcHMgPT4gcHJvcHMuY29sb3J9O1xuICBib3JkZXItcmlnaHQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnNpemV9O1xuICB3aWR0aDogJHtwcm9wcyA9PiBwcm9wcy5zaXplfTtcblxuICBAa2V5ZnJhbWVzIHNwaW5uZXItYm9yZGVyIHtcbiAgICB0byB7XG4gICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgzNjBkZWcpO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFNwaW5uZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjb2xvciwgbm9Sb2xlLCBzaXplLCB0ZXN0SWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgY29uc3Qgc2l6ZVN0cmluZyA9IHNpemVcclxuICAgICAgICA/IHR5cGVvZiBzaXplID09PSAnbnVtYmVyJyB8fFxyXG4gICAgICAgICAgICAodHlwZW9mIHNpemUgPT09ICdzdHJpbmcnICYmICFzdHJpbmdJbmNsdWRlc1VuaXQoc2l6ZSkpXHJcbiAgICAgICAgICAgID8gYCR7c2l6ZX1weGBcclxuICAgICAgICAgICAgOiBzaXplXHJcbiAgICAgICAgOiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRTcGlubmVyLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsID8gYXJpYUxhYmVsIDogaTE4bi5zcGlubmVyLmFyaWFMYWJlbCwgY29sb3I6IGNvbG9yXHJcbiAgICAgICAgICAgID8gY29sb3JcclxuICAgICAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5XHJcbiAgICAgICAgICAgICAgICA6IHRoZW1lLmNvbG9ycy5wcmltYXJ5LCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgcmVmOiByZWYsIHJvbGU6IG5vUm9sZSA/IHVuZGVmaW5lZCA6ICdpbWcnLCBcImFyaWEtaGlkZGVuXCI6IG5vUm9sZSwgc2l6ZTogc2l6ZVN0cmluZyB9KSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
|
|
1909
1909
|
var Spinner = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
1910
1910
|
var ariaLabel = props['aria-label'],
|
|
1911
1911
|
color = props.color,
|
|
@@ -1921,7 +1921,7 @@ var Spinner = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
1921
1921
|
color: color ? color : props.isInverse ? theme.colors.tertiary : theme.colors.primary,
|
|
1922
1922
|
"data-testid": testId,
|
|
1923
1923
|
ref: ref,
|
|
1924
|
-
role:
|
|
1924
|
+
role: noRole ? undefined : 'img',
|
|
1925
1925
|
"aria-hidden": noRole,
|
|
1926
1926
|
size: sizeString
|
|
1927
1927
|
}));
|
|
@@ -2316,7 +2316,7 @@ var Circle = /*#__PURE__*/_styled("circle", {
|
|
|
2316
2316
|
})( {
|
|
2317
2317
|
name: "1mlt7hr",
|
|
2318
2318
|
styles: "transition:stroke-dashoffset 0.35s",
|
|
2319
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
2319
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHNkIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIGNvbnN0IG1vdW50ZWRSZWYgPSBSZWFjdC51c2VSZWYodHJ1ZSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IHRydWU7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHByZXZQZXJjZW50YWdlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBpZiAoIW1vdW50ZWRSZWYuY3VycmVudCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHByZXZQZXJjZW50YWdlO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBpZiAocHJldlBlcmNlbnRhZ2UgPD0gMikge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIDA7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBwcmV2UGVyY2VudGFnZSAtIDI7XHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAoKSA9PiB7XHJcbiAgICAgICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IGZhbHNlO1xyXG4gICAgICAgICAgICBpZiAoaW50ZXJ2YWwpIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgIH0sIFtpc0FjdGl2ZSwgZHVyYXRpb25dKTtcclxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSYWRpdXMgPSByYWRpdXMgLSBzdHJva2VXaWR0aCAqIDI7XHJcbiAgICBjb25zdCBjaXJjdW1mZXJlbmNlID0gbm9ybWFsaXplZFJhZGl1cyAqIDIgKiBNYXRoLlBJO1xyXG4gICAgY29uc3Qgc3Ryb2tlRGFzaG9mZnNldCA9IGNpcmN1bWZlcmVuY2UgLSAocGVyY2VudGFnZSAvIDEwMCkgKiBjaXJjdW1mZXJlbmNlO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3ZnLCB7IGhlaWdodDogcmFkaXVzICogMiwgd2lkdGg6IHJhZGl1cyAqIDIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjbGUsIHsgY3g6IHJhZGl1cywgY3k6IHJhZGl1cywgZmlsbDogXCJ0cmFuc3BhcmVudFwiLCByOiBub3JtYWxpemVkUmFkaXVzLCBzdHJva2U6IGNvbG9yID8/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLCBzdHJva2VXaWR0aDogc3Ryb2tlV2lkdGgsIHN0cm9rZURhc2hhcnJheTogYCR7Y2lyY3VtZmVyZW5jZX0gJHtjaXJjdW1mZXJlbmNlfWAsIHN0cm9rZURhc2hvZmZzZXQ6IHN0cm9rZURhc2hvZmZzZXQgfSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
|
|
2320
2320
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
2321
2321
|
});
|
|
2322
2322
|
var Svg = /*#__PURE__*/_styled("svg", {
|
|
@@ -2325,7 +2325,7 @@ var Svg = /*#__PURE__*/_styled("svg", {
|
|
|
2325
2325
|
})( {
|
|
2326
2326
|
name: "126fkb5",
|
|
2327
2327
|
styles: "transform:rotate(-90deg);transform-origin:50% 50%",
|
|
2328
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
2328
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNdUIiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmNvbnN0IENpcmNsZSA9IHN0eWxlZC5jaXJjbGUgYFxuICB0cmFuc2l0aW9uOiBzdHJva2UtZGFzaG9mZnNldCAwLjM1cztcbmA7XHJcbmNvbnN0IFN2ZyA9IHN0eWxlZC5zdmcgYFxuICB0cmFuc2Zvcm06IHJvdGF0ZSgtOTBkZWcpO1xuICB0cmFuc2Zvcm0tb3JpZ2luOiA1MCUgNTAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IFByb2dyZXNzUmluZyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY29sb3IsIGR1cmF0aW9uID0gNTAwMCwgaXNBY3RpdmUsIHJhZGl1cyA9IDIxLCBzdHJva2VXaWR0aCA9IDMsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgW3BlcmNlbnRhZ2UsIHNldFBlcmNlbnRhZ2VdID0gUmVhY3QudXNlU3RhdGUoMTAwKTtcclxuICAgIGNvbnN0IG1vdW50ZWRSZWYgPSBSZWFjdC51c2VSZWYodHJ1ZSk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IHRydWU7XHJcbiAgICAgICAgY29uc3QgaW50ZXJ2YWxEdXJhdGlvbiA9IGR1cmF0aW9uIC8gNTA7XHJcbiAgICAgICAgbGV0IGludGVydmFsID0gbnVsbDtcclxuICAgICAgICBpZiAoaXNBY3RpdmUpIHtcclxuICAgICAgICAgICAgaW50ZXJ2YWwgPSBzZXRJbnRlcnZhbCgoKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQZXJjZW50YWdlKHByZXZQZXJjZW50YWdlID0+IHtcclxuICAgICAgICAgICAgICAgICAgICBpZiAoIW1vdW50ZWRSZWYuY3VycmVudCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHByZXZQZXJjZW50YWdlO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBpZiAocHJldlBlcmNlbnRhZ2UgPD0gMikge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhckludGVydmFsKGludGVydmFsKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIDA7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBwcmV2UGVyY2VudGFnZSAtIDI7XHJcbiAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgfSwgaW50ZXJ2YWxEdXJhdGlvbik7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiAoKSA9PiB7XHJcbiAgICAgICAgICAgIG1vdW50ZWRSZWYuY3VycmVudCA9IGZhbHNlO1xyXG4gICAgICAgICAgICBpZiAoaW50ZXJ2YWwpIHtcclxuICAgICAgICAgICAgICAgIGNsZWFySW50ZXJ2YWwoaW50ZXJ2YWwpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfTtcclxuICAgIH0sIFtpc0FjdGl2ZSwgZHVyYXRpb25dKTtcclxuICAgIGNvbnN0IG5vcm1hbGl6ZWRSYWRpdXMgPSByYWRpdXMgLSBzdHJva2VXaWR0aCAqIDI7XHJcbiAgICBjb25zdCBjaXJjdW1mZXJlbmNlID0gbm9ybWFsaXplZFJhZGl1cyAqIDIgKiBNYXRoLlBJO1xyXG4gICAgY29uc3Qgc3Ryb2tlRGFzaG9mZnNldCA9IGNpcmN1bWZlcmVuY2UgLSAocGVyY2VudGFnZSAvIDEwMCkgKiBjaXJjdW1mZXJlbmNlO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgcmVmOiByZWYsIFwiZGF0YS10ZXN0aWRcIjogdGVzdElkIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3ZnLCB7IGhlaWdodDogcmFkaXVzICogMiwgd2lkdGg6IHJhZGl1cyAqIDIgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjbGUsIHsgY3g6IHJhZGl1cywgY3k6IHJhZGl1cywgZmlsbDogXCJ0cmFuc3BhcmVudFwiLCByOiBub3JtYWxpemVkUmFkaXVzLCBzdHJva2U6IGNvbG9yID8/IHRoZW1lLmNvbG9ycy5uZXV0cmFsLCBzdHJva2VXaWR0aDogc3Ryb2tlV2lkdGgsIHN0cm9rZURhc2hhcnJheTogYCR7Y2lyY3VtZmVyZW5jZX0gJHtjaXJjdW1mZXJlbmNlfWAsIHN0cm9rZURhc2hvZmZzZXQ6IHN0cm9rZURhc2hvZmZzZXQgfSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
|
|
2329
2329
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
2330
2330
|
});
|
|
2331
2331
|
var ProgressRing = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
@@ -2342,23 +2342,33 @@ var ProgressRing = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
2342
2342
|
var _React$useState = React.useState(100),
|
|
2343
2343
|
percentage = _React$useState[0],
|
|
2344
2344
|
setPercentage = _React$useState[1];
|
|
2345
|
+
var mountedRef = React.useRef(true);
|
|
2345
2346
|
React.useEffect(function () {
|
|
2347
|
+
mountedRef.current = true;
|
|
2346
2348
|
var intervalDuration = duration / 50;
|
|
2347
2349
|
var interval = null;
|
|
2348
2350
|
if (isActive) {
|
|
2349
2351
|
interval = setInterval(function () {
|
|
2350
|
-
setPercentage(
|
|
2352
|
+
setPercentage(function (prevPercentage) {
|
|
2353
|
+
if (!mountedRef.current) {
|
|
2354
|
+
clearInterval(interval);
|
|
2355
|
+
return prevPercentage;
|
|
2356
|
+
}
|
|
2357
|
+
if (prevPercentage <= 2) {
|
|
2358
|
+
clearInterval(interval);
|
|
2359
|
+
return 0;
|
|
2360
|
+
}
|
|
2361
|
+
return prevPercentage - 2;
|
|
2362
|
+
});
|
|
2351
2363
|
}, intervalDuration);
|
|
2352
|
-
if (percentage <= 0) {
|
|
2353
|
-
clearInterval(interval);
|
|
2354
|
-
}
|
|
2355
|
-
} else {
|
|
2356
|
-
clearInterval(interval);
|
|
2357
2364
|
}
|
|
2358
2365
|
return function () {
|
|
2359
|
-
|
|
2366
|
+
mountedRef.current = false;
|
|
2367
|
+
if (interval) {
|
|
2368
|
+
clearInterval(interval);
|
|
2369
|
+
}
|
|
2360
2370
|
};
|
|
2361
|
-
}, [
|
|
2371
|
+
}, [isActive, duration]);
|
|
2362
2372
|
var normalizedRadius = radius - strokeWidth * 2;
|
|
2363
2373
|
var circumference = normalizedRadius * 2 * Math.PI;
|
|
2364
2374
|
var strokeDashoffset = circumference - percentage / 100 * circumference;
|
|
@@ -2374,7 +2384,7 @@ var ProgressRing = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
2374
2384
|
cy: radius,
|
|
2375
2385
|
fill: "transparent",
|
|
2376
2386
|
r: normalizedRadius,
|
|
2377
|
-
stroke: color ? color : theme.colors.neutral,
|
|
2387
|
+
stroke: color != null ? color : theme.colors.neutral,
|
|
2378
2388
|
strokeWidth: strokeWidth,
|
|
2379
2389
|
strokeDasharray: circumference + " " + circumference,
|
|
2380
2390
|
strokeDashoffset: strokeDashoffset
|
|
@@ -3759,7 +3769,7 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__$9() { return "You have tried to string
|
|
|
3759
3769
|
InputIconPosition["right"] = "right";
|
|
3760
3770
|
})(exports.InputIconPosition || (exports.InputIconPosition = {}));
|
|
3761
3771
|
var inputWrapperStyles = function inputWrapperStyles(props) {
|
|
3762
|
-
return /*#__PURE__*/react.css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? polished.transparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;}", props.hasError && /*#__PURE__*/react.css("border-color:", props.isInverse ? props.theme.colors.danger300 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + ( "/*# 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__*/react.css("border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + ( "/*# 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__*/react.css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + ( "/*# 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;" + ( "/*# 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"]} */"));
|
|
3772
|
+
return /*#__PURE__*/react.css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? polished.transparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;}", props.hasError && /*#__PURE__*/react.css("border-color:", props.isInverse ? props.theme.colors.danger300 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + ( "/*# 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__*/react.css("border-color:", props.isInverse ? polished.transparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? polished.transparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + ( "/*# 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__*/react.css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + ( "/*# 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;" + ( "/*# 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"]} */"));
|
|
3763
3773
|
};
|
|
3764
3774
|
function getInputPadding(props) {
|
|
3765
3775
|
var inputSize = props.inputSize,
|
|
@@ -3811,7 +3821,7 @@ function getInputPadding(props) {
|
|
|
3811
3821
|
return padding;
|
|
3812
3822
|
}
|
|
3813
3823
|
var inputBaseStyles = function inputBaseStyles(props) {
|
|
3814
|
-
return /*#__PURE__*/react.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__*/react.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;" + ( "/*# 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 ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/react.css("color:", props.isInverse ? polished.transparentize(0.6, props.theme.colors.neutral100) : polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + ( "/*# 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;" + ( "/*# 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"]} */"));
|
|
3824
|
+
return /*#__PURE__*/react.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__*/react.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;" + ( "/*# 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 ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/react.css("color:", props.isInverse ? polished.transparentize(0.6, props.theme.colors.neutral100) : polished.transparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + ( "/*# 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;" + ( "/*# 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"]} */"));
|
|
3815
3825
|
};
|
|
3816
3826
|
var InputContainer = /*#__PURE__*/_styled("div", {
|
|
3817
3827
|
target: "e1jxjjn77",
|
|
@@ -3819,17 +3829,17 @@ var InputContainer = /*#__PURE__*/_styled("div", {
|
|
|
3819
3829
|
})( {
|
|
3820
3830
|
name: "zjik7",
|
|
3821
3831
|
styles: "display:flex",
|
|
3822
|
-
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"]} */",
|
|
3832
|
+
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"]} */",
|
|
3823
3833
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
3824
3834
|
});
|
|
3825
3835
|
var InputWrapper = /*#__PURE__*/_styled("div", {
|
|
3826
3836
|
target: "e1jxjjn76",
|
|
3827
3837
|
label: "InputWrapper"
|
|
3828
|
-
})(inputWrapperStyles, ";" + ( "/*# 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"]} */"));
|
|
3838
|
+
})(inputWrapperStyles, ";" + ( "/*# 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"]} */"));
|
|
3829
3839
|
var StyledInput = /*#__PURE__*/_styled("input", {
|
|
3830
3840
|
target: "e1jxjjn75",
|
|
3831
3841
|
label: "StyledInput"
|
|
3832
|
-
})(inputBaseStyles, ";" + ( "/*# 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"]} */"));
|
|
3842
|
+
})(inputBaseStyles, ";" + ( "/*# 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"]} */"));
|
|
3833
3843
|
var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
3834
3844
|
target: "e1jxjjn74",
|
|
3835
3845
|
label: "IconWrapper"
|
|
@@ -3846,8 +3856,8 @@ var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
|
3846
3856
|
return props.theme.spaceScale.spacing03;
|
|
3847
3857
|
};
|
|
3848
3858
|
}, ";", function (props) {
|
|
3849
|
-
return props.inputSize === 'large' && /*#__PURE__*/react.css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"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"]} */"));
|
|
3850
|
-
}, ";" + ( "/*# 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"]} */"));
|
|
3859
|
+
return props.inputSize === 'large' && /*#__PURE__*/react.css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"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"]} */"));
|
|
3860
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
3851
3861
|
function getIconButtonSVGSize(props) {
|
|
3852
3862
|
var isClickable = props.isClickable,
|
|
3853
3863
|
iconPosition = props.iconPosition,
|
|
@@ -3937,7 +3947,7 @@ var IconButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
3937
3947
|
return getIconButtonSVGSize(props);
|
|
3938
3948
|
}, ";width:", function (props) {
|
|
3939
3949
|
return getIconButtonSVGSize(props);
|
|
3940
|
-
}, ";}" + ( "/*# 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"]} */"));
|
|
3950
|
+
}, ";}" + ( "/*# 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"]} */"));
|
|
3941
3951
|
var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
3942
3952
|
target: "e1jxjjn72",
|
|
3943
3953
|
label: "PasswordButtonContainer"
|
|
@@ -3945,7 +3955,7 @@ var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
3945
3955
|
return props.size === exports.InputSize.large ? -props.buttonWidth - 8 + "px" : -props.buttonWidth - 6 + "px";
|
|
3946
3956
|
}, ",\n ", function (props) {
|
|
3947
3957
|
return props.size === exports.InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
|
|
3948
|
-
}, "\n );" + ( "/*# 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"]} */"));
|
|
3958
|
+
}, "\n );" + ( "/*# 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"]} */"));
|
|
3949
3959
|
function getClearablePosition(props) {
|
|
3950
3960
|
if (props.iconPosition === 'right' && props.icon) {
|
|
3951
3961
|
if (props.inputSize === 'large') {
|
|
@@ -3965,7 +3975,7 @@ var IsClearableContainer = /*#__PURE__*/_styled("span", {
|
|
|
3965
3975
|
return getClearablePosition(props);
|
|
3966
3976
|
}, ",\n ", function (props) {
|
|
3967
3977
|
return props.inputSize === exports.InputSize.large ? props.theme.spaceScale.spacing03 : '7px';
|
|
3968
|
-
}, "\n );" + ( "/*# 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"]} */"));
|
|
3978
|
+
}, "\n );" + ( "/*# 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"]} */"));
|
|
3969
3979
|
function getIconSize$1(size, theme, iconPosition) {
|
|
3970
3980
|
switch (size) {
|
|
3971
3981
|
case 'large':
|
|
@@ -4006,7 +4016,7 @@ var HelpLinkContainer = /*#__PURE__*/_styled("span", {
|
|
|
4006
4016
|
return getHelpIconButtonSize(props);
|
|
4007
4017
|
}, ";}inset-inline-end:", function (props) {
|
|
4008
4018
|
return isLeftOrHidden(props) ? 'auto' : '0';
|
|
4009
|
-
}, ";" + ( "/*# 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"]} */"));
|
|
4019
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
4010
4020
|
var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
4011
4021
|
var children = props.children,
|
|
4012
4022
|
containerStyle = props.containerStyle,
|
|
@@ -4120,7 +4130,6 @@ var InputBase = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
4120
4130
|
theme: theme,
|
|
4121
4131
|
iconPosition: iconPosition,
|
|
4122
4132
|
inputSize: inputSize,
|
|
4123
|
-
onIconClick: onIconClick,
|
|
4124
4133
|
icon: icon
|
|
4125
4134
|
}, React.createElement(IconButton, {
|
|
4126
4135
|
"aria-label": i18n.input.isClearableAriaLabel,
|
|
@@ -6946,7 +6955,7 @@ var StyledFormFieldContainer$2 = /*#__PURE__*/_styled(FormFieldContainer, {
|
|
|
6946
6955
|
minHeight = _getLabelStyles.minHeight,
|
|
6947
6956
|
justifyContent = _getLabelStyles.justifyContent;
|
|
6948
6957
|
return "\n margin-block: " + marginBlock + ";\n margin-inline: " + marginInline + ";\n max-width: " + maxWidth + ";\n min-height: " + minHeight + ";\n justify-content: " + justifyContent + ";\n ";
|
|
6949
|
-
}, " display:flex;align-items:center;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6958
|
+
}, " display:flex;align-items:center;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzREIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBvbWl0LCB1c2VHZW5lcmF0ZUlkIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgZ2V0SGVscEljb25CdXR0b25TaXplLCBJbnB1dEJhc2UsIElucHV0U2l6ZSwgaXNMZWZ0T3JIaWRkZW4sIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5jb25zdCBnZXRMYWJlbFN0eWxlcyA9IChwcm9wcykgPT4ge1xyXG4gICAgY29uc3QgbWFyZ2luQmxvY2sgPSBpc0xlZnRPckhpZGRlbihwcm9wcylcclxuICAgICAgICA/ICcwJ1xyXG4gICAgICAgIDogYDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gO1xyXG4gICAgY29uc3QgbWFyZ2luSW5saW5lID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyBgMCAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfWBcclxuICAgICAgICA6ICcwJztcclxuICAgIGNvbnN0IG1heFdpZHRoID0gaXNMZWZ0T3JIaWRkZW4ocHJvcHMpXHJcbiAgICAgICAgPyAnYXV0bydcclxuICAgICAgICA6IGBjYWxjKDEwMCUgLSAke2dldEhlbHBJY29uQnV0dG9uU2l6ZShwcm9wcyl9IC0gJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30pYDtcclxuICAgIGxldCBtaW5IZWlnaHQ7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgbWluSGVpZ2h0ID1cclxuICAgICAgICAgICAgcHJvcHMuSW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgICAgICAgICAgICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMTFcclxuICAgICAgICAgICAgICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICBtaW5IZWlnaHQgPSAnYXV0byc7XHJcbiAgICB9XHJcbiAgICBjb25zdCBqdXN0aWZ5Q29udGVudCA9IGlzTGVmdE9ySGlkZGVuKHByb3BzKSA/ICdlbmQnIDogJ3N0YXJ0JztcclxuICAgIHJldHVybiB7IG1hcmdpbkJsb2NrLCBtYXJnaW5JbmxpbmUsIG1heFdpZHRoLCBtaW5IZWlnaHQsIGp1c3RpZnlDb250ZW50IH07XHJcbn07XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBhbGlnbi1pdGVtczogc3RhcnQ7XG5cbiAgbGFiZWwge1xuICAgICR7cHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBtYXJnaW5CbG9jaywgbWFyZ2luSW5saW5lLCBtYXhXaWR0aCwgbWluSGVpZ2h0LCBqdXN0aWZ5Q29udGVudCB9ID0gZ2V0TGFiZWxTdHlsZXMocHJvcHMpO1xyXG4gICAgcmV0dXJuIGBcbiAgICAgICAgbWFyZ2luLWJsb2NrOiAke21hcmdpbkJsb2NrfTtcbiAgICAgICAgbWFyZ2luLWlubGluZTogJHttYXJnaW5JbmxpbmV9O1xuICAgICAgICBtYXgtd2lkdGg6ICR7bWF4V2lkdGh9O1xuICAgICAgICBtaW4taGVpZ2h0OiAke21pbkhlaWdodH07XG4gICAgICAgIGp1c3RpZnktY29udGVudDogJHtqdXN0aWZ5Q29udGVudH07XG4gICAgICBgO1xyXG59fVxuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZSwgaGFzQ2hhcmFjdGVyQ291bnRlciA9IHRydWUsIGhlbHBlck1lc3NhZ2UsIGljb25Qb3NpdGlvbiwgaWQ6IGRlZmF1bHRJZCwgaW5wdXRTaXplID0gSW5wdXRTaXplLm1lZGl1bSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1heENvdW50LCBtYXhMZW5ndGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCB2YWx1ZSwgc2V0UmVmZXJlbmNlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGRlc2NyaXB0aW9uSWQgPSBlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSB8fCBtYXhDb3VudCB8fCBtYXhMZW5ndGhcclxuICAgICAgICA/IGAke2lkfV9fZGVzY2BcclxuICAgICAgICA6IG51bGw7XHJcbiAgICBjb25zdCBtYXhDaGFyYWN0ZXJzID0gdHlwZW9mIG1heENvdW50ID09PSAnbnVtYmVyJyA/IG1heENvdW50IDogbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgbWF4TGVuZ3RoTnVtID0gIWhhc0NoYXJhY3RlckNvdW50ZXIgJiYgbWF4TGVuZ3RoID8gbWF4TGVuZ3RoIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaXNJbnZlcnNlID0gdXNlSXNJbnZlcnNlKHByb3BzLmlzSW52ZXJzZSk7XHJcbiAgICBjb25zdCBbY2hhcmFjdGVyTGVuZ3RoLCBzZXRDaGFyYWN0ZXJMZW5ndGhdID0gdXNlU3RhdGUodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgodmFsdWU/LnRvU3RyaW5nKCkubGVuZ3RoKTtcclxuICAgIH0sIFt2YWx1ZV0pO1xyXG4gICAgZnVuY3Rpb24gaGFuZGxlQ2hhbmdlKGV2ZW50KSB7XHJcbiAgICAgICAgcHJvcHMub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIHByb3BzLm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIHByb3BzLm9uQ2hhbmdlKGV2ZW50KTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoZXZlbnQudGFyZ2V0LnZhbHVlLmxlbmd0aCk7XHJcbiAgICB9XHJcbiAgICBmdW5jdGlvbiBoYW5kbGVDbGVhcigpIHtcclxuICAgICAgICBwcm9wcy5vbkNsZWFyICYmIHR5cGVvZiBwcm9wcy5vbkNsZWFyID09PSAnZnVuY3Rpb24nICYmIHByb3BzLm9uQ2xlYXIoKTtcclxuICAgICAgICBzZXRDaGFyYWN0ZXJMZW5ndGgoMCk7XHJcbiAgICB9XHJcbiAgICBjb25zdCB2YWxpZElucHV0QmFzZVByb3BzID0gb21pdChbXHJcbiAgICAgICAgJ29uRGF0ZUNoYW5nZScsXHJcbiAgICAgICAgJ29uSW5wdXRDaGFuZ2UnLFxyXG4gICAgICAgICdvbklucHV0Qmx1cicsXHJcbiAgICAgICAgJ29uSW5wdXRGb2N1cycsXHJcbiAgICAgICAgJ29uQ2xlYXInLFxyXG4gICAgXSwgb3RoZXIpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgeyBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZTogZXJyb3JNZXNzYWdlLCBmaWVsZElkOiBpZCwgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGlzTGFiZWxWaXN1YWxseUhpZGRlbjogaXNMYWJlbFZpc3VhbGx5SGlkZGVuLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaW5wdXRTaXplOiBpbnB1dFNpemUsIGlucHV0TGVuZ3RoOiBjaGFyYWN0ZXJMZW5ndGgsIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGU6IGxhYmVsU3R5bGUsIGxhYmVsVGV4dDogbGFiZWxUZXh0LCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBtYXhMZW5ndGg6IG1heExlbmd0aCwgbWF4Q291bnQ6IG1heENvdW50LCBtZXNzYWdlU3R5bGU6IG1lc3NhZ2VTdHlsZSwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1mb3JtRmllbGRDb250YWluZXJgLCB0aGVtZTogdGhlbWUsIElucHV0U2l6ZTogaW5wdXRTaXplIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dEJhc2UsIE9iamVjdC5hc3NpZ24oe30sIHZhbGlkSW5wdXRCYXNlUHJvcHMsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGRlc2NyaXB0aW9uSWQgPyBkZXNjcmlwdGlvbklkIDogcHJvcHNbJ2FyaWEtZGVzY3JpYmVkYnknXSwgXCJhcmlhLWludmFsaWRcIjogISFlcnJvck1lc3NhZ2UsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSB8fFxyXG4gICAgICAgICAgICAgICAgKGhhc0NoYXJhY3RlckNvdW50ZXIgJiYgY2hhcmFjdGVyTGVuZ3RoID4gbWF4Q2hhcmFjdGVycyksIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uLCBpZDogaWQsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBpbnB1dExlbmd0aDogY2hhcmFjdGVyTGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4TGVuZ3RoOiBtYXhMZW5ndGhOdW0sIG9uQ2hhbmdlOiBoYW5kbGVDaGFuZ2UsIG9uQ2xlYXI6IGhhbmRsZUNsZWFyLCBvbkRhdGVDaGFuZ2U6IHByb3BzLm9uRGF0ZUNoYW5nZSwgcmVmOiByZWYsIHNldFJlZmVyZW5jZTogc2V0UmVmZXJlbmNlLCB0ZXN0SWQ6IHRlc3RJZCwgdmFsdWU6IHZhbHVlLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW46IGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiB9KSwgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
|
|
6950
6959
|
var Input = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
6951
6960
|
var children = props.children,
|
|
6952
6961
|
containerStyle = props.containerStyle,
|
|
@@ -6990,6 +6999,7 @@ var Input = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
6990
6999
|
props.onClear && typeof props.onClear === 'function' && props.onClear();
|
|
6991
7000
|
setCharacterLength(0);
|
|
6992
7001
|
}
|
|
7002
|
+
var validInputBaseProps = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus', 'onClear'], other);
|
|
6993
7003
|
return React.createElement(StyledFormFieldContainer$2, {
|
|
6994
7004
|
containerStyle: containerStyle,
|
|
6995
7005
|
errorMessage: errorMessage,
|
|
@@ -7011,8 +7021,8 @@ var Input = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
7011
7021
|
testId: testId && testId + "-formFieldContainer",
|
|
7012
7022
|
theme: theme,
|
|
7013
7023
|
InputSize: inputSize
|
|
7014
|
-
}, React.createElement(InputBase, Object.assign({},
|
|
7015
|
-
"aria-describedby": descriptionId
|
|
7024
|
+
}, React.createElement(InputBase, Object.assign({}, validInputBaseProps, {
|
|
7025
|
+
"aria-describedby": descriptionId ? descriptionId : props['aria-describedby'],
|
|
7016
7026
|
"aria-invalid": !!errorMessage,
|
|
7017
7027
|
hasError: !!errorMessage || hasCharacterCounter && characterLength > maxCharacters,
|
|
7018
7028
|
iconPosition: iconPosition,
|
|
@@ -10232,7 +10242,7 @@ function instanceOfNavChildrenTab(object) {
|
|
|
10232
10242
|
var StyledTab$1 = /*#__PURE__*/_styled("a", {
|
|
10233
10243
|
target: "e1p8nst20",
|
|
10234
10244
|
label: "StyledTab"
|
|
10235
|
-
})(TabStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdlRhYi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6Ik5hdlRhYi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBOYXZUYWJzQ29udGV4dCB9IGZyb20gJy4vTmF2VGFicyc7XHJcbmltcG9ydCB7IFN0eWxlZFRhYnNDaGlsZCwgU3R5bGVkSWNvbiwgVGFiU3R5bGVzLCBUYWJzSWNvblBvc2l0aW9uLCB9IGZyb20gJy4uL1RhYnMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBvbWl0LCByZXNvbHZlUHJvcHMsIHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNvbXBvbmVudFRhYihvYmplY3QpIHtcclxuICAgIHJldHVybiAnY29tcG9uZW50JyBpbiBvYmplY3QgJiYgISgnY2hpbGRyZW4nIGluIG9iamVjdCk7XHJcbn1cclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKG9iamVjdCkge1xyXG4gICAgcmV0dXJuICEoJ2NvbXBvbmVudCcgaW4gb2JqZWN0KSAmJiAnY2hpbGRyZW4nIGluIG9iamVjdDtcclxufVxyXG5jb25zdCBTdHlsZWRUYWIgPSBzdHlsZWQuYSBgXG4gICR7VGFiU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IFN0eWxlZEN1c3RvbVRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+
|
|
10245
|
+
})(TabStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdlRhYi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYTJCIiwiZmlsZSI6Ik5hdlRhYi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgeyBOYXZUYWJzQ29udGV4dCB9IGZyb20gJy4vTmF2VGFicyc7XHJcbmltcG9ydCB7IFN0eWxlZFRhYnNDaGlsZCwgU3R5bGVkSWNvbiwgVGFiU3R5bGVzLCBUYWJzSWNvblBvc2l0aW9uLCB9IGZyb20gJy4uL1RhYnMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBvbWl0LCByZXNvbHZlUHJvcHMsIHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNvbXBvbmVudFRhYihvYmplY3QpIHtcclxuICAgIHJldHVybiAnY29tcG9uZW50JyBpbiBvYmplY3QgJiYgISgnY2hpbGRyZW4nIGluIG9iamVjdCk7XHJcbn1cclxuZnVuY3Rpb24gaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKG9iamVjdCkge1xyXG4gICAgcmV0dXJuICEoJ2NvbXBvbmVudCcgaW4gb2JqZWN0KSAmJiAnY2hpbGRyZW4nIGluIG9iamVjdDtcclxufVxyXG5jb25zdCBTdHlsZWRUYWIgPSBzdHlsZWQuYSBgXG4gICR7VGFiU3R5bGVzfVxuYDtcclxuZXhwb3J0IGNvbnN0IFN0eWxlZEN1c3RvbVRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgY2hpbGRyZW4sIGNvbXBvbmVudCwgaWNvbiwgc3R5bGUsIG9uQ2xpY2ssIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgaWYgKFJlYWN0LmlzVmFsaWRFbGVtZW50KGNvbXBvbmVudCkgJiYgUmVhY3QuaXNWYWxpZEVsZW1lbnQoY29tcG9uZW50KSkge1xyXG4gICAgICAgIGNvbnN0IGNsb25lRWxlbWVudCA9IChlbGVtZW50LCBuZXdQcm9wcykgPT4ge1xyXG4gICAgICAgICAgICByZXR1cm4ganN4KGVsZW1lbnQudHlwZSwge1xyXG4gICAgICAgICAgICAgICAga2V5OiBlbGVtZW50LmtleSxcclxuICAgICAgICAgICAgICAgIHJlZjogZWxlbWVudC5yZWYsXHJcbiAgICAgICAgICAgICAgICAuLi5lbGVtZW50LnByb3BzLFxyXG4gICAgICAgICAgICAgICAgLi4ubmV3UHJvcHMsXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH07XHJcbiAgICAgICAgY29uc3Qgb3RoZXIgPSBvbWl0KFsnaWNvblBvc2l0aW9uJywgJ2lzSW52ZXJzZScsICdpc0FjdGl2ZScsICdpc0Z1bGxXaWR0aCcsICdib3JkZXJQb3NpdGlvbicsICdvcmllbnRhdGlvbicsICd0ZXh0VHJhbnNmb3JtJ10sIHJlc3QpO1xyXG4gICAgICAgIHJldHVybiBjbG9uZUVsZW1lbnQoY29tcG9uZW50LCB7XHJcbiAgICAgICAgICAgIC4uLm90aGVyLFxyXG4gICAgICAgICAgICBjc3M6IFRhYlN0eWxlcyhwcm9wcyksXHJcbiAgICAgICAgICAgIC4uLnN0eWxlLFxyXG4gICAgICAgICAgICBvbkNsaWNrLFxyXG4gICAgICAgICAgICByZWYsXHJcbiAgICAgICAgICAgIGNoaWxkcmVuOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgICAgIGljb24sXHJcbiAgICAgICAgICAgICAgICBjb21wb25lbnQucHJvcHMuY2hpbGRyZW4pKSxcclxuICAgICAgICB9KTtcclxuICAgIH1cclxufSk7XHJcbi8vIFVzaW5nIGFueSB0eXBlIGJlY2F1c2Ugd2UgZG8gbm90IGtub3cgdGhlIGVsZW1lbnQgdHlwZSBvZiBhIGN1c3RvbSB0YWJcclxuZXhwb3J0IGNvbnN0IE5hdlRhYiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCBmb3J3YXJkUmVmKSA9PiB7XHJcbiAgICBsZXQgY2hpbGRyZW47XHJcbiAgICBsZXQgY29tcG9uZW50O1xyXG4gICAgY29uc3QgY29udGV4dFByb3BzID0gUmVhY3QudXNlQ29udGV4dChOYXZUYWJzQ29udGV4dCk7XHJcbiAgICBjb25zdCByZXNvbHZlZFByb3BzID0gcmVzb2x2ZVByb3BzKGNvbnRleHRQcm9wcywgcHJvcHMpO1xyXG4gICAgY29uc3QgeyBpc0FjdGl2ZSwgaWNvbiwgaXNGb2N1c2VkLCB0ZXN0SWQsIHRvLCAuLi5vdGhlciB9ID0gcmVzb2x2ZWRQcm9wcztcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgaWYgKGluc3RhbmNlT2ZOYXZDb21wb25lbnRUYWIocHJvcHMpKSB7XHJcbiAgICAgICAgY29tcG9uZW50ID0gcHJvcHMuY29tcG9uZW50O1xyXG4gICAgfVxyXG4gICAgZWxzZSBpZiAoaW5zdGFuY2VPZk5hdkNoaWxkcmVuVGFiKHByb3BzKSkge1xyXG4gICAgICAgIGNoaWxkcmVuID0gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICBjb25zdCBpc0ljb25Pbmx5ID0gIWNoaWxkcmVuO1xyXG4gICAgY29uc3QgeyBvcmllbnRhdGlvbiwgYm9yZGVyUG9zaXRpb24sIGljb25Qb3NpdGlvbiwgaXNJbnZlcnNlLCBpc0Z1bGxXaWR0aCwgdGV4dFRyYW5zZm9ybSwgfSA9IHJlc29sdmVkUHJvcHM7XHJcbiAgICBjb25zdCB0YWJJY29uUG9zaXRpb24gPSBpY29uUG9zaXRpb25cclxuICAgICAgICA/IGljb25Qb3NpdGlvblxyXG4gICAgICAgIDogb3JpZW50YXRpb24gPT09ICd2ZXJ0aWNhbCdcclxuICAgICAgICAgICAgPyBUYWJzSWNvblBvc2l0aW9uLmxlZnRcclxuICAgICAgICAgICAgOiBUYWJzSWNvblBvc2l0aW9uLnRvcDtcclxuICAgIGNvbnN0IHN0eWxlZFRhYlJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRSZWYsIHN0eWxlZFRhYlJlZik7XHJcbiAgICAvLyBTZXRzIGZvY3VzIG9uIE5hdlRhYiBmb3IgYWNjZXNzaWJpbGl0eVxyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoaXNGb2N1c2VkKSB7XHJcbiAgICAgICAgICAgIHN0eWxlZFRhYlJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWJzQ2hpbGQsIHsgYm9yZGVyUG9zaXRpb246IGJvcmRlclBvc2l0aW9uLCBcImRhdGEtdGVzdGlkXCI6IFwidGFiQ29udGFpbmVyXCIsIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNGdWxsV2lkdGg6IGlzRnVsbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgb3JpZW50YXRpb246IG9yaWVudGF0aW9uLCB0aGVtZTogdGhlbWUgfSwgY29tcG9uZW50ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ3VzdG9tVGFiLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtY3VycmVudFwiOiBpc0FjdGl2ZSA/ICdwYWdlJyA6IGZhbHNlLCBjb21wb25lbnQ6IGNvbXBvbmVudCwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGljb25Qb3NpdGlvbjogdGFiSWNvblBvc2l0aW9uLCBpY29uOiBpY29uICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEljb24sIHsgdGhlbWU6IHRoZW1lLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiB9LCBpY29uKSksIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlzRnVsbFdpZHRoOiBpc0Z1bGxXaWR0aCwgb3JpZW50YXRpb246IG9yaWVudGF0aW9uLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRUYWIsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1jdXJyZW50XCI6IGlzQWN0aXZlID8gJ3BhZ2UnIDogZmFsc2UsIHJlZjogcmVmLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaHJlZjogdG8sIGlzQWN0aXZlOiBpc0FjdGl2ZSwgaXNGdWxsV2lkdGg6IGlzRnVsbFdpZHRoLCBpY29uUG9zaXRpb246IHRhYkljb25Qb3NpdGlvbiwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG9yaWVudGF0aW9uOiBvcmllbnRhdGlvbiwgdGV4dFRyYW5zZm9ybTogdGV4dFRyYW5zZm9ybSwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgIGljb24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSWNvbiwgeyB0aGVtZTogdGhlbWUsIGljb25Qb3NpdGlvbjogdGFiSWNvblBvc2l0aW9uLCBpc0ljb25Pbmx5OiBpc0ljb25Pbmx5IH0sIGljb24pKSxcclxuICAgICAgICBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1OYXZUYWIuanMubWFwIl19 */"));
|
|
10236
10246
|
var StyledCustomTab = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
10237
10247
|
var component = props.component,
|
|
10238
10248
|
icon = props.icon,
|
|
@@ -10246,7 +10256,7 @@ var StyledCustomTab = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
10246
10256
|
ref: element.ref
|
|
10247
10257
|
}, element.props, newProps));
|
|
10248
10258
|
};
|
|
10249
|
-
var other = omit(['iconPosition', 'isInverse', 'isActive', 'isFullWidth'], rest);
|
|
10259
|
+
var other = omit(['iconPosition', 'isInverse', 'isActive', 'isFullWidth', 'borderPosition', 'orientation', 'textTransform'], rest);
|
|
10250
10260
|
return cloneElement(component, _extends({}, other, {
|
|
10251
10261
|
css: TabStyles(props)
|
|
10252
10262
|
}, style, {
|
|
@@ -13414,7 +13424,7 @@ function buildStepSvgColors(props) {
|
|
|
13414
13424
|
var HiddenLabelText$2 = /*#__PURE__*/_styled("span", {
|
|
13415
13425
|
target: "e1vnah7r5",
|
|
13416
13426
|
label: "HiddenLabelText"
|
|
13417
|
-
})(HiddenStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13427
|
+
})(HiddenStyles, ";" + ( "/*# 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"]} */"));
|
|
13418
13428
|
var StyledStep = /*#__PURE__*/_styled("div", {
|
|
13419
13429
|
target: "e1vnah7r4",
|
|
13420
13430
|
label: "StyledStep"
|
|
@@ -13426,7 +13436,7 @@ var StyledStep = /*#__PURE__*/_styled("div", {
|
|
|
13426
13436
|
return !props.isVerticalOrientation && 'center';
|
|
13427
13437
|
}, ";&:last-child>span{margin-bottom:", function (props) {
|
|
13428
13438
|
return props.isVerticalOrientation && 0;
|
|
13429
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13439
|
+
}, ";}" + ( "/*# 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"]} */"));
|
|
13430
13440
|
var StyledStepIndicator = /*#__PURE__*/_styled("span", {
|
|
13431
13441
|
target: "e1vnah7r3",
|
|
13432
13442
|
label: "StyledStepIndicator"
|
|
@@ -13436,13 +13446,13 @@ var StyledStepIndicator = /*#__PURE__*/_styled("span", {
|
|
|
13436
13446
|
return props.theme.iconSizes.xSmall;
|
|
13437
13447
|
}, "px;height:", function (props) {
|
|
13438
13448
|
return props.theme.iconSizes.xSmall;
|
|
13439
|
-
}, "px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13449
|
+
}, "px;}" + ( "/*# 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"]} */"));
|
|
13440
13450
|
var StyledStepTextWrapper = /*#__PURE__*/_styled("span", {
|
|
13441
13451
|
target: "e1vnah7r2",
|
|
13442
13452
|
label: "StyledStepTextWrapper"
|
|
13443
13453
|
})("flex:1;display:flex;align-self:center;flex-direction:column;position:relative;margin:", function (props) {
|
|
13444
13454
|
return props.isVerticalOrientation ? '2px 0 24px 8px' : '6px 8px 0';
|
|
13445
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13455
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
13446
13456
|
var StyledLabel$2 = /*#__PURE__*/_styled("span", {
|
|
13447
13457
|
target: "e1vnah7r1",
|
|
13448
13458
|
label: "StyledLabel"
|
|
@@ -13452,7 +13462,7 @@ var StyledLabel$2 = /*#__PURE__*/_styled("span", {
|
|
|
13452
13462
|
return props.theme.typographyVisualStyles.bodySmall.desktop.letterSpacing;
|
|
13453
13463
|
}, ";line-height:", function (props) {
|
|
13454
13464
|
return props.theme.typographyVisualStyles.bodySmall.desktop.lineHeight;
|
|
13455
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13465
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
13456
13466
|
var StyledSecondaryLabel = /*#__PURE__*/_styled("span", {
|
|
13457
13467
|
target: "e1vnah7r0",
|
|
13458
13468
|
label: "StyledSecondaryLabel"
|
|
@@ -13464,7 +13474,7 @@ var StyledSecondaryLabel = /*#__PURE__*/_styled("span", {
|
|
|
13464
13474
|
return props.theme.typographyVisualStyles.bodyXSmall.desktop.lineHeight;
|
|
13465
13475
|
}, ";margin:", function (props) {
|
|
13466
13476
|
return props.isVerticalOrientation ? '2px 0 0' : '2px 12px 0 12px';
|
|
13467
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13477
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
13468
13478
|
var Step = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
13469
13479
|
var hasError = props.hasError,
|
|
13470
13480
|
label = props.label,
|
|
@@ -13491,7 +13501,7 @@ var Step = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13491
13501
|
theme: theme
|
|
13492
13502
|
}, stepStatus === StepStatus.completed && !hasError && React.createElement(reactMagmaIcons.CheckIcon, {
|
|
13493
13503
|
"aria-hidden": "true"
|
|
13494
|
-
}), hasError && React.createElement(reactMagmaIcons.
|
|
13504
|
+
}), hasError && React.createElement(reactMagmaIcons.CloseIcon, {
|
|
13495
13505
|
"aria-hidden": "true"
|
|
13496
13506
|
})), React.createElement(StyledStepTextWrapper, {
|
|
13497
13507
|
isVerticalOrientation: isVerticalOrientation
|
|
@@ -13844,11 +13854,11 @@ var ToastWrapper = /*#__PURE__*/_styled("div", {
|
|
|
13844
13854
|
return 0 - props.bottomOffsetForContainer;
|
|
13845
13855
|
}, "px);transition:bottom 0.3s;z-index:999;@media (max-width: 600px){bottom:", function (props) {
|
|
13846
13856
|
return props.bottomOffsetForToast + 10;
|
|
13847
|
-
}, "px;left:10px;right:10px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13857
|
+
}, "px;left:10px;right:10px;}" + ( "/*# 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"]} */"));
|
|
13848
13858
|
var DEFAULT_TOAST_DURATION = 5000;
|
|
13849
13859
|
var TOAST_HEIGHT = 65;
|
|
13850
13860
|
var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
13851
|
-
var timerAutoHide = React.useRef();
|
|
13861
|
+
var timerAutoHide = React.useRef(null);
|
|
13852
13862
|
var _React$useState = React.useState(false),
|
|
13853
13863
|
isDismissed = _React$useState[0],
|
|
13854
13864
|
setIsDismissed = _React$useState[1];
|
|
@@ -13858,6 +13868,7 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13858
13868
|
var _React$useState3 = React.useState(),
|
|
13859
13869
|
timerTimeRemaining = _React$useState3[0],
|
|
13860
13870
|
setTimerTimeRemaining = _React$useState3[1];
|
|
13871
|
+
var mountedRef = React.useRef(true);
|
|
13861
13872
|
var alertStyle = props.alertStyle,
|
|
13862
13873
|
defaultId = props.id,
|
|
13863
13874
|
testId = props.testId,
|
|
@@ -13875,6 +13886,7 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13875
13886
|
var timerStartTime = Date.now();
|
|
13876
13887
|
var containerElement = React.useRef();
|
|
13877
13888
|
function dismissToast() {
|
|
13889
|
+
if (!mountedRef.current) return;
|
|
13878
13890
|
setIsDismissed(true);
|
|
13879
13891
|
setTimeout(function () {
|
|
13880
13892
|
if (toastsArray.current) {
|
|
@@ -13898,7 +13910,9 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13898
13910
|
clearTimeout(timerAutoHide.current);
|
|
13899
13911
|
var totalDuration = duration + transitionDuration;
|
|
13900
13912
|
timerAutoHide.current = setTimeout(function () {
|
|
13901
|
-
|
|
13913
|
+
if (mountedRef.current) {
|
|
13914
|
+
dismissToast();
|
|
13915
|
+
}
|
|
13902
13916
|
}, totalDuration);
|
|
13903
13917
|
}
|
|
13904
13918
|
function handlePause() {
|
|
@@ -13937,15 +13951,22 @@ var Toast = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
13937
13951
|
}
|
|
13938
13952
|
return function () {
|
|
13939
13953
|
clearTimeout(timerAutoHide.current);
|
|
13954
|
+
mountedRef.current = false;
|
|
13940
13955
|
};
|
|
13941
|
-
}, []);
|
|
13956
|
+
}, [props.disableAutoDismiss, props.toastDuration]);
|
|
13942
13957
|
React.useEffect(function () {
|
|
13943
|
-
if (!disableAutoDismiss) {
|
|
13958
|
+
if (!props.disableAutoDismiss) {
|
|
13944
13959
|
var focusableElements = getTrapElements(containerElement);
|
|
13945
13960
|
focusableElements.forEach(function (element) {
|
|
13946
13961
|
element.addEventListener('focus', handlePause);
|
|
13947
13962
|
element.addEventListener('blur', handleResume);
|
|
13948
13963
|
});
|
|
13964
|
+
return function () {
|
|
13965
|
+
focusableElements.forEach(function (element) {
|
|
13966
|
+
element.removeEventListener('focus', handlePause);
|
|
13967
|
+
element.removeEventListener('blur', handleResume);
|
|
13968
|
+
});
|
|
13969
|
+
};
|
|
13949
13970
|
}
|
|
13950
13971
|
}, []);
|
|
13951
13972
|
React.useEffect(function () {
|
|
@@ -14577,15 +14598,27 @@ var TimePicker = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
14577
14598
|
}));
|
|
14578
14599
|
});
|
|
14579
14600
|
|
|
14601
|
+
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)."; }
|
|
14602
|
+
var _ref$6 = {
|
|
14603
|
+
name: "1vymn85-getGlobalImports",
|
|
14604
|
+
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;",
|
|
14605
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWwsIGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vVGhlbWVDb250ZXh0JztcclxuZnVuY3Rpb24gZ2V0R2xvYmFsSW1wb3J0cygpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgIEBpbXBvcnQgdXJsKCdodHRwczovL2ZvbnRzLmdvb2dsZWFwaXMuY29tL2NzczI/ZmFtaWx5PU5vdG8rU2VyaWY6aXRhbCx3Z2h0QDAsMTAwLi45MDA7MSwxMDAuLjkwMCZmYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMC4uOTAwOzEsMTAwLi45MDAmZGlzcGxheT1zd2FwJyk7XG4gIGA7XHJcbn1cclxuZnVuY3Rpb24gZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogLTFweDtcbiAgICB9XG5cbiAgICBodG1sIHtcbiAgICAgIC1tcy10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgLXdlYmtpdC10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgZm9udC1zaXplOiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICAgIHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuICAgIH1cblxuICAgIGh0bWwsXG4gICAgYm9keSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2lzSW52ZXJzZVxyXG4gICAgICAgID8gdGhlbWUuY29sb3JzLnByaW1hcnk2MDBcclxuICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwIDogdGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICAgICAgbWFyZ2luOiAwO1xuICAgICAgcGFkZGluZzogMDtcbiAgICB9XG5cbiAgICBib2R5IHtcbiAgICAgIGZvbnQtZmFtaWx5OiAke3RoZW1lLmJvZHlGb250fTtcbiAgICAgIGZvbnQtc3R5bGU6IG5vcm1hbDtcbiAgICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgIH1cblxuICAgIGEge1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5IDogdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG5cbiAgICAgICY6aG92ZXIsXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB9XG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICAgJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlIDogdGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBidXR0b24sXG4gICAgaW5wdXQsXG4gICAgb3B0Z3JvdXAsXG4gICAgc2VsZWN0LFxuICAgIHRleHRhcmVhIHtcbiAgICAgIGZvbnQ6IGluaGVyaXQ7XG4gICAgICBtYXJnaW46IDA7XG4gICAgfVxuXG4gICAgc3ZnOm5vdCg6cm9vdCkge1xuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICB9XG4gIGA7XHJcbn1cclxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IHtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRoZW1lQ29udGV4dC5Db25zdW1lciwgbnVsbCwgdGhlbWUgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRHbG9iYWxJbXBvcnRzKCkgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */",
|
|
14606
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$A
|
|
14607
|
+
};
|
|
14608
|
+
function getGlobalImports() {
|
|
14609
|
+
return _ref$6;
|
|
14610
|
+
}
|
|
14580
14611
|
function getStyles(theme, isInverse) {
|
|
14581
|
-
return /*#__PURE__*/react.css("
|
|
14612
|
+
return /*#__PURE__*/react.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;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVZSIsImZpbGUiOiJpbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHbG9iYWwsIGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vVGhlbWVDb250ZXh0JztcclxuZnVuY3Rpb24gZ2V0R2xvYmFsSW1wb3J0cygpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgIEBpbXBvcnQgdXJsKCdodHRwczovL2ZvbnRzLmdvb2dsZWFwaXMuY29tL2NzczI/ZmFtaWx5PU5vdG8rU2VyaWY6aXRhbCx3Z2h0QDAsMTAwLi45MDA7MSwxMDAuLjkwMCZmYW1pbHk9V29yaytTYW5zOml0YWwsd2dodEAwLDEwMC4uOTAwOzEsMTAwLi45MDAmZGlzcGxheT1zd2FwJyk7XG4gIGA7XHJcbn1cclxuZnVuY3Rpb24gZ2V0U3R5bGVzKHRoZW1lLCBpc0ludmVyc2UpIHtcclxuICAgIHJldHVybiBjc3MgYFxuICAgICosXG4gICAgKjpiZWZvcmUsXG4gICAgKjphZnRlciB7XG4gICAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICAgIH1cblxuICAgICo6Zm9jdXMge1xuICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZSA6IHRoZW1lLmNvbG9ycy5mb2N1c307XG4gICAgICBvdXRsaW5lLW9mZnNldDogLTFweDtcbiAgICB9XG5cbiAgICBodG1sIHtcbiAgICAgIC1tcy10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgLXdlYmtpdC10ZXh0LXNpemUtYWRqdXN0OiAxMDAlO1xuICAgICAgZm9udC1zaXplOiAke3RoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICAgICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgICAgIHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuICAgIH1cblxuICAgIGh0bWwsXG4gICAgYm9keSB7XG4gICAgICBiYWNrZ3JvdW5kOiAke2lzSW52ZXJzZVxyXG4gICAgICAgID8gdGhlbWUuY29sb3JzLnByaW1hcnk2MDBcclxuICAgICAgICA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgICAgIGNvbG9yOiAke2lzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwIDogdGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICAgICAgbWFyZ2luOiAwO1xuICAgICAgcGFkZGluZzogMDtcbiAgICB9XG5cbiAgICBib2R5IHtcbiAgICAgIGZvbnQtZmFtaWx5OiAke3RoZW1lLmJvZHlGb250fTtcbiAgICAgIGZvbnQtc3R5bGU6IG5vcm1hbDtcbiAgICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgICBmb250LXNpemU6ICR7dGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gICAgICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICAgIH1cblxuICAgIGEge1xuICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLnRlcnRpYXJ5IDogdGhlbWUuY29sb3JzLnByaW1hcnl9O1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiB1bmRlcmxpbmU7XG5cbiAgICAgICY6aG92ZXIsXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgY29sb3I6ICR7aXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLm5ldXRyYWwxMDAgOiB0aGVtZS5jb2xvcnMucHJpbWFyeTcwMH07XG4gICAgICB9XG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgb3V0bGluZTogMnB4IHNvbGlkXG4gICAgICAgICAgJHtpc0ludmVyc2UgPyB0aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlIDogdGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBidXR0b24sXG4gICAgaW5wdXQsXG4gICAgb3B0Z3JvdXAsXG4gICAgc2VsZWN0LFxuICAgIHRleHRhcmVhIHtcbiAgICAgIGZvbnQ6IGluaGVyaXQ7XG4gICAgICBtYXJnaW46IDA7XG4gICAgfVxuXG4gICAgc3ZnOm5vdCg6cm9vdCkge1xuICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgICB9XG4gIGA7XHJcbn1cclxuZXhwb3J0IGNvbnN0IEdsb2JhbFN0eWxlcyA9ICgpID0+IHtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZSgpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRoZW1lQ29udGV4dC5Db25zdW1lciwgbnVsbCwgdGhlbWUgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRHbG9iYWxJbXBvcnRzKCkgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHbG9iYWwsIHsgc3R5bGVzOiBnZXRTdHlsZXModGhlbWUsIGlzSW52ZXJzZSkgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
|
|
14582
14613
|
}
|
|
14583
14614
|
var GlobalStyles = function GlobalStyles() {
|
|
14584
14615
|
var isInverse = useIsInverse();
|
|
14585
14616
|
return React.createElement(ThemeContext.Consumer, null, function (theme) {
|
|
14586
|
-
return React.createElement(react.Global, {
|
|
14617
|
+
return React.createElement(React.Fragment, null, React.createElement(react.Global, {
|
|
14618
|
+
styles: getGlobalImports()
|
|
14619
|
+
}), React.createElement(react.Global, {
|
|
14587
14620
|
styles: getStyles(theme, isInverse)
|
|
14588
|
-
});
|
|
14621
|
+
}));
|
|
14589
14622
|
});
|
|
14590
14623
|
};
|
|
14591
14624
|
|
|
@@ -16546,7 +16579,7 @@ function setBackgroundColor(props) {
|
|
|
16546
16579
|
}
|
|
16547
16580
|
}
|
|
16548
16581
|
var ToggleButtonStyles = function ToggleButtonStyles(props) {
|
|
16549
|
-
return /*#__PURE__*/react.css("background:", setBackgroundColor(props), ";&:not(:disabled):focus{background:", setBackgroundColor(props), ";outline-offset:-2px;}&:hover{background:", setBackgroundColor(props), ";};label:ToggleButtonStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16582
|
+
return /*#__PURE__*/react.css("background:", setBackgroundColor(props), ";&:not(:disabled):focus{background:", setBackgroundColor(props), ";outline-offset:-2px;}&:hover{background:", setBackgroundColor(props), ";};label:ToggleButtonStyles;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkIrQyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
|
|
16550
16583
|
};
|
|
16551
16584
|
var StyledToggleButtonIcon = /*#__PURE__*/_styled(IconButton, {
|
|
16552
16585
|
target: "e1iyqz1w1",
|
|
@@ -16555,11 +16588,11 @@ var StyledToggleButtonIcon = /*#__PURE__*/_styled(IconButton, {
|
|
|
16555
16588
|
return !props.hasLabel ? setIconWidth : '';
|
|
16556
16589
|
}, ";span{padding:", function (props) {
|
|
16557
16590
|
return !props.hasLabel ? 0 : '';
|
|
16558
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16591
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUNrRCIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
|
|
16559
16592
|
var StyledToggleButtonText = /*#__PURE__*/_styled(Button, {
|
|
16560
16593
|
target: "e1iyqz1w0",
|
|
16561
16594
|
label: "StyledToggleButtonText"
|
|
16562
|
-
})(ToggleButtonStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16595
|
+
})(ToggleButtonStyles, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRvZ2dsZUJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkM4QyIsImZpbGUiOiJUb2dnbGVCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvblNpemUsIEJ1dHRvbkNvbG9yIH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb2dnbGVCdXR0b25Hcm91cENvbnRleHQgfSBmcm9tICcuLi9Ub2dnbGVCdXR0b25Hcm91cC9Ub2dnbGVCdXR0b25Hcm91cCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuLy9TZXRzIHRoZSBpY29uIHdpZHRoIGZvciBpY29uIG9ubHkgVG9nZ2xlIEJ1dHRvbnNcclxuZXhwb3J0IGZ1bmN0aW9uIHNldEljb25XaWR0aChwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLnNpemUgPT09IEJ1dHRvblNpemUuc21hbGwpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDc7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuc2l6ZSA9PT0gQnV0dG9uU2l6ZS5sYXJnZSkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcxMTtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOTtcclxufVxyXG4vL1NldHMgdGhlIGJhY2tncm91bmQgY29sb3IgZm9yIHRoZSBUb2dnbGUgQnV0dG9uXHJcbmV4cG9ydCBmdW5jdGlvbiBzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc1NlbGVjdGVkKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDkwMCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0cmFuc3BhcmVudGl6ZSgwLjUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMzAwKTtcclxuICAgIH1cclxufVxyXG5leHBvcnQgY29uc3QgVG9nZ2xlQnV0dG9uU3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgJjpub3QoOmRpc2FibGVkKTpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtzZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgICBvdXRsaW5lLW9mZnNldDogLTJweDtcbiAgfVxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kOiAke3NldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25JY29uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtUb2dnbGVCdXR0b25TdHlsZXN9XG4gIG1pbi13aWR0aDogYXV0bztcbiAgd2lkdGg6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IHNldEljb25XaWR0aCA6ICcnKX07XG4gIHNwYW4ge1xuICAgIHBhZGRpbmc6ICR7cHJvcHMgPT4gKCFwcm9wcy5oYXNMYWJlbCA/IDAgOiAnJyl9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRUb2dnbGVCdXR0b25UZXh0ID0gc3R5bGVkKEJ1dHRvbikgYFxuICAke1RvZ2dsZUJ1dHRvblN0eWxlc31cbmA7XHJcbmV4cG9ydCBjb25zdCBUb2dnbGVCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7ICdhcmlhLWxhYmVsJzogYXJpYUxhYmVsLCBjaGlsZHJlbiwgZGlzYWJsZWQsIGljb24sIGlzQ2hlY2tlZCA9IGZhbHNlLCBpc0ludmVyc2UsIG9uQ2xpY2ssIHRlc3RJZCwgdmFsdWUsIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KFRvZ2dsZUJ1dHRvbkdyb3VwQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzRGVmYXVsdENoZWNrZWQgPSAoY29udGV4dC5zZWxlY3RlZFZhbHVlcyAmJlxyXG4gICAgICAgIHZhbHVlICYmXHJcbiAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcz8uaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHx8XHJcbiAgICAgICAgaXNDaGVja2VkO1xyXG4gICAgY29uc3QgW2lzU2VsZWN0ZWQsIHNldElzU2VsZWN0ZWRdID0gUmVhY3QudXNlU3RhdGUoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldElzU2VsZWN0ZWQoaXNEZWZhdWx0Q2hlY2tlZCk7XHJcbiAgICB9LCBbaXNDaGVja2VkXSk7XHJcbiAgICBjb25zdCBpbnZlcnNlQ2hlY2sgPSBjb250ZXh0LmlzSW52ZXJzZSB8fCBpc0ludmVyc2U7XHJcbiAgICBjb25zdCByb2xlQ2hlY2sgPSBjb250ZXh0LmV4Y2x1c2l2ZSA/ICdyYWRpbycgOiAnc3dpdGNoJztcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuZW5mb3JjZWQgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5sZW5ndGggPT09IDEgJiZcclxuICAgICAgICAgICAgY29udGV4dC5zZWxlY3RlZFZhbHVlcy5pbmNsdWRlcyh2YWx1ZS50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKGlzU2VsZWN0ZWQpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgLy8gZmxpcCB0aGUgdmFsdWUgb2YgaXNTZWxlY3RlZFxyXG4gICAgICAgICAgICBzZXRJc1NlbGVjdGVkKCFpc1NlbGVjdGVkKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25DbGljayAmJiB0eXBlb2Ygb25DbGljayA9PT0gJ2Z1bmN0aW9uJyAmJiBvbkNsaWNrKGV2ZW50KTtcclxuICAgICAgICBjb250ZXh0Lm9uQ2hhbmdlICYmXHJcbiAgICAgICAgICAgIHR5cGVvZiBjb250ZXh0Lm9uQ2hhbmdlID09PSAnZnVuY3Rpb24nICYmXHJcbiAgICAgICAgICAgIGNvbnRleHQub25DaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUNsaWNrRXhjbHVzaXZlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuc2VsZWN0ZWRWYWx1ZXMuaW5jbHVkZXModmFsdWUudG9TdHJpbmcoKSkpIHtcclxuICAgICAgICAgICAgc2V0SXNTZWxlY3RlZCh0cnVlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIHNldElzU2VsZWN0ZWQoZmFsc2UpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbkNsaWNrICYmIHR5cGVvZiBvbkNsaWNrID09PSAnZnVuY3Rpb24nICYmIG9uQ2xpY2soZXZlbnQpO1xyXG4gICAgICAgIGNvbnRleHQub25DaGFuZ2UgJiZcclxuICAgICAgICAgICAgdHlwZW9mIGNvbnRleHQub25DaGFuZ2UgPT09ICdmdW5jdGlvbicgJiZcclxuICAgICAgICAgICAgY29udGV4dC5vbkNoYW5nZShldmVudCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBpY29uID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVG9nZ2xlQnV0dG9uSWNvbiwgeyBcImFyaWEtY2hlY2tlZFwiOiBpc1NlbGVjdGVkLCBcImFyaWEtbGFiZWxcIjogYXJpYUxhYmVsLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogZGlzYWJsZWQsIHRoZW1lOiB0aGVtZSwgaGFzTGFiZWw6IGNoaWxkcmVuID8gdHJ1ZSA6IGZhbHNlLCBpY29uOiBpY29uLCBpZDogY29udGV4dC5kZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGludmVyc2VDaGVjaywgb25DbGljazogY29udGV4dC5leGNsdXNpdmUgPyBoYW5kbGVDbGlja0V4Y2x1c2l2ZSA6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgZW5mb3JjZWQ6IGNvbnRleHQuZW5mb3JjZWQsIHJvbGU6IHJvbGVDaGVjaywgaXNTZWxlY3RlZDogaXNTZWxlY3RlZCwgZXhjbHVzaXZlOiBjb250ZXh0LmV4Y2x1c2l2ZSwgc2l6ZTogcHJvcHMuc2l6ZSB8fCBjb250ZXh0LnNpemUsIHRlc3RJZDogdGVzdElkLCB2YWx1ZTogdmFsdWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBjaGlsZHJlbikpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRvZ2dsZUJ1dHRvblRleHQsIHsgXCJhcmlhLWNoZWNrZWRcIjogaXNTZWxlY3RlZCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCB0aGVtZTogdGhlbWUsIGlkOiBjb250ZXh0LmRlc2NyaXB0aW9uSWQsIGlzSW52ZXJzZTogaW52ZXJzZUNoZWNrLCBvbkNsaWNrOiBjb250ZXh0LmV4Y2x1c2l2ZSA/IGhhbmRsZUNsaWNrRXhjbHVzaXZlIDogaGFuZGxlQ2xpY2ssIHJlZjogcmVmLCBlbmZvcmNlZDogY29udGV4dC5lbmZvcmNlZCwgcm9sZTogcm9sZUNoZWNrLCBpc1NlbGVjdGVkOiBpc1NlbGVjdGVkLCBleGNsdXNpdmU6IGNvbnRleHQuZXhjbHVzaXZlLCBzaXplOiBwcm9wcy5zaXplIHx8IGNvbnRleHQuc2l6ZSwgdGVzdElkOiB0ZXN0SWQsIHZhbHVlOiB2YWx1ZSB9LCBjaGlsZHJlbikpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ub2dnbGVCdXR0b24uanMubWFwIl19 */"));
|
|
16563
16596
|
var ToggleButton = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
16564
16597
|
var _context$selectedValu;
|
|
16565
16598
|
var ariaLabel = props['aria-label'],
|