react-magma-dom 4.7.0-next.30 → 4.7.0-next.32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.js +101 -35
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +101 -35
- 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
package/dist/esm/index.js
CHANGED
|
@@ -4799,7 +4799,7 @@ var CardHeading = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
4799
4799
|
|
|
4800
4800
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$8() { 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)."; }
|
|
4801
4801
|
var DisplayInputStyles = function DisplayInputStyles(props) {
|
|
4802
|
-
return /*#__PURE__*/css("align-items:center;display:flex;height:", props.theme.spaceScale.spacing06, ";flex-shrink:0;justify-content:center;position:relative;transition:all 0.2s ease-out;width:", props.theme.spaceScale.spacing06, ";&:before,&:after{content:'';position:absolute;}&:after{border-radius:50%;height:", props.theme.spaceScale.spacing09, ";left:-", props.theme.spaceScale.spacing03, ";opacity:0;padding:50%;top:-", props.theme.spaceScale.spacing03, ";transform:scale(1);transition:opacity 1s,transform 0.5s;width:", props.theme.spaceScale.spacing09, ";};label:DisplayInputStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
4802
|
+
return /*#__PURE__*/css("align-items:center;display:flex;height:", props.theme.spaceScale.spacing06, ";flex-shrink:0;justify-content:center;position:relative;transition:all 0.2s ease-out;width:", props.theme.spaceScale.spacing06, ";&:before,&:after{content:'';position:absolute;}&:after{border-radius:50%;height:", props.theme.spaceScale.spacing09, ";left:-", props.theme.spaceScale.spacing03, ";opacity:0;padding:50%;top:-", props.theme.spaceScale.spacing03, ";transform:scale(1);transition:opacity 1s,transform 0.5s;width:", props.theme.spaceScale.spacing09, ";};label:DisplayInputStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0U3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDK0MiLCJmaWxlIjoiSW5wdXRTdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5leHBvcnQgY29uc3QgRGlzcGxheUlucHV0U3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgaGVpZ2h0OiAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA2fTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHRyYW5zaXRpb246IGFsbCAwLjJzIGVhc2Utb3V0O1xuICB3aWR0aDogJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNn07XG5cbiAgJjpiZWZvcmUsXG4gICY6YWZ0ZXIge1xuICAgIC8vIGZvY3VzIGFuZCBhY3RpdmUgc3RhdGVzXG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICB9XG5cbiAgJjphZnRlciB7XG4gICAgLy8gYWN0aXZlIHN0YXRlXG4gICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgIGhlaWdodDogJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOX07XG4gICAgbGVmdDogLSR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICAgIG9wYWNpdHk6IDA7XG4gICAgcGFkZGluZzogNTAlO1xuICAgIHRvcDogLSR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gICAgdHJhbnNpdGlvbjogb3BhY2l0eSAxcywgdHJhbnNmb3JtIDAuNXM7XG4gICAgd2lkdGg6ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDl9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzcGxheUlucHV0QWN0aXZlU3R5bGVzID0gY3NzIGBcbiAgb3BhY2l0eTogMC40O1xuICB0cmFuc2Zvcm06IHNjYWxlKDApO1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMHM7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGREaXNwbGF5SW5wdXRBY3RpdmVCYWNrZ3JvdW5kKHByb3BzKSB7XHJcbiAgICByZXR1cm4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgICAgIDogcHJvcHMuY29sb3JcclxuICAgICAgICAgICAgPyBwcm9wcy5jb2xvclxyXG4gICAgICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5O1xyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBidWlsZERpc3BsYXlJbnB1dEJvcmRlckNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMzAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIHJldHVybiAndHJhbnNwYXJlbnQnO1xyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBidWlsZERpc3BsYXlJbnB1dEZvY3VzU3R5bGVzKHByb3BzKSB7XHJcbiAgICByZXR1cm4gY3NzIGBcbiAgICBoZWlnaHQ6IDMwcHg7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIGA7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5wdXRTdHlsZXMuanMubWFwIl19 */"));
|
|
4803
4803
|
};
|
|
4804
4804
|
var DisplayInputActiveStyles = process.env.NODE_ENV === "production" ? {
|
|
4805
4805
|
name: "1r962mu-DisplayInputActiveStyles",
|
|
@@ -4807,7 +4807,7 @@ var DisplayInputActiveStyles = process.env.NODE_ENV === "production" ? {
|
|
|
4807
4807
|
} : {
|
|
4808
4808
|
name: "1r962mu-DisplayInputActiveStyles",
|
|
4809
4809
|
styles: "opacity:0.4;transform:scale(0);transition:transform 0s;label:DisplayInputActiveStyles;",
|
|
4810
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0U3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQjRDIiwiZmlsZSI6IklucHV0U3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuZXhwb3J0IGNvbnN0IERpc3BsYXlJbnB1dFN0eWxlcyA9IHByb3BzID0+
|
|
4810
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0U3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQjRDIiwiZmlsZSI6IklucHV0U3R5bGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuZXhwb3J0IGNvbnN0IERpc3BsYXlJbnB1dFN0eWxlcyA9IHByb3BzID0+IGNzcyBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGhlaWdodDogJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNn07XG4gIGZsZXgtc2hyaW5rOiAwO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB0cmFuc2l0aW9uOiBhbGwgMC4ycyBlYXNlLW91dDtcbiAgd2lkdGg6ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDZ9O1xuXG4gICY6YmVmb3JlLFxuICAmOmFmdGVyIHtcbiAgICAvLyBmb2N1cyBhbmQgYWN0aXZlIHN0YXRlc1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgfVxuXG4gICY6YWZ0ZXIge1xuICAgIC8vIGFjdGl2ZSBzdGF0ZVxuICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICBoZWlnaHQ6ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDl9O1xuICAgIGxlZnQ6IC0ke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgICBvcGFjaXR5OiAwO1xuICAgIHBhZGRpbmc6IDUwJTtcbiAgICB0b3A6IC0ke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEpO1xuICAgIHRyYW5zaXRpb246IG9wYWNpdHkgMXMsIHRyYW5zZm9ybSAwLjVzO1xuICAgIHdpZHRoOiAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA5fTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IERpc3BsYXlJbnB1dEFjdGl2ZVN0eWxlcyA9IGNzcyBgXG4gIG9wYWNpdHk6IDAuNDtcbiAgdHJhbnNmb3JtOiBzY2FsZSgwKTtcbiAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIDBzO1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZChwcm9wcykge1xyXG4gICAgcmV0dXJuIHByb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgICAgICA6IHByb3BzLmNvbG9yXHJcbiAgICAgICAgICAgID8gcHJvcHMuY29sb3JcclxuICAgICAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGREaXNwbGF5SW5wdXRCb3JkZXJDb2xvcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjMwMDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gJ3RyYW5zcGFyZW50JztcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGREaXNwbGF5SW5wdXRGb2N1c1N0eWxlcyhwcm9wcykge1xyXG4gICAgcmV0dXJuIGNzcyBgXG4gICAgaGVpZ2h0OiAzMHB4O1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICB3aWR0aDogMzBweDtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXNJbnZlcnNlXHJcbiAgICAgICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICBgO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUlucHV0U3R5bGVzLmpzLm1hcCJdfQ== */",
|
|
4811
4811
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
4812
4812
|
};
|
|
4813
4813
|
function buildDisplayInputActiveBackground(props) {
|
|
@@ -4816,14 +4816,14 @@ function buildDisplayInputActiveBackground(props) {
|
|
|
4816
4816
|
function buildDisplayInputBorderColor(props) {
|
|
4817
4817
|
if (props.hasError) {
|
|
4818
4818
|
if (props.isInverse) {
|
|
4819
|
-
return props.theme.colors.
|
|
4819
|
+
return props.theme.colors.danger300;
|
|
4820
4820
|
}
|
|
4821
4821
|
return props.theme.colors.danger;
|
|
4822
4822
|
}
|
|
4823
4823
|
return 'transparent';
|
|
4824
4824
|
}
|
|
4825
4825
|
function buildDisplayInputFocusStyles(props) {
|
|
4826
|
-
return /*#__PURE__*/css("height:30px;position:absolute;width:30px;outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";;label:buildDisplayInputFocusStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
4826
|
+
return /*#__PURE__*/css("height:30px;position:absolute;width:30px;outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";;label:buildDisplayInputFocusStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0U3R5bGVzLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRGUiLCJmaWxlIjoiSW5wdXRTdHlsZXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5leHBvcnQgY29uc3QgRGlzcGxheUlucHV0U3R5bGVzID0gcHJvcHMgPT4gY3NzIGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgaGVpZ2h0OiAke3Byb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA2fTtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHRyYW5zaXRpb246IGFsbCAwLjJzIGVhc2Utb3V0O1xuICB3aWR0aDogJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNn07XG5cbiAgJjpiZWZvcmUsXG4gICY6YWZ0ZXIge1xuICAgIC8vIGZvY3VzIGFuZCBhY3RpdmUgc3RhdGVzXG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICB9XG5cbiAgJjphZnRlciB7XG4gICAgLy8gYWN0aXZlIHN0YXRlXG4gICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgIGhlaWdodDogJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOX07XG4gICAgbGVmdDogLSR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICAgIG9wYWNpdHk6IDA7XG4gICAgcGFkZGluZzogNTAlO1xuICAgIHRvcDogLSR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gICAgdHJhbnNpdGlvbjogb3BhY2l0eSAxcywgdHJhbnNmb3JtIDAuNXM7XG4gICAgd2lkdGg6ICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDl9O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzcGxheUlucHV0QWN0aXZlU3R5bGVzID0gY3NzIGBcbiAgb3BhY2l0eTogMC40O1xuICB0cmFuc2Zvcm06IHNjYWxlKDApO1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMHM7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGREaXNwbGF5SW5wdXRBY3RpdmVCYWNrZ3JvdW5kKHByb3BzKSB7XHJcbiAgICByZXR1cm4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgICAgIDogcHJvcHMuY29sb3JcclxuICAgICAgICAgICAgPyBwcm9wcy5jb2xvclxyXG4gICAgICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5O1xyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBidWlsZERpc3BsYXlJbnB1dEJvcmRlckNvbG9yKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMzAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIHJldHVybiAndHJhbnNwYXJlbnQnO1xyXG59XHJcbmV4cG9ydCBmdW5jdGlvbiBidWlsZERpc3BsYXlJbnB1dEZvY3VzU3R5bGVzKHByb3BzKSB7XHJcbiAgICByZXR1cm4gY3NzIGBcbiAgICBoZWlnaHQ6IDMwcHg7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIHdpZHRoOiAzMHB4O1xuICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgJHtwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c307XG4gIGA7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5wdXRTdHlsZXMuanMubWFwIl19 */"));
|
|
4827
4827
|
}
|
|
4828
4828
|
|
|
4829
4829
|
var _excluded$k = ["actionable", "children", "iconPosition", "labelPosition", "size", "testId"];
|
|
@@ -4911,7 +4911,7 @@ var InputIconPosition;
|
|
|
4911
4911
|
InputIconPosition["right"] = "right";
|
|
4912
4912
|
})(InputIconPosition || (InputIconPosition = {}));
|
|
4913
4913
|
var inputWrapperStyles = function inputWrapperStyles(props) {
|
|
4914
|
-
return /*#__PURE__*/css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? curriedTransparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;}", props.hasError && /*#__PURE__*/css("border-color:", props.isInverse ? props.theme.colors.danger200 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyDQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgEQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0EQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4914
|
+
return /*#__PURE__*/css("flex:1 1 auto;align-items:center;display:flex;position:relative;width:", props.width || 'auto', ";background-color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral900) : props.theme.colors.neutral100, ";border-radius:", props.theme.borderRadius, ";border:1px solid ", props.isInverse ? curriedTransparentize(0.5, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";height:", props.theme.spaceScale.spacing09, ";&:focus-within{outline:2px solid ", props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus, ";outline-offset:-1px;}", props.hasError && /*#__PURE__*/css("border-color:", props.isInverse ? props.theme.colors.danger300 : props.theme.colors.danger, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyDQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgEQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0EQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgCiD","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4915
4915
|
};
|
|
4916
4916
|
function getInputPadding(props) {
|
|
4917
4917
|
var inputSize = props.inputSize,
|
|
@@ -4963,7 +4963,7 @@ function getInputPadding(props) {
|
|
|
4963
4963
|
return padding;
|
|
4964
4964
|
}
|
|
4965
4965
|
var inputBaseStyles = function inputBaseStyles(props) {
|
|
4966
|
-
return /*#__PURE__*/css("border:0;border-radius:", props.theme.borderRadius, ";background:transparent;color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";display:block;font-size:", props.theme.typeScale.size03.fontSize, ";line-height:", props.theme.typeScale.size03.lineHeight, ";font-family:", props.theme.bodyFont, ";height:", props.theme.spaceScale.spacing09, ";padding:", props.theme.spaceScale.spacing03, ";-webkit-appearance:none;width:100%;", props.inputSize === 'large' && /*#__PURE__*/css("font-size:", props.theme.typeScale.size04.fontSize, ";line-height:", props.theme.typeScale.size04.lineHeight, ";height:", props.theme.spaceScale.spacing11, ";padding:", props.theme.spaceScale.spacing04, ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqJQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmLQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoI8C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4966
|
+
return /*#__PURE__*/css("border:0;border-radius:", props.theme.borderRadius, ";background:transparent;color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, ";display:block;font-size:", props.theme.typeScale.size03.fontSize, ";line-height:", props.theme.typeScale.size03.lineHeight, ";font-family:", props.theme.bodyFont, ";height:", props.theme.spaceScale.spacing09, ";padding:", props.theme.spaceScale.spacing03, ";-webkit-appearance:none;width:100%;", props.inputSize === 'large' && /*#__PURE__*/css("font-size:", props.theme.typeScale.size04.fontSize, ";line-height:", props.theme.typeScale.size04.lineHeight, ";height:", props.theme.spaceScale.spacing11, ";padding:", props.theme.spaceScale.spacing04, ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqJQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmLQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, onIconClick: onIconClick, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoI8C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4967
4967
|
};
|
|
4968
4968
|
var InputContainer = /*#__PURE__*/_styled("div", {
|
|
4969
4969
|
target: "e1jxjjn77",
|
|
@@ -4974,17 +4974,17 @@ var InputContainer = /*#__PURE__*/_styled("div", {
|
|
|
4974
4974
|
} : {
|
|
4975
4975
|
name: "zjik7",
|
|
4976
4976
|
styles: "display:flex",
|
|
4977
|
-
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.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */",
|
|
4977
|
+
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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */",
|
|
4978
4978
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$9
|
|
4979
4979
|
});
|
|
4980
4980
|
var InputWrapper = /*#__PURE__*/_styled("div", {
|
|
4981
4981
|
target: "e1jxjjn76",
|
|
4982
4982
|
label: "InputWrapper"
|
|
4983
|
-
})(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoMuC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4983
|
+
})(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoMuC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4984
4984
|
var StyledInput = /*#__PURE__*/_styled("input", {
|
|
4985
4985
|
target: "e1jxjjn75",
|
|
4986
4986
|
label: "StyledInput"
|
|
4987
|
-
})(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuMiC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4987
|
+
})(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuMiC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
4988
4988
|
var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
4989
4989
|
target: "e1jxjjn74",
|
|
4990
4990
|
label: "IconWrapper"
|
|
@@ -5001,8 +5001,8 @@ var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
|
5001
5001
|
return props.theme.spaceScale.spacing03;
|
|
5002
5002
|
};
|
|
5003
5003
|
}, ";", function (props) {
|
|
5004
|
-
return props.inputSize === 'large' && /*#__PURE__*/css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5005
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0MgC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5004
|
+
return props.inputSize === 'large' && /*#__PURE__*/css("bottom:", props.iconPosition === 'top' ? '62px' : 'inherit', ";left:", props.iconPosition === 'left' ? props.theme.spaceScale.spacing04 : 'auto', ";right:", props.iconPosition === 'right' ? props.theme.spaceScale.spacing04 : props.iconPosition === 'top' ? '3px' : 'auto', ";top:", props.iconPosition === 'top' ? 'inherit' : props.theme.spaceScale.spacing04, ";;label:IconWrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2NQ","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5005
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0MgC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5006
5006
|
function getIconButtonSVGSize(props) {
|
|
5007
5007
|
var isClickable = props.isClickable,
|
|
5008
5008
|
iconPosition = props.iconPosition,
|
|
@@ -5092,7 +5092,7 @@ var IconButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
5092
5092
|
return getIconButtonSVGSize(props);
|
|
5093
5093
|
}, ";width:", function (props) {
|
|
5094
5094
|
return getIconButtonSVGSize(props);
|
|
5095
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8S+C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5095
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8S+C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5096
5096
|
var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
5097
5097
|
target: "e1jxjjn72",
|
|
5098
5098
|
label: "PasswordButtonContainer"
|
|
@@ -5100,7 +5100,7 @@ var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
5100
5100
|
return props.size === InputSize.large ? -props.buttonWidth - 8 + "px" : -props.buttonWidth - 6 + "px";
|
|
5101
5101
|
}, ",\n ", function (props) {
|
|
5102
5102
|
return props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
|
|
5103
|
-
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T4C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5103
|
+
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T4C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5104
5104
|
function getClearablePosition(props) {
|
|
5105
5105
|
if (props.iconPosition === 'right' && props.icon) {
|
|
5106
5106
|
if (props.inputSize === 'large') {
|
|
@@ -5120,7 +5120,7 @@ var IsClearableContainer = /*#__PURE__*/_styled("span", {
|
|
|
5120
5120
|
return getClearablePosition(props);
|
|
5121
5121
|
}, ",\n ", function (props) {
|
|
5122
5122
|
return props.inputSize === InputSize.large ? props.theme.spaceScale.spacing03 : '7px';
|
|
5123
|
-
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoVyC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5123
|
+
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoVyC","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5124
5124
|
function getIconSize$1(size, theme, iconPosition) {
|
|
5125
5125
|
switch (size) {
|
|
5126
5126
|
case 'large':
|
|
@@ -5159,7 +5159,7 @@ var HelpLinkContainer = /*#__PURE__*/_styled("span", {
|
|
|
5159
5159
|
return getHelpIconButtonSize(props);
|
|
5160
5160
|
}, ";width:", function (props) {
|
|
5161
5161
|
return getHelpIconButtonSize(props);
|
|
5162
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgX6C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger200\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = 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\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5162
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgX6C","file":"index.tsx","sourcesContent":["import { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport * as React from 'react';\r\nimport { ClearIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useForkedRef } from '../../utils';\r\nimport { ButtonShape, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { LabelPosition } from '../Label';\r\nexport var InputSize;\r\n(function (InputSize) {\r\n    InputSize[\"large\"] = \"large\";\r\n    InputSize[\"medium\"] = \"medium\";\r\n})(InputSize || (InputSize = {}));\r\nexport var InputType;\r\n(function (InputType) {\r\n    InputType[\"email\"] = \"email\";\r\n    InputType[\"file\"] = \"file\";\r\n    InputType[\"number\"] = \"number\";\r\n    InputType[\"password\"] = \"password\";\r\n    InputType[\"search\"] = \"search\";\r\n    InputType[\"text\"] = \"text\";\r\n})(InputType || (InputType = {}));\r\nexport var InputIconPosition;\r\n(function (InputIconPosition) {\r\n    InputIconPosition[\"top\"] = \"top\";\r\n    InputIconPosition[\"left\"] = \"left\";\r\n    InputIconPosition[\"right\"] = \"right\";\r\n})(InputIconPosition || (InputIconPosition = {}));\r\nexport const inputWrapperStyles = (props) => css `\n  flex: 1 1 auto;\n  align-items: center;\n  display: flex;\n  position: relative;\n  width: ${props.width || 'auto'};\n  background-color: ${props.isInverse\r\n    ? transparentize(0.8, props.theme.colors.neutral900)\r\n    : props.theme.colors.neutral100};\n  border-radius: ${props.theme.borderRadius};\n  border: 1px solid\n    ${props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  height: ${props.theme.spaceScale.spacing09};\n\n  &:focus-within {\n    outline: 2px solid\n      ${props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: -1px;\n  }\n\n  ${props.hasError &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? props.theme.colors.danger300\r\n        : props.theme.colors.danger};\n  `}\n\n  ${props.disabled &&\r\n    css `\n    border-color: ${props.isInverse\r\n        ? transparentize(0.85, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral300};\n    background-color: ${props.isInverse\r\n        ? transparentize(0.9, props.theme.colors.neutral900)\r\n        : props.theme.colors.neutral200};\n  `}\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    height: ${props.theme.spaceScale.spacing11};\n  `}\n`;\r\nfunction getInputPadding(props) {\r\n    const { inputSize, isClearable, iconPosition } = props;\r\n    let padding = {\r\n        left: props.theme.spaceScale.spacing03,\r\n        right: props.theme.spaceScale.spacing03,\r\n    };\r\n    if (inputSize === 'large') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '92px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing11;\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing11;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing10;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing10;\r\n            }\r\n        }\r\n    }\r\n    else if (inputSize === 'medium') {\r\n        if (isClearable) {\r\n            if (iconPosition === 'right') {\r\n                padding.right = '68px';\r\n            }\r\n            else if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            else {\r\n                // icon top, no icon\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n        else {\r\n            if (iconPosition === 'right') {\r\n                padding.right = props.theme.spaceScale.spacing09;\r\n            }\r\n            if (iconPosition === 'left') {\r\n                padding.left = props.theme.spaceScale.spacing09;\r\n            }\r\n        }\r\n    }\r\n    return padding;\r\n}\r\nexport const inputBaseStyles = (props) => css `\n  border: 0;\n  border-radius: ${props.theme.borderRadius};\n  background: transparent;\n  color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: block;\n  font-size: ${props.theme.typeScale.size03.fontSize};\n  line-height: ${props.theme.typeScale.size03.lineHeight};\n  font-family: ${props.theme.bodyFont};\n  height: ${props.theme.spaceScale.spacing09};\n  padding: ${props.theme.spaceScale.spacing03};\n  -webkit-appearance: none;\n  width: 100%;\n\n  ${props.inputSize === 'large' &&\r\n    css `\n    font-size: ${props.theme.typeScale.size04.fontSize};\n    line-height: ${props.theme.typeScale.size04.lineHeight};\n    height: ${props.theme.spaceScale.spacing11};\n    padding: ${props.theme.spaceScale.spacing04};\n  `}\n\n  padding-left: ${getInputPadding(props).left};\n  padding-right: ${getInputPadding(props).right};\n\n  &::placeholder {\n    color: ${props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  }\n\n  &:focus {\n    outline: 0;\n  }\n\n  &[type='search'] {\n    &::-webkit-search-decoration,\n    &::-webkit-search-cancel-button,\n    &::-webkit-search-results-button,\n    &::-webkit-search-results-decoration {\n      display: none;\n    }\n  }\n\n  ${props.disabled &&\r\n    css `\n    color: ${props.isInverse\r\n        ? transparentize(0.6, props.theme.colors.neutral100)\r\n        : transparentize(0.4, props.theme.colors.neutral500)};\n    cursor: not-allowed;\n\n    &::placeholder {\n      color: ${props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral100)\r\n        : props.theme.colors.neutral500};\n      opacity: ${props.isInverse ? 0.4 : 0.6};\n    }\n  `}\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nfunction 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\nconst isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: relative;\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}` : 0};\n  transform: translate(\n    ${props => (isLeftOrHidden(props) ? '0' : '-100%')},\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`;\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"]} */"));
|
|
5163
5163
|
var InputBase = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
5164
5164
|
var children = props.children,
|
|
5165
5165
|
containerStyle = props.containerStyle,
|
|
@@ -5344,13 +5344,13 @@ var Message = /*#__PURE__*/_styled("div", {
|
|
|
5344
5344
|
return props.theme.typeScale.size02.lineHeight;
|
|
5345
5345
|
}, ";margin-top:", function (props) {
|
|
5346
5346
|
return props.inputSize === InputSize.large ? props.theme.spaceScale.spacing03 : props.theme.spaceScale.spacing02;
|
|
5347
|
-
}, ";text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0IyQiIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+
|
|
5347
|
+
}, ";text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0IyQiIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gcHJvcHMuaW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDNcclxuICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuYDtcclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBmbGV4LXNocmluazogMDtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG5gO1xyXG5leHBvcnQgY29uc3QgSW5wdXRNZXNzYWdlID0gKHsgY2hpbGRyZW4sIGlkLCBpc0ludmVyc2UsIGhhc0Vycm9yLCBtYXhDb3VudCwgLi4ub3RoZXIgfSkgPT4ge1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICAvL0NvbmRpdGlvbmFsIHdyYXBwZXIgYmFzZWQgb24gbWF4Q291bnQsIGFsbG93cyBDaGFyYWN0ZXIgQ291bnRlciB0byByZW5kZXIgd2l0aG91dCB0aGUgQW5ub3VuY2UgY29tcG9uZW50IGZvciBhY2Nlc3NpYmlsaXR5IHB1cnBvc2VzLlxyXG4gICAgZnVuY3Rpb24gQW5ub3VuY2VXcmFwcGVyKHByb3BzKSB7XHJcbiAgICAgICAgaWYgKG1heENvdW50KSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQW5ub3VuY2UsIG51bGwsIHByb3BzLmNoaWxkcmVuKTtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZVdyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChNZXNzYWdlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IFwiaW5wdXRNZXNzYWdlXCIsIGlkOiBpZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICBoYXNFcnJvciAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyBcImFyaWEtbGFiZWxcIjogXCJFcnJvclwiLCByb2xlOiBcImltZ1wiLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRXJyb3JJY29uLCB7IHNpemU6IHRoZW1lLmljb25TaXplcy5zbWFsbCwgY29sb3I6IGlzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5kYW5nZXIzMDAgOiB1bmRlZmluZWQgfSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCBudWxsLCBjaGlsZHJlbikpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUlucHV0TWVzc2FnZS5qcy5tYXAiXX0= */"));
|
|
5348
5348
|
var IconWrapper$4 = /*#__PURE__*/_styled("span", {
|
|
5349
5349
|
target: "e1egx0lj0",
|
|
5350
5350
|
label: "IconWrapper"
|
|
5351
5351
|
})("display:inline-flex;flex-shrink:0;padding-right:", function (props) {
|
|
5352
5352
|
return props.theme.spaceScale.spacing02;
|
|
5353
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJnQyIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+
|
|
5353
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJnQyIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyB0cmFuc3BhcmVudGl6ZSB9IGZyb20gJ3BvbGlzaGVkJztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gcHJvcHMuaW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDNcclxuICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuYDtcclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBmbGV4LXNocmluazogMDtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG5gO1xyXG5leHBvcnQgY29uc3QgSW5wdXRNZXNzYWdlID0gKHsgY2hpbGRyZW4sIGlkLCBpc0ludmVyc2UsIGhhc0Vycm9yLCBtYXhDb3VudCwgLi4ub3RoZXIgfSkgPT4ge1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICAvL0NvbmRpdGlvbmFsIHdyYXBwZXIgYmFzZWQgb24gbWF4Q291bnQsIGFsbG93cyBDaGFyYWN0ZXIgQ291bnRlciB0byByZW5kZXIgd2l0aG91dCB0aGUgQW5ub3VuY2UgY29tcG9uZW50IGZvciBhY2Nlc3NpYmlsaXR5IHB1cnBvc2VzLlxyXG4gICAgZnVuY3Rpb24gQW5ub3VuY2VXcmFwcGVyKHByb3BzKSB7XHJcbiAgICAgICAgaWYgKG1heENvdW50KSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQW5ub3VuY2UsIG51bGwsIHByb3BzLmNoaWxkcmVuKTtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZVdyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChNZXNzYWdlLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImRhdGEtdGVzdGlkXCI6IFwiaW5wdXRNZXNzYWdlXCIsIGlkOiBpZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGhhc0Vycm9yOiBoYXNFcnJvciwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICBoYXNFcnJvciAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJY29uV3JhcHBlciwgeyBcImFyaWEtbGFiZWxcIjogXCJFcnJvclwiLCByb2xlOiBcImltZ1wiLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRXJyb3JJY29uLCB7IHNpemU6IHRoZW1lLmljb25TaXplcy5zbWFsbCwgY29sb3I6IGlzSW52ZXJzZSA/IHRoZW1lLmNvbG9ycy5kYW5nZXIzMDAgOiB1bmRlZmluZWQgfSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCBudWxsLCBjaGlsZHJlbikpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUlucHV0TWVzc2FnZS5qcy5tYXAiXX0= */"));
|
|
5354
5354
|
var InputMessage = function InputMessage(_ref) {
|
|
5355
5355
|
var children = _ref.children,
|
|
5356
5356
|
id = _ref.id,
|
|
@@ -5377,7 +5377,8 @@ var InputMessage = function InputMessage(_ref) {
|
|
|
5377
5377
|
role: "img",
|
|
5378
5378
|
theme: theme
|
|
5379
5379
|
}, createElement(ErrorIcon, {
|
|
5380
|
-
size: theme.iconSizes.small
|
|
5380
|
+
size: theme.iconSizes.small,
|
|
5381
|
+
color: isInverse ? theme.colors.danger300 : undefined
|
|
5381
5382
|
})), createElement("div", null, children)));
|
|
5382
5383
|
};
|
|
5383
5384
|
|
|
@@ -6574,11 +6575,11 @@ var StyledNativeSelectWrapper = /*#__PURE__*/_styled("div", {
|
|
|
6574
6575
|
return props.theme.spaceScale.spacing03;
|
|
6575
6576
|
}, " 0 -", function (props) {
|
|
6576
6577
|
return props.theme.spaceScale.spacing08;
|
|
6577
|
-
}, ";pointer-events:none;z-index:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzZDIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICAgICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIC0ke3Byb3BzID0+
|
|
6578
|
+
}, ";pointer-events:none;z-index:1;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzZDIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICAgICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIC0ke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICB6LWluZGV4OiAxO1xuICB9XG5gO1xyXG5mdW5jdGlvbiBib3JkZXJDb2xvcnMocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIzMDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC44NSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMDtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMDtcclxufVxyXG5jb25zdCBTdHlsZWROYXRpdmVTZWxlY3QgPSBzdHlsZWQuc2VsZWN0IGBcbiAgJHtpbnB1dEJhc2VTdHlsZXN9O1xuICBoZWlnaHQ6IDM4cHg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDh9O1xuICAvLyBSZXF1aXJlZCBmb3IgV2luZG93cyAmJiBDaHJvbWUgc3VwcG9ydFxuICBiYWNrZ3JvdW5kOiBpbmhlcml0O1xuICA+IG9wdGlvbiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDYwMCA6ICdub25lJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGZsZXg6IDE7XG4gICAgICBsYWJlbCB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGxhYmVsIHtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwO1xuICB9XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAwIDAgMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IE5hdGl2ZVNlbGVjdCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZGlzYWJsZWQsIGVycm9yTWVzc2FnZSwgaWQ6IGRlZmF1bHRJZCwgaGVscGVyTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChkZWZhdWx0SWQpO1xyXG4gICAgY29uc3QgaGFzTGFiZWwgPSAhIWxhYmVsVGV4dDtcclxuICAgIGNvbnN0IG5hdGl2ZVNlbGVjdCA9IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgeyBhZGRpdGlvbmFsQ29udGVudDogYWRkaXRpb25hbENvbnRlbnQsIGNvbnRhaW5lclN0eWxlOiBjb250YWluZXJTdHlsZSwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1mb3JtLWZpZWxkLWNvbnRhaW5lcmAsIGVycm9yTWVzc2FnZTogZXJyb3JNZXNzYWdlLCBmaWVsZElkOiBpZCwgaGFzTGFiZWw6ICEhbGFiZWxUZXh0LCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlOiBsYWJlbFN0eWxlLCBsYWJlbFRleHQ6IGxhYmVsUG9zaXRpb24gIT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICBsYWJlbFRleHQsXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiBhZGRpdGlvbmFsQ29udGVudCkpIDogKGxhYmVsVGV4dCksIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBoZWxwZXJNZXNzYWdlOiBoZWxwZXJNZXNzYWdlLCBtZXNzYWdlU3R5bGU6IG1lc3NhZ2VTdHlsZSwgcmVmOiByZWYgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIsIHsgZGlzYWJsZWQ6IGRpc2FibGVkLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3QsIE9iamVjdC5hc3NpZ24oeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlkOiBpZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LCBvdGhlciksIGNoaWxkcmVuKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEZWZhdWx0RHJvcGRvd25JbmRpY2F0b3IsIHsgZGlzYWJsZWQ6IGRpc2FibGVkIH0pKSkpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIEZvcm1GaWVsZENvbnRhaW5lciwgTmF0aXZlU2VsZWN0V3JhcHBlciwgYW5kIE5hdGl2ZVNlbGVjdCBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG4gICAgZnVuY3Rpb24gQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyKHByb3BzKSB7XHJcbiAgICAgICAgaWYgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi50b3AgJiYgIWhhc0xhYmVsKSkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS1hZGRpdGlvbmFsLWNvbnRlbnQtd3JhcHBlcmAsIHRoZW1lOiB0aGVtZSB9LCBwcm9wcy5jaGlsZHJlbikpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICBpZiAoYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgbmF0aXZlU2VsZWN0LFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAgICAgKCFsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICByZXR1cm4gbmF0aXZlU2VsZWN0O1xyXG4gICAgfVxyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9TmF0aXZlU2VsZWN0LmpzLm1hcCJdfQ== */"));
|
|
6578
6579
|
function borderColors(props) {
|
|
6579
6580
|
if (props.isInverse) {
|
|
6580
6581
|
if (props.hasError) {
|
|
6581
|
-
return props.theme.colors.
|
|
6582
|
+
return props.theme.colors.danger300;
|
|
6582
6583
|
}
|
|
6583
6584
|
if (props.disabled) {
|
|
6584
6585
|
return curriedTransparentize(0.85, props.theme.colors.neutral100);
|
|
@@ -6600,14 +6601,14 @@ var StyledNativeSelect = /*#__PURE__*/_styled("select", {
|
|
|
6600
6601
|
return props.theme.spaceScale.spacing08;
|
|
6601
6602
|
}, ";background:inherit;>option{background:", function (props) {
|
|
6602
6603
|
return props.isInverse ? props.theme.colors.neutral600 : 'none';
|
|
6603
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkN5QyIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/
|
|
6604
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkN5QyIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApXHJcbiAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAtJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOH07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgei1pbmRleDogMTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gYm9yZGVyQ29sb3JzKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMzAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbn1cclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0ID0gc3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICBwYWRkaW5nLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgLy8gUmVxdWlyZWQgZm9yIFdpbmRvd3MgJiYgQ2hyb21lIHN1cHBvcnRcbiAgYmFja2dyb3VuZDogaW5oZXJpdDtcbiAgPiBvcHRpb24ge1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw2MDAgOiAnbm9uZSd9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRGb3JtRmllbGRDb250YWluZXIgPSBzdHlsZWQoRm9ybUZpZWxkQ29udGFpbmVyKSBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuYWRkaXRpb25hbENvbnRlbnQgJiZcclxuICAgIGNzcyBgXG4gICAgICBmbGV4OiAxO1xuICAgICAgbGFiZWwge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMDtcbiAgfVxuICBidXR0b24ge1xuICAgIG1hcmdpbjogMCAwIDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBOYXRpdmVTZWxlY3QgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGRpc2FibGVkLCBlcnJvck1lc3NhZ2UsIGlkOiBkZWZhdWx0SWQsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGhhc0xhYmVsID0gISFsYWJlbFRleHQ7XHJcbiAgICBjb25zdCBuYXRpdmVTZWxlY3QgPSAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIHsgYWRkaXRpb25hbENvbnRlbnQ6IGFkZGl0aW9uYWxDb250ZW50LCBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tZm9ybS1maWVsZC1jb250YWluZXJgLCBlcnJvck1lc3NhZ2U6IGVycm9yTWVzc2FnZSwgZmllbGRJZDogaWQsIGhhc0xhYmVsOiAhIWxhYmVsVGV4dCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSA6IChsYWJlbFRleHQpLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgbWVzc2FnZVN0eWxlOiBtZXNzYWdlU3R5bGUsIHJlZjogcmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3RXcmFwcGVyLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0LCBPYmplY3QuYXNzaWduKHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpZDogaWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgb3RoZXIpLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yLCB7IGRpc2FibGVkOiBkaXNhYmxlZCB9KSkpKTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBGb3JtRmllbGRDb250YWluZXIsIE5hdGl2ZVNlbGVjdFdyYXBwZXIsIGFuZCBOYXRpdmVTZWxlY3QgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24udG9wICYmICFoYXNMYWJlbCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBcImRhdGEtdGVzdGlkXCI6IGAke3Rlc3RJZH0tYWRkaXRpb25hbC1jb250ZW50LXdyYXBwZXJgLCB0aGVtZTogdGhlbWUgfSwgcHJvcHMuY2hpbGRyZW4pKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgaWYgKGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIG5hdGl2ZVNlbGVjdCxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgICAgICghbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgcmV0dXJuIG5hdGl2ZVNlbGVjdDtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPU5hdGl2ZVNlbGVjdC5qcy5tYXAiXX0= */"));
|
|
6604
6605
|
var _ref$3 = process.env.NODE_ENV === "production" ? {
|
|
6605
6606
|
name: "i0lfe0-StyledFormFieldContainer",
|
|
6606
6607
|
styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;"
|
|
6607
6608
|
} : {
|
|
6608
6609
|
name: "i0lfe0-StyledFormFieldContainer",
|
|
6609
6610
|
styles: "flex:1;label{display:flex;justify-content:space-between;align-items:center;};label:StyledFormFieldContainer;",
|
|
6610
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRRIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICAgICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIC0ke3Byb3BzID0+
|
|
6611
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRRIiwiZmlsZSI6Ik5hdGl2ZVNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHsgaW5wdXRCYXNlU3R5bGVzLCBpbnB1dFdyYXBwZXJTdHlsZXMgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGRDb250YWluZXIsIH0gZnJvbSAnLi4vRm9ybUZpZWxkQ29udGFpbmVyJztcclxuaW1wb3J0IHsgRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yIH0gZnJvbSAnLi4vU2VsZWN0L2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmltcG9ydCB7IExhYmVsUG9zaXRpb24gfSBmcm9tICcuLi9MYWJlbCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICAke2lucHV0V3JhcHBlclN0eWxlc31cbiAgYm9yZGVyOiAxcHggc29saWQgJHtib3JkZXJDb2xvcnN9O1xuICBzdmcge1xuICAgIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZSAmJiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgPyB0cmFuc3BhcmVudGl6ZSgwLjYsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKVxyXG4gICAgOiBwcm9wcy5kaXNhYmxlZFxyXG4gICAgICAgID8gdHJhbnNwYXJlbnRpemUoMC40LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMClcclxuICAgICAgICA6IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgICAgICAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICAgICAgICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICAgIG1hcmdpbjogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwIC0ke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICB6LWluZGV4OiAxO1xuICB9XG5gO1xyXG5mdW5jdGlvbiBib3JkZXJDb2xvcnMocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIzMDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC44NSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gdHJhbnNwYXJlbnRpemUoMC41LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMCk7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaGFzRXJyb3IpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLmRhbmdlcjtcclxuICAgIH1cclxuICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDMwMDtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDUwMDtcclxufVxyXG5jb25zdCBTdHlsZWROYXRpdmVTZWxlY3QgPSBzdHlsZWQuc2VsZWN0IGBcbiAgJHtpbnB1dEJhc2VTdHlsZXN9O1xuICBoZWlnaHQ6IDM4cHg7XG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDh9O1xuICAvLyBSZXF1aXJlZCBmb3IgV2luZG93cyAmJiBDaHJvbWUgc3VwcG9ydFxuICBiYWNrZ3JvdW5kOiBpbmhlcml0O1xuICA+IG9wdGlvbiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDYwMCA6ICdub25lJ307XG4gIH1cbmA7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZChGb3JtRmllbGRDb250YWluZXIpIGBcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG5cbiAgJHtwcm9wcyA9PiBwcm9wcy5hZGRpdGlvbmFsQ29udGVudCAmJlxyXG4gICAgY3NzIGBcbiAgICAgIGZsZXg6IDE7XG4gICAgICBsYWJlbCB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgfVxuYDtcclxuY29uc3QgU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGxhYmVsIHtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAwO1xuICB9XG4gIGJ1dHRvbiB7XG4gICAgbWFyZ2luOiAwIDAgMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IE5hdGl2ZVNlbGVjdCA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWRkaXRpb25hbENvbnRlbnQsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZGlzYWJsZWQsIGVycm9yTWVzc2FnZSwgaWQ6IGRlZmF1bHRJZCwgaGVscGVyTWVzc2FnZSwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlLCBsYWJlbFRleHQsIGxhYmVsV2lkdGgsIG1lc3NhZ2VTdHlsZSwgdGVzdElkLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChkZWZhdWx0SWQpO1xyXG4gICAgY29uc3QgaGFzTGFiZWwgPSAhIWxhYmVsVGV4dDtcclxuICAgIGNvbnN0IG5hdGl2ZVNlbGVjdCA9IChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgeyBhZGRpdGlvbmFsQ29udGVudDogYWRkaXRpb25hbENvbnRlbnQsIGNvbnRhaW5lclN0eWxlOiBjb250YWluZXJTdHlsZSwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1mb3JtLWZpZWxkLWNvbnRhaW5lcmAsIGVycm9yTWVzc2FnZTogZXJyb3JNZXNzYWdlLCBmaWVsZElkOiBpZCwgaGFzTGFiZWw6ICEhbGFiZWxUZXh0LCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFN0eWxlOiBsYWJlbFN0eWxlLCBsYWJlbFRleHQ6IGxhYmVsUG9zaXRpb24gIT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICBsYWJlbFRleHQsXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiBhZGRpdGlvbmFsQ29udGVudCkpIDogKGxhYmVsVGV4dCksIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGgsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBoZWxwZXJNZXNzYWdlOiBoZWxwZXJNZXNzYWdlLCBtZXNzYWdlU3R5bGU6IG1lc3NhZ2VTdHlsZSwgcmVmOiByZWYgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIsIHsgZGlzYWJsZWQ6IGRpc2FibGVkLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3QsIE9iamVjdC5hc3NpZ24oeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBkaXNhYmxlZDogZGlzYWJsZWQsIGlkOiBpZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHRoZW1lOiB0aGVtZSB9LCBvdGhlciksIGNoaWxkcmVuKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEZWZhdWx0RHJvcGRvd25JbmRpY2F0b3IsIHsgZGlzYWJsZWQ6IGRpc2FibGVkIH0pKSkpO1xyXG4gICAgLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIEZvcm1GaWVsZENvbnRhaW5lciwgTmF0aXZlU2VsZWN0V3JhcHBlciwgYW5kIE5hdGl2ZVNlbGVjdCBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG4gICAgZnVuY3Rpb24gQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyKHByb3BzKSB7XHJcbiAgICAgICAgaWYgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCB8fFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi50b3AgJiYgIWhhc0xhYmVsKSkge1xyXG4gICAgICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogYCR7dGVzdElkfS1hZGRpdGlvbmFsLWNvbnRlbnQtd3JhcHBlcmAsIHRoZW1lOiB0aGVtZSB9LCBwcm9wcy5jaGlsZHJlbikpO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbiAgICB9XHJcbiAgICBpZiAoYWRkaXRpb25hbENvbnRlbnQpIHtcclxuICAgICAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkaXRpb25hbENvbnRlbnRXcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24gfSxcclxuICAgICAgICAgICAgbmF0aXZlU2VsZWN0LFxyXG4gICAgICAgICAgICAobGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ICYmIGFkZGl0aW9uYWxDb250ZW50KSB8fFxyXG4gICAgICAgICAgICAgICAgKCFsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSk7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICByZXR1cm4gbmF0aXZlU2VsZWN0O1xyXG4gICAgfVxyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9TmF0aXZlU2VsZWN0LmpzLm1hcCJdfQ== */",
|
|
6611
6612
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$e
|
|
6612
6613
|
};
|
|
6613
6614
|
var StyledFormFieldContainer$1 = /*#__PURE__*/_styled(FormFieldContainer, {
|
|
@@ -6617,7 +6618,7 @@ var StyledFormFieldContainer$1 = /*#__PURE__*/_styled(FormFieldContainer, {
|
|
|
6617
6618
|
return props.labelPosition === LabelPosition.left ? 'flex' : '';
|
|
6618
6619
|
}, ";", function (props) {
|
|
6619
6620
|
return props.additionalContent && _ref$3;
|
|
6620
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUQ0RCIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/
|
|
6621
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdUQ0RCIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApXHJcbiAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAtJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOH07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgei1pbmRleDogMTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gYm9yZGVyQ29sb3JzKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMzAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbn1cclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0ID0gc3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICBwYWRkaW5nLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgLy8gUmVxdWlyZWQgZm9yIFdpbmRvd3MgJiYgQ2hyb21lIHN1cHBvcnRcbiAgYmFja2dyb3VuZDogaW5oZXJpdDtcbiAgPiBvcHRpb24ge1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw2MDAgOiAnbm9uZSd9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRGb3JtRmllbGRDb250YWluZXIgPSBzdHlsZWQoRm9ybUZpZWxkQ29udGFpbmVyKSBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuYWRkaXRpb25hbENvbnRlbnQgJiZcclxuICAgIGNzcyBgXG4gICAgICBmbGV4OiAxO1xuICAgICAgbGFiZWwge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMDtcbiAgfVxuICBidXR0b24ge1xuICAgIG1hcmdpbjogMCAwIDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBOYXRpdmVTZWxlY3QgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGRpc2FibGVkLCBlcnJvck1lc3NhZ2UsIGlkOiBkZWZhdWx0SWQsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGhhc0xhYmVsID0gISFsYWJlbFRleHQ7XHJcbiAgICBjb25zdCBuYXRpdmVTZWxlY3QgPSAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIHsgYWRkaXRpb25hbENvbnRlbnQ6IGFkZGl0aW9uYWxDb250ZW50LCBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tZm9ybS1maWVsZC1jb250YWluZXJgLCBlcnJvck1lc3NhZ2U6IGVycm9yTWVzc2FnZSwgZmllbGRJZDogaWQsIGhhc0xhYmVsOiAhIWxhYmVsVGV4dCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSA6IChsYWJlbFRleHQpLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgbWVzc2FnZVN0eWxlOiBtZXNzYWdlU3R5bGUsIHJlZjogcmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3RXcmFwcGVyLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0LCBPYmplY3QuYXNzaWduKHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpZDogaWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgb3RoZXIpLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yLCB7IGRpc2FibGVkOiBkaXNhYmxlZCB9KSkpKTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBGb3JtRmllbGRDb250YWluZXIsIE5hdGl2ZVNlbGVjdFdyYXBwZXIsIGFuZCBOYXRpdmVTZWxlY3QgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24udG9wICYmICFoYXNMYWJlbCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBcImRhdGEtdGVzdGlkXCI6IGAke3Rlc3RJZH0tYWRkaXRpb25hbC1jb250ZW50LXdyYXBwZXJgLCB0aGVtZTogdGhlbWUgfSwgcHJvcHMuY2hpbGRyZW4pKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgaWYgKGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIG5hdGl2ZVNlbGVjdCxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgICAgICghbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgcmV0dXJuIG5hdGl2ZVNlbGVjdDtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPU5hdGl2ZVNlbGVjdC5qcy5tYXAiXX0= */"));
|
|
6621
6622
|
var StyledAdditionalContentWrapper = /*#__PURE__*/_styled("div", {
|
|
6622
6623
|
target: "ek9bqze0",
|
|
6623
6624
|
label: "StyledAdditionalContentWrapper"
|
|
@@ -6625,7 +6626,7 @@ var StyledAdditionalContentWrapper = /*#__PURE__*/_styled("div", {
|
|
|
6625
6626
|
return props.theme.spaceScale.spacing03;
|
|
6626
6627
|
}, " 0 0;}button{margin:0 0 0 ", function (props) {
|
|
6627
6628
|
return props.theme.spaceScale.spacing03;
|
|
6628
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0VrRCIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/
|
|
6629
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIk5hdGl2ZVNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0VrRCIsImZpbGUiOiJOYXRpdmVTZWxlY3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCB7IGlucHV0QmFzZVN0eWxlcywgaW5wdXRXcmFwcGVyU3R5bGVzIH0gZnJvbSAnLi4vSW5wdXRCYXNlJztcclxuaW1wb3J0IHsgRm9ybUZpZWxkQ29udGFpbmVyLCB9IGZyb20gJy4uL0Zvcm1GaWVsZENvbnRhaW5lcic7XHJcbmltcG9ydCB7IERlZmF1bHREcm9wZG93bkluZGljYXRvciB9IGZyb20gJy4uL1NlbGVjdC9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZUdlbmVyYXRlSWQgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZE5hdGl2ZVNlbGVjdFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgJHtpbnB1dFdyYXBwZXJTdHlsZXN9XG4gIGJvcmRlcjogMXB4IHNvbGlkICR7Ym9yZGVyQ29sb3JzfTtcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2UgJiYgcHJvcHMuZGlzYWJsZWRcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC42LCBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMClcclxuICAgIDogcHJvcHMuZGlzYWJsZWRcclxuICAgICAgICA/IHRyYW5zcGFyZW50aXplKDAuNCwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDApXHJcbiAgICAgICAgOiBwcm9wcy5pc0ludmVyc2VcclxuICAgICAgICAgICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgICAgICAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgICBtYXJnaW46IDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMCAtJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwOH07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgei1pbmRleDogMTtcbiAgfVxuYDtcclxuZnVuY3Rpb24gYm9yZGVyQ29sb3JzKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyMzAwO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuODUsIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXI7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuZGlzYWJsZWQpIHtcclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw1MDA7XHJcbn1cclxuY29uc3QgU3R5bGVkTmF0aXZlU2VsZWN0ID0gc3R5bGVkLnNlbGVjdCBgXG4gICR7aW5wdXRCYXNlU3R5bGVzfTtcbiAgaGVpZ2h0OiAzOHB4O1xuICBwYWRkaW5nLXJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA4fTtcbiAgLy8gUmVxdWlyZWQgZm9yIFdpbmRvd3MgJiYgQ2hyb21lIHN1cHBvcnRcbiAgYmFja2dyb3VuZDogaW5oZXJpdDtcbiAgPiBvcHRpb24ge1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw2MDAgOiAnbm9uZSd9O1xuICB9XG5gO1xyXG5jb25zdCBTdHlsZWRGb3JtRmllbGRDb250YWluZXIgPSBzdHlsZWQoRm9ybUZpZWxkQ29udGFpbmVyKSBgXG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuXG4gICR7cHJvcHMgPT4gcHJvcHMuYWRkaXRpb25hbENvbnRlbnQgJiZcclxuICAgIGNzcyBgXG4gICAgICBmbGV4OiAxO1xuICAgICAgbGFiZWwge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICB9XG4gICAgYH1cbmA7XHJcbmNvbnN0IFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBsYWJlbCB7XG4gICAgbWFyZ2luOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMDtcbiAgfVxuICBidXR0b24ge1xuICAgIG1hcmdpbjogMCAwIDAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBOYXRpdmVTZWxlY3QgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFkZGl0aW9uYWxDb250ZW50LCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGRpc2FibGVkLCBlcnJvck1lc3NhZ2UsIGlkOiBkZWZhdWx0SWQsIGhlbHBlck1lc3NhZ2UsIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBpZCA9IHVzZUdlbmVyYXRlSWQoZGVmYXVsdElkKTtcclxuICAgIGNvbnN0IGhhc0xhYmVsID0gISFsYWJlbFRleHQ7XHJcbiAgICBjb25zdCBuYXRpdmVTZWxlY3QgPSAoUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIHsgYWRkaXRpb25hbENvbnRlbnQ6IGFkZGl0aW9uYWxDb250ZW50LCBjb250YWluZXJTdHlsZTogY29udGFpbmVyU3R5bGUsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tZm9ybS1maWVsZC1jb250YWluZXJgLCBlcnJvck1lc3NhZ2U6IGVycm9yTWVzc2FnZSwgZmllbGRJZDogaWQsIGhhc0xhYmVsOiAhIWxhYmVsVGV4dCwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZTogbGFiZWxTdHlsZSwgbGFiZWxUZXh0OiBsYWJlbFBvc2l0aW9uICE9PSBMYWJlbFBvc2l0aW9uLmxlZnQgJiYgYWRkaXRpb25hbENvbnRlbnQgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgYWRkaXRpb25hbENvbnRlbnQpKSA6IChsYWJlbFRleHQpLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGVscGVyTWVzc2FnZTogaGVscGVyTWVzc2FnZSwgbWVzc2FnZVN0eWxlOiBtZXNzYWdlU3R5bGUsIHJlZjogcmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWROYXRpdmVTZWxlY3RXcmFwcGVyLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTmF0aXZlU2VsZWN0LCBPYmplY3QuYXNzaWduKHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGhhc0Vycm9yOiAhIWVycm9yTWVzc2FnZSwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpZDogaWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCB0aGVtZTogdGhlbWUgfSwgb3RoZXIpLCBjaGlsZHJlbiksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGVmYXVsdERyb3Bkb3duSW5kaWNhdG9yLCB7IGRpc2FibGVkOiBkaXNhYmxlZCB9KSkpKTtcclxuICAgIC8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBGb3JtRmllbGRDb250YWluZXIsIE5hdGl2ZVNlbGVjdFdyYXBwZXIsIGFuZCBOYXRpdmVTZWxlY3QgZm9yIHByb3BlciBzdHlsaW5nIGFsaWdubWVudC5cclxuICAgIGZ1bmN0aW9uIEFkZGl0aW9uYWxDb250ZW50V3JhcHBlcihwcm9wcykge1xyXG4gICAgICAgIGlmIChsYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgfHxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24udG9wICYmICFoYXNMYWJlbCkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBcImRhdGEtdGVzdGlkXCI6IGAke3Rlc3RJZH0tYWRkaXRpb25hbC1jb250ZW50LXdyYXBwZXJgLCB0aGVtZTogdGhlbWUgfSwgcHJvcHMuY2hpbGRyZW4pKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgaWYgKGFkZGl0aW9uYWxDb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFkZGl0aW9uYWxDb250ZW50V3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uIH0sXHJcbiAgICAgICAgICAgIG5hdGl2ZVNlbGVjdCxcclxuICAgICAgICAgICAgKGxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCAmJiBhZGRpdGlvbmFsQ29udGVudCkgfHxcclxuICAgICAgICAgICAgICAgICghbGFiZWxUZXh0ICYmIGFkZGl0aW9uYWxDb250ZW50KSkpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgcmV0dXJuIG5hdGl2ZVNlbGVjdDtcclxuICAgIH1cclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPU5hdGl2ZVNlbGVjdC5qcy5tYXAiXX0= */"));
|
|
6629
6630
|
var NativeSelect = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
6630
6631
|
var additionalContent = props.additionalContent,
|
|
6631
6632
|
children = props.children,
|
|
@@ -22410,7 +22411,7 @@ var StyledContainer$3 = /*#__PURE__*/_styled('div', {
|
|
|
22410
22411
|
return props.orientation === 'vertical' ? '100%' : 'auto';
|
|
22411
22412
|
}, ";position:relative;width:", function (props) {
|
|
22412
22413
|
return props.orientation === 'vertical' ? 'auto' : '100%';
|
|
22413
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AA2CG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    React.useEffect(scrollSelectedIntoView, []);\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22414
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AA2CG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22414
22415
|
var StyledTabsWrapper = /*#__PURE__*/_styled('div', {
|
|
22415
22416
|
shouldForwardProp: isPropValid,
|
|
22416
22417
|
target: "exr2c6p1",
|
|
@@ -22419,7 +22420,7 @@ var StyledTabsWrapper = /*#__PURE__*/_styled('div', {
|
|
|
22419
22420
|
return props.orientation === 'vertical' ? '' : 'auto';
|
|
22420
22421
|
}, ";overflow-y:", function (props) {
|
|
22421
22422
|
return props.orientation === 'vertical' ? 'auto' : '';
|
|
22422
|
-
}, ";&::-webkit-scrollbar{width:0;height:0;}scrollbar-width:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAsDG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    React.useEffect(scrollSelectedIntoView, []);\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22423
|
+
}, ";&::-webkit-scrollbar{width:0;height:0;}scrollbar-width:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAsDG","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22423
22424
|
var StyledTabs = /*#__PURE__*/_styled('ul', {
|
|
22424
22425
|
shouldForwardProp: isPropValid,
|
|
22425
22426
|
target: "exr2c6p0",
|
|
@@ -22430,7 +22431,7 @@ var StyledTabs = /*#__PURE__*/_styled('ul', {
|
|
|
22430
22431
|
return props.alignment === 'center' ? 'center' : props.alignment === 'right' ? 'flex-end' : '';
|
|
22431
22432
|
}, ";margin:0;padding:0;width:", function (props) {
|
|
22432
22433
|
return props.orientation === 'vertical' ? 'auto' : '100%';
|
|
22433
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAkE2E","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    React.useEffect(scrollSelectedIntoView, []);\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22434
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tabs.tsx"],"names":[],"mappings":"AAkE2E","file":"Tabs.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { TabsContainerContext } from './TabsContainer';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { omit, getNormalizedScrollLeft } from '../../utils';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonNext, ButtonPrev } from './TabsScrollButtons';\r\nimport { useTabsMeta } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { TabsOrientation, TabsTextTransform } from './shared';\r\nexport var TabsAlignment;\r\n(function (TabsAlignment) {\r\n    TabsAlignment[\"center\"] = \"center\";\r\n    TabsAlignment[\"left\"] = \"left\";\r\n    TabsAlignment[\"right\"] = \"right\";\r\n})(TabsAlignment || (TabsAlignment = {}));\r\nexport var TabsBorderPosition;\r\n(function (TabsBorderPosition) {\r\n    TabsBorderPosition[\"bottom\"] = \"bottom\";\r\n    TabsBorderPosition[\"left\"] = \"left\";\r\n    TabsBorderPosition[\"right\"] = \"right\";\r\n    TabsBorderPosition[\"top\"] = \"top\";\r\n})(TabsBorderPosition || (TabsBorderPosition = {}));\r\nexport var TabsIconPosition;\r\n(function (TabsIconPosition) {\r\n    TabsIconPosition[\"bottom\"] = \"bottom\";\r\n    TabsIconPosition[\"left\"] = \"left\";\r\n    TabsIconPosition[\"right\"] = \"right\";\r\n    TabsIconPosition[\"top\"] = \"top\";\r\n})(TabsIconPosition || (TabsIconPosition = {}));\r\nexport const TabsContext = React.createContext({\r\n    borderPosition: TabsBorderPosition.bottom,\r\n    changeHandler: () => { },\r\n    iconPosition: TabsIconPosition.left,\r\n    isInverse: false,\r\n    isFullWidth: false,\r\n    orientation: TabsOrientation.horizontal,\r\n    textTransform: TabsTextTransform.uppercase,\r\n    registerTabButton: (elements, element) => { },\r\n});\r\nexport const StyledContainer = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  background-color: ${props => props.backgroundColor ? props.backgroundColor : 'transparent'};\n  background: backgroundColor;\n  display: flex;\n  height: ${props => (props.orientation === 'vertical' ? '100%' : 'auto')};\n\n  position: relative;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const StyledTabsWrapper = styled('div', {\r\n    shouldForwardProp: isPropValid,\r\n}) `\n  display: flex;\n  flex-grow: 1;\n  overflow-x: ${props => (props.orientation === 'vertical' ? '' : 'auto')};\n  overflow-y: ${props => (props.orientation === 'vertical' ? 'auto' : '')};\n\n  &::-webkit-scrollbar {\n    width: 0;\n    height: 0;\n  }\n  scrollbar-width: none;\n`;\r\nexport const StyledTabs = styled('ul', { shouldForwardProp: isPropValid }) `\n  align-items: center;\n  display: flex;\n  flex-direction: ${props => props.orientation === 'vertical' ? 'column' : 'row'};\n  justify-content: ${props => props.alignment === 'center'\r\n    ? 'center'\r\n    : props.alignment === 'right'\r\n        ? 'flex-end'\r\n        : ''};\n  margin: 0;\n  padding: 0;\n  width: ${props => (props.orientation === 'vertical' ? 'auto' : '100%')};\n`;\r\nexport const Tabs = React.forwardRef((props, ref) => {\r\n    const { alignment, backgroundColor, borderPosition, children, isFullWidth, orientation, onChange, iconPosition, testId, textTransform, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const { activeTabIndex, setActiveTabIndex, isInverseContainer } = React.useContext(TabsContainerContext);\r\n    const isInverse = typeof props.isInverse !== 'undefined'\r\n        ? Boolean(props.isInverse)\r\n        : isInverseContainer;\r\n    const [tabsMeta, tabsHandleMethods, tabsRefs] = useTabsMeta(theme, orientation, backgroundColor, isInverse);\r\n    const { vertical, background, displayScroll, scrollStart } = tabsMeta;\r\n    const { handleStartScrollClick, handleEndScrollClick, handleTabsScroll, scroll, } = tabsHandleMethods;\r\n    const { prevButtonRef, nextButtonRef, tabsWrapperRef } = tabsRefs;\r\n    const start = vertical ? 'top' : 'left';\r\n    const end = vertical ? 'bottom' : 'right';\r\n    const [buttonRefArray, registerTabButton] = useDescendants();\r\n    const childrenWrapperRef = React.useRef();\r\n    function getTabsMeta() {\r\n        const tabsNode = tabsWrapperRef.current;\r\n        let tabsMeta;\r\n        if (tabsNode) {\r\n            const rect = tabsNode.getBoundingClientRect();\r\n            tabsMeta = {\r\n                clientWidth: tabsNode.clientWidth,\r\n                scrollLeft: tabsNode.scrollLeft,\r\n                scrollTop: tabsNode.scrollTop,\r\n                scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),\r\n                scrollWidth: tabsNode.scrollWidth,\r\n                top: rect.top,\r\n                bottom: rect.bottom,\r\n                left: rect.left,\r\n                right: rect.right,\r\n            };\r\n        }\r\n        let tabMeta;\r\n        if (tabsNode) {\r\n            const childrenArray = childrenWrapperRef.current.children;\r\n            if (childrenArray.length > 0) {\r\n                const tab = childrenArray[activeTabIndex];\r\n                tabMeta = tab ? tab.getBoundingClientRect() : null;\r\n            }\r\n        }\r\n        return { tabsMeta, tabMeta };\r\n    }\r\n    function scrollSelectedIntoView() {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const prevButtonOffset = vertical\r\n            ? Number(prevButtonRef.current.offsetHeight)\r\n            : Number(prevButtonRef.current.offsetWidth);\r\n        const nextButtonOffset = vertical\r\n            ? Number(nextButtonRef.current.offsetHeight)\r\n            : Number(nextButtonRef.current.offsetWidth);\r\n        if (tabMeta[start] < Number(tabsMeta[start]) + prevButtonOffset) {\r\n            // left side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[start]) - Number(tabsMeta[start])) -\r\n                prevButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n        else if (tabMeta[end] > Number(tabsMeta[end]) - nextButtonOffset) {\r\n            // right side of button is out of view\r\n            const nextScrollStart = Number(tabsMeta[scrollStart]) +\r\n                (Number(tabMeta[end]) - Number(tabsMeta[end])) +\r\n                nextButtonOffset;\r\n            scroll(nextScrollStart);\r\n        }\r\n    }\r\n    const scrollInitialActiveIndexIntoView = () => {\r\n        const { tabsMeta, tabMeta } = getTabsMeta();\r\n        if (!tabMeta || !tabsMeta) {\r\n            return;\r\n        }\r\n        const tabCenter = (tabMeta[start] + tabMeta[end]) / 2;\r\n        const containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;\r\n        const scrollDelta = tabCenter - containerCenter;\r\n        const nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;\r\n        scroll(nextScrollStart);\r\n    };\r\n    React.useEffect(scrollSelectedIntoView, [activeTabIndex]);\r\n    React.useEffect(scrollInitialActiveIndexIntoView, []);\r\n    function changeHandler(newActiveIndex, event) {\r\n        if (event.target.children[0] &&\r\n            event.target.children[0].hasAttribute('disabled')) {\r\n            event.preventDefault();\r\n            return undefined;\r\n        }\r\n        onChange && typeof onChange === 'function' && onChange(newActiveIndex);\r\n        newActiveIndex === activeTabIndex\r\n            ? scrollSelectedIntoView()\r\n            : setActiveTabIndex(newActiveIndex);\r\n    }\r\n    function tabIsEnabled(tabIndex) {\r\n        return (buttonRefArray.current[tabIndex].current.getAttribute('disabled') ===\r\n            null);\r\n    }\r\n    function findPreviousEnabledTabIndex(modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex > 0 ? currentTabIndex - 1 : 0;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex - 1 >= 0) {\r\n            return findPreviousEnabledTabIndex(newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function findNextEnabledTabIndex(lastChildIndex, modifiedActiveTabIndex) {\r\n        const currentTabIndex = modifiedActiveTabIndex === 0 || modifiedActiveTabIndex\r\n            ? modifiedActiveTabIndex\r\n            : activeTabIndex;\r\n        const newActiveTabIndex = currentTabIndex < lastChildIndex ? currentTabIndex + 1 : lastChildIndex;\r\n        if (tabIsEnabled(newActiveTabIndex)) {\r\n            return newActiveTabIndex;\r\n        }\r\n        else if (newActiveTabIndex + 1 <= lastChildIndex) {\r\n            return findNextEnabledTabIndex(lastChildIndex, newActiveTabIndex);\r\n        }\r\n        else {\r\n            return activeTabIndex;\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        const target = event.target;\r\n        const role = target.getAttribute('role');\r\n        if (role !== 'tab') {\r\n            return;\r\n        }\r\n        const lastChildIndex = buttonRefArray.current.length - 1;\r\n        let newActiveTabIndex = null;\r\n        let previousItemKey = orientation !== TabsOrientation.vertical ? 'ArrowLeft' : 'ArrowUp';\r\n        let nextItemKey = orientation !== TabsOrientation.vertical ? 'ArrowRight' : 'ArrowDown';\r\n        switch (event.key) {\r\n            case previousItemKey:\r\n                newActiveTabIndex = findPreviousEnabledTabIndex();\r\n                break;\r\n            case nextItemKey:\r\n                newActiveTabIndex = findNextEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            case 'Home':\r\n                newActiveTabIndex = tabIsEnabled(0)\r\n                    ? 0\r\n                    : findNextEnabledTabIndex(lastChildIndex, 0);\r\n                break;\r\n            case 'End':\r\n                newActiveTabIndex = tabIsEnabled(lastChildIndex)\r\n                    ? lastChildIndex\r\n                    : findPreviousEnabledTabIndex(lastChildIndex);\r\n                break;\r\n            default:\r\n                break;\r\n        }\r\n        if (newActiveTabIndex !== null) {\r\n            onChange &&\r\n                typeof onChange === 'function' &&\r\n                onChange(newActiveTabIndex);\r\n            setActiveTabIndex(newActiveTabIndex);\r\n            buttonRefArray.current[newActiveTabIndex].current.focus();\r\n            event.preventDefault();\r\n        }\r\n    }\r\n    const i18n = React.useContext(I18nContext);\r\n    const ariaLabel = `${rest['aria-label'] || ''}, ${orientation === TabsOrientation.vertical\r\n        ? i18n.tabs.verticalTabsInstructions\r\n        : i18n.tabs.horizontalTabsInstructions}`;\r\n    const other = omit(['aria-label'], rest);\r\n    return (React.createElement(StyledContainer, Object.assign({ \"data-testid\": testId, backgroundColor: background, isInverse: isInverse, orientation: orientation || TabsOrientation.horizontal, ref: ref, theme: theme }, other),\r\n        React.createElement(ButtonPrev, { backgroundColor: background, buttonVisible: displayScroll.start, isInverse: isInverse, onClick: handleStartScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: prevButtonRef, theme: theme }),\r\n        React.createElement(StyledTabsWrapper, { \"data-testid\": \"tabsWrapper\", onScroll: handleTabsScroll, orientation: orientation, ref: tabsWrapperRef },\r\n            React.createElement(StyledTabs, { alignment: alignment ? alignment : TabsAlignment.left, \"aria-label\": ariaLabel, \"aria-orientation\": orientation || TabsOrientation.horizontal, onKeyDown: handleKeyDown, orientation: orientation, ref: childrenWrapperRef, role: \"tablist\" },\r\n                React.createElement(TabsContext.Provider, { value: {\r\n                        borderPosition,\r\n                        buttonRefArray,\r\n                        changeHandler,\r\n                        iconPosition,\r\n                        isInverse,\r\n                        isFullWidth,\r\n                        orientation,\r\n                        textTransform: textTransform || TabsTextTransform.uppercase,\r\n                        registerTabButton,\r\n                    } }, children))),\r\n        React.createElement(ButtonNext, { backgroundColor: background, buttonVisible: displayScroll.end, isInverse: isInverse, onClick: handleEndScrollClick, orientation: orientation || TabsOrientation.horizontal, ref: nextButtonRef, theme: theme })));\r\n});\r\n//# sourceMappingURL=Tabs.js.map"]} */"));
|
|
22434
22435
|
var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
|
|
22435
22436
|
var alignment = props.alignment,
|
|
22436
22437
|
backgroundColor = props.backgroundColor,
|
|
@@ -22519,8 +22520,21 @@ var Tabs = /*#__PURE__*/React__default.forwardRef(function (props, ref) {
|
|
|
22519
22520
|
scroll(_nextScrollStart);
|
|
22520
22521
|
}
|
|
22521
22522
|
}
|
|
22522
|
-
|
|
22523
|
+
var scrollInitialActiveIndexIntoView = function scrollInitialActiveIndexIntoView() {
|
|
22524
|
+
var _getTabsMeta2 = getTabsMeta(),
|
|
22525
|
+
tabsMeta = _getTabsMeta2.tabsMeta,
|
|
22526
|
+
tabMeta = _getTabsMeta2.tabMeta;
|
|
22527
|
+
if (!tabMeta || !tabsMeta) {
|
|
22528
|
+
return;
|
|
22529
|
+
}
|
|
22530
|
+
var tabCenter = (tabMeta[start] + tabMeta[end]) / 2;
|
|
22531
|
+
var containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;
|
|
22532
|
+
var scrollDelta = tabCenter - containerCenter;
|
|
22533
|
+
var nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;
|
|
22534
|
+
scroll(nextScrollStart);
|
|
22535
|
+
};
|
|
22523
22536
|
React__default.useEffect(scrollSelectedIntoView, [activeTabIndex]);
|
|
22537
|
+
React__default.useEffect(scrollInitialActiveIndexIntoView, []);
|
|
22524
22538
|
function changeHandler(newActiveIndex, event) {
|
|
22525
22539
|
if (event.target.children[0] && event.target.children[0].hasAttribute('disabled')) {
|
|
22526
22540
|
event.preventDefault();
|
|
@@ -23149,14 +23163,19 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
23149
23163
|
tabsMeta = _useTabsMeta[0],
|
|
23150
23164
|
tabsHandleMethods = _useTabsMeta[1],
|
|
23151
23165
|
tabsRefs = _useTabsMeta[2];
|
|
23152
|
-
var displayScroll = tabsMeta.displayScroll
|
|
23166
|
+
var displayScroll = tabsMeta.displayScroll,
|
|
23167
|
+
scrollStart = tabsMeta.scrollStart;
|
|
23168
|
+
var _React$useContext = useContext(TabsContainerContext),
|
|
23169
|
+
activeTabIndex = _React$useContext.activeTabIndex;
|
|
23153
23170
|
var handleStartScrollClick = tabsHandleMethods.handleStartScrollClick,
|
|
23154
23171
|
handleEndScrollClick = tabsHandleMethods.handleEndScrollClick,
|
|
23155
|
-
handleTabsScroll = tabsHandleMethods.handleTabsScroll
|
|
23172
|
+
handleTabsScroll = tabsHandleMethods.handleTabsScroll,
|
|
23173
|
+
scroll = tabsHandleMethods.scroll;
|
|
23156
23174
|
var prevButtonRef = tabsRefs.prevButtonRef,
|
|
23157
23175
|
nextButtonRef = tabsRefs.nextButtonRef,
|
|
23158
23176
|
tabsWrapperRef = tabsRefs.tabsWrapperRef;
|
|
23159
23177
|
var navTabChildren = Children.toArray(children);
|
|
23178
|
+
var childrenWrapperRef = useRef();
|
|
23160
23179
|
var hasChildFocus = navTabChildren.some(function (child) {
|
|
23161
23180
|
if (isValidElement(child)) {
|
|
23162
23181
|
return Object.keys(child.props).includes('isFocused');
|
|
@@ -23173,6 +23192,52 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
23173
23192
|
}
|
|
23174
23193
|
return child;
|
|
23175
23194
|
});
|
|
23195
|
+
function getTabsMeta() {
|
|
23196
|
+
var tabsNode = tabsWrapperRef.current;
|
|
23197
|
+
var tabsMeta;
|
|
23198
|
+
if (tabsNode) {
|
|
23199
|
+
var rect = tabsNode.getBoundingClientRect();
|
|
23200
|
+
tabsMeta = {
|
|
23201
|
+
clientWidth: tabsNode.clientWidth,
|
|
23202
|
+
scrollLeft: tabsNode.scrollLeft,
|
|
23203
|
+
scrollTop: tabsNode.scrollTop,
|
|
23204
|
+
scrollLeftNormalized: getNormalizedScrollLeft(tabsNode, theme.direction),
|
|
23205
|
+
scrollWidth: tabsNode.scrollWidth,
|
|
23206
|
+
top: rect.top,
|
|
23207
|
+
bottom: rect.bottom,
|
|
23208
|
+
left: rect.left,
|
|
23209
|
+
right: rect.right
|
|
23210
|
+
};
|
|
23211
|
+
}
|
|
23212
|
+
var tabMeta;
|
|
23213
|
+
if (tabsNode) {
|
|
23214
|
+
var childrenArray = childrenWrapperRef.current.children;
|
|
23215
|
+
if (childrenArray.length > 0) {
|
|
23216
|
+
var tab = childrenArray[activeTabIndex];
|
|
23217
|
+
tabMeta = tab ? tab.getBoundingClientRect() : null;
|
|
23218
|
+
}
|
|
23219
|
+
}
|
|
23220
|
+
return {
|
|
23221
|
+
tabsMeta: tabsMeta,
|
|
23222
|
+
tabMeta: tabMeta
|
|
23223
|
+
};
|
|
23224
|
+
}
|
|
23225
|
+
var scrollInitialActiveIndexIntoView = function scrollInitialActiveIndexIntoView() {
|
|
23226
|
+
var _getTabsMeta = getTabsMeta(),
|
|
23227
|
+
tabsMeta = _getTabsMeta.tabsMeta,
|
|
23228
|
+
tabMeta = _getTabsMeta.tabMeta;
|
|
23229
|
+
if (!tabMeta || !tabsMeta) {
|
|
23230
|
+
return;
|
|
23231
|
+
}
|
|
23232
|
+
var start = orientation === TabsOrientation.vertical ? 'top' : 'left';
|
|
23233
|
+
var end = orientation === TabsOrientation.vertical ? 'bottom' : 'right';
|
|
23234
|
+
var tabCenter = (tabMeta[start] + tabMeta[end]) / 2;
|
|
23235
|
+
var containerCenter = (tabsMeta[start] + tabsMeta[end]) / 2;
|
|
23236
|
+
var scrollDelta = tabCenter - containerCenter;
|
|
23237
|
+
var nextScrollStart = Number(tabsMeta[scrollStart]) + scrollDelta;
|
|
23238
|
+
scroll(nextScrollStart);
|
|
23239
|
+
};
|
|
23240
|
+
useEffect(scrollInitialActiveIndexIntoView, []);
|
|
23176
23241
|
return createElement(StyledContainer$3, Object.assign({
|
|
23177
23242
|
"aria-label": rest['aria-label'],
|
|
23178
23243
|
as: "nav",
|
|
@@ -23197,7 +23262,8 @@ var NavTabs = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
23197
23262
|
ref: tabsWrapperRef
|
|
23198
23263
|
}, createElement(StyledTabs, {
|
|
23199
23264
|
alignment: alignment ? alignment : TabsAlignment.left,
|
|
23200
|
-
orientation: orientation
|
|
23265
|
+
orientation: orientation,
|
|
23266
|
+
ref: childrenWrapperRef
|
|
23201
23267
|
}, createElement(NavTabsContext.Provider, {
|
|
23202
23268
|
value: {
|
|
23203
23269
|
borderPosition: borderPosition,
|
|
@@ -23746,11 +23812,11 @@ var RadioTextPosition;
|
|
|
23746
23812
|
var HiddenLabelText$1 = /*#__PURE__*/_styled("span", {
|
|
23747
23813
|
target: "ex21ne2",
|
|
23748
23814
|
label: "HiddenLabelText"
|
|
23749
|
-
})(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23815
|
+
})(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQm9DIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgRGlzcGxheUlucHV0U3R5bGVzLCBEaXNwbGF5SW5wdXRBY3RpdmVTdHlsZXMsIGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZCwgYnVpbGREaXNwbGF5SW5wdXRGb2N1c1N0eWxlcywgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9JbnB1dFN0eWxlcyc7XHJcbmltcG9ydCB7IEhpZGRlblN0eWxlcyB9IGZyb20gJy4uLy4uL3V0aWxzL1V0aWxpdHlTdHlsZXMnO1xyXG5pbXBvcnQgeyBSYWRpb0NvbnRleHQgfSBmcm9tICcuLi9SYWRpb0dyb3VwJztcclxuaW1wb3J0IHsgUmFkaW9CdXR0b25DaGVja2VkSWNvbiwgUmFkaW9CdXR0b25VbmNoZWNrZWRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9TdHlsZWRMYWJlbCc7XHJcbmltcG9ydCB7IFN0eWxlZENvbnRhaW5lciB9IGZyb20gJy4uL1NlbGVjdGlvbkNvbnRyb2xzL1N0eWxlZENvbnRhaW5lcic7XHJcbi8vIFVzaW5nIHRoZSBiYXNlIGBzdHlsZWRgIGZyb20gYGVtb3Rpb25gIHVudGlsIGltcG9ydCBtYXBwaW5nIGlzIGZpeGVkOiBodHRwczovL2dpdGh1Yi5jb20vZW1vdGlvbi1qcy9lbW90aW9uL3B1bGwvMTIyMFxyXG4vLyBpbXBvcnQgc3R5bGVkIGZyb20gJy4uLy4uL3RoZW1lL3N0eWxlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmV4cG9ydCB2YXIgUmFkaW9UZXh0UG9zaXRpb247XHJcbihmdW5jdGlvbiAoUmFkaW9UZXh0UG9zaXRpb24pIHtcclxuICAgIFJhZGlvVGV4dFBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgUmFkaW9UZXh0UG9zaXRpb25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoUmFkaW9UZXh0UG9zaXRpb24gfHwgKFJhZGlvVGV4dFBvc2l0aW9uID0ge30pKTtcclxuY29uc3QgSGlkZGVuTGFiZWxUZXh0ID0gc3R5bGVkLnNwYW4gYFxuICAke0hpZGRlblN0eWxlc307XG5gO1xyXG5jb25zdCBIaWRkZW5JbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7SGlkZGVuU3R5bGVzfTtcbmA7XHJcbmZ1bmN0aW9uIGJ1aWxkUmFkaW9JY29uQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNiwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmlzQ2hlY2tlZCkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy5jb2xvcjtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMDtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRFcnJvckJvcmRlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gYDAgMCAwIDJweCAke3Byb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIzMDB9YDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIGAwIDAgMCAycHggJHtwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gYGluaGVyaXRgO1xyXG59XHJcbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5zcGFuIGBcbiAgJHtEaXNwbGF5SW5wdXRTdHlsZXN9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZFJhZGlvSWNvbkNvbG9yKHByb3BzKX07XG4gIGN1cnNvcjogJHtwcm9wcyA9PiAocHJvcHMuZGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInKX07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy50ZXh0UG9zaXRpb24gPT09ICdsZWZ0J1xyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6IGAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMGB9O1xuICBib3gtc2hhZG93OiAke2J1aWxkRXJyb3JCb3JkZXJ9O1xuXG4gICR7SGlkZGVuSW5wdXR9OmNoZWNrZWQ6bm90ICg6ZGlzYWJsZWQpICsgbGFiZWwgJiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG59fTtcbiAgfVxuXG4gICR7SGlkZGVuSW5wdXR9OmZvY3VzICsgbGFiZWwgJiB7XG4gICAgLy8gZm9jdXMgc3RhdGVcbiAgICAmOmJlZm9yZSB7XG4gICAgICAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0Rm9jdXNTdHlsZXMocHJvcHMpfTtcbiAgICB9XG4gIH1cblxuICAmOmFmdGVyIHtcbiAgICAvLyBhY3RpdmUgc3RhdGVcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZChwcm9wcyl9O1xuICB9XG5cbiAgJHtIaWRkZW5JbnB1dH06bm90KDpkaXNhYmxlZCk6YWN0aXZlICsgbGFiZWwgJiB7XG4gICAgJjphZnRlciB7XG4gICAgICAke0Rpc3BsYXlJbnB1dEFjdGl2ZVN0eWxlc31cbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBSYWRpbyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChwcm9wcy5pZCk7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChSYWRpb0NvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCB7IGNvbG9yID0gdGhlbWUuY29sb3JzLnByaW1hcnksIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgaW5wdXRTdHlsZSwgaXNJbnZlcnNlLCBpc1RleHRWaXN1YWxseUhpZGRlbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCByZXF1aXJlZCwgdGVzdElkLCB0ZXh0UG9zaXRpb24sIHZhbHVlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ29udGFpbmVyLCB7IHN0eWxlOiBjb250YWluZXJTdHlsZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaWQ6IGlkLCByZWY6IHJlZiwgY2hlY2tlZDogY29udGV4dC5zZWxlY3RlZFZhbHVlID09PSB2YWx1ZSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGRpc2FibGVkOiBkaXNhYmxlZCwgbmFtZTogY29udGV4dC5uYW1lLCByZXF1aXJlZDogY29udGV4dC5yZXF1aXJlZCB8fCByZXF1aXJlZCwgdHlwZTogXCJyYWRpb1wiLCB2YWx1ZTogdmFsdWUsIG9uQmx1cjogY29udGV4dC5vbkJsdXIsIG9uQ2hhbmdlOiBjb250ZXh0Lm9uQ2hhbmdlLCBvbkZvY3VzOiBjb250ZXh0Lm9uRm9jdXMgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGFiZWwsIHsgaHRtbEZvcjogaWQsIGlzSW52ZXJzZTogY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlLCBzdHlsZTogbGFiZWxTdHlsZSB9LFxyXG4gICAgICAgICAgICAhaXNUZXh0VmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgICAgIHRleHRQb3NpdGlvbiA9PT0gUmFkaW9UZXh0UG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZha2VJbnB1dCwgeyBpc0NoZWNrZWQ6IGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUsIGNvbG9yOiBjb2xvciwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlIHx8IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGNvbnRleHQuaGFzRXJyb3IsIHN0eWxlOiBpbnB1dFN0eWxlLCB0ZXh0UG9zaXRpb246IHRleHRQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvbkNoZWNrZWRJY29uLCBudWxsKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvblVuY2hlY2tlZEljb24sIG51bGwpKSksXHJcbiAgICAgICAgICAgIGlzVGV4dFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuTGFiZWxUZXh0LCBudWxsLCBsYWJlbFRleHQpKSA6ICh0ZXh0UG9zaXRpb24gIT09IFJhZGlvVGV4dFBvc2l0aW9uLmxlZnQgJiYgbGFiZWxUZXh0ICYmIGxhYmVsVGV4dCkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
|
|
23750
23816
|
var HiddenInput$1 = /*#__PURE__*/_styled("input", {
|
|
23751
23817
|
target: "ex21ne1",
|
|
23752
23818
|
label: "HiddenInput"
|
|
23753
|
-
})(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23819
|
+
})(HiddenStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQmlDIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgRGlzcGxheUlucHV0U3R5bGVzLCBEaXNwbGF5SW5wdXRBY3RpdmVTdHlsZXMsIGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZCwgYnVpbGREaXNwbGF5SW5wdXRGb2N1c1N0eWxlcywgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9JbnB1dFN0eWxlcyc7XHJcbmltcG9ydCB7IEhpZGRlblN0eWxlcyB9IGZyb20gJy4uLy4uL3V0aWxzL1V0aWxpdHlTdHlsZXMnO1xyXG5pbXBvcnQgeyBSYWRpb0NvbnRleHQgfSBmcm9tICcuLi9SYWRpb0dyb3VwJztcclxuaW1wb3J0IHsgUmFkaW9CdXR0b25DaGVja2VkSWNvbiwgUmFkaW9CdXR0b25VbmNoZWNrZWRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9TdHlsZWRMYWJlbCc7XHJcbmltcG9ydCB7IFN0eWxlZENvbnRhaW5lciB9IGZyb20gJy4uL1NlbGVjdGlvbkNvbnRyb2xzL1N0eWxlZENvbnRhaW5lcic7XHJcbi8vIFVzaW5nIHRoZSBiYXNlIGBzdHlsZWRgIGZyb20gYGVtb3Rpb25gIHVudGlsIGltcG9ydCBtYXBwaW5nIGlzIGZpeGVkOiBodHRwczovL2dpdGh1Yi5jb20vZW1vdGlvbi1qcy9lbW90aW9uL3B1bGwvMTIyMFxyXG4vLyBpbXBvcnQgc3R5bGVkIGZyb20gJy4uLy4uL3RoZW1lL3N0eWxlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmV4cG9ydCB2YXIgUmFkaW9UZXh0UG9zaXRpb247XHJcbihmdW5jdGlvbiAoUmFkaW9UZXh0UG9zaXRpb24pIHtcclxuICAgIFJhZGlvVGV4dFBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgUmFkaW9UZXh0UG9zaXRpb25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoUmFkaW9UZXh0UG9zaXRpb24gfHwgKFJhZGlvVGV4dFBvc2l0aW9uID0ge30pKTtcclxuY29uc3QgSGlkZGVuTGFiZWxUZXh0ID0gc3R5bGVkLnNwYW4gYFxuICAke0hpZGRlblN0eWxlc307XG5gO1xyXG5jb25zdCBIaWRkZW5JbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7SGlkZGVuU3R5bGVzfTtcbmA7XHJcbmZ1bmN0aW9uIGJ1aWxkUmFkaW9JY29uQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNiwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmlzQ2hlY2tlZCkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy5jb2xvcjtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMDtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRFcnJvckJvcmRlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gYDAgMCAwIDJweCAke3Byb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIzMDB9YDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIGAwIDAgMCAycHggJHtwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gYGluaGVyaXRgO1xyXG59XHJcbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5zcGFuIGBcbiAgJHtEaXNwbGF5SW5wdXRTdHlsZXN9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZFJhZGlvSWNvbkNvbG9yKHByb3BzKX07XG4gIGN1cnNvcjogJHtwcm9wcyA9PiAocHJvcHMuZGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInKX07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy50ZXh0UG9zaXRpb24gPT09ICdsZWZ0J1xyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6IGAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMGB9O1xuICBib3gtc2hhZG93OiAke2J1aWxkRXJyb3JCb3JkZXJ9O1xuXG4gICR7SGlkZGVuSW5wdXR9OmNoZWNrZWQ6bm90ICg6ZGlzYWJsZWQpICsgbGFiZWwgJiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG59fTtcbiAgfVxuXG4gICR7SGlkZGVuSW5wdXR9OmZvY3VzICsgbGFiZWwgJiB7XG4gICAgLy8gZm9jdXMgc3RhdGVcbiAgICAmOmJlZm9yZSB7XG4gICAgICAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0Rm9jdXNTdHlsZXMocHJvcHMpfTtcbiAgICB9XG4gIH1cblxuICAmOmFmdGVyIHtcbiAgICAvLyBhY3RpdmUgc3RhdGVcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZChwcm9wcyl9O1xuICB9XG5cbiAgJHtIaWRkZW5JbnB1dH06bm90KDpkaXNhYmxlZCk6YWN0aXZlICsgbGFiZWwgJiB7XG4gICAgJjphZnRlciB7XG4gICAgICAke0Rpc3BsYXlJbnB1dEFjdGl2ZVN0eWxlc31cbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBSYWRpbyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChwcm9wcy5pZCk7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChSYWRpb0NvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCB7IGNvbG9yID0gdGhlbWUuY29sb3JzLnByaW1hcnksIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgaW5wdXRTdHlsZSwgaXNJbnZlcnNlLCBpc1RleHRWaXN1YWxseUhpZGRlbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCByZXF1aXJlZCwgdGVzdElkLCB0ZXh0UG9zaXRpb24sIHZhbHVlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ29udGFpbmVyLCB7IHN0eWxlOiBjb250YWluZXJTdHlsZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaWQ6IGlkLCByZWY6IHJlZiwgY2hlY2tlZDogY29udGV4dC5zZWxlY3RlZFZhbHVlID09PSB2YWx1ZSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGRpc2FibGVkOiBkaXNhYmxlZCwgbmFtZTogY29udGV4dC5uYW1lLCByZXF1aXJlZDogY29udGV4dC5yZXF1aXJlZCB8fCByZXF1aXJlZCwgdHlwZTogXCJyYWRpb1wiLCB2YWx1ZTogdmFsdWUsIG9uQmx1cjogY29udGV4dC5vbkJsdXIsIG9uQ2hhbmdlOiBjb250ZXh0Lm9uQ2hhbmdlLCBvbkZvY3VzOiBjb250ZXh0Lm9uRm9jdXMgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGFiZWwsIHsgaHRtbEZvcjogaWQsIGlzSW52ZXJzZTogY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlLCBzdHlsZTogbGFiZWxTdHlsZSB9LFxyXG4gICAgICAgICAgICAhaXNUZXh0VmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgICAgIHRleHRQb3NpdGlvbiA9PT0gUmFkaW9UZXh0UG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZha2VJbnB1dCwgeyBpc0NoZWNrZWQ6IGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUsIGNvbG9yOiBjb2xvciwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlIHx8IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGNvbnRleHQuaGFzRXJyb3IsIHN0eWxlOiBpbnB1dFN0eWxlLCB0ZXh0UG9zaXRpb246IHRleHRQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvbkNoZWNrZWRJY29uLCBudWxsKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvblVuY2hlY2tlZEljb24sIG51bGwpKSksXHJcbiAgICAgICAgICAgIGlzVGV4dFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuTGFiZWxUZXh0LCBudWxsLCBsYWJlbFRleHQpKSA6ICh0ZXh0UG9zaXRpb24gIT09IFJhZGlvVGV4dFBvc2l0aW9uLmxlZnQgJiYgbGFiZWxUZXh0ICYmIGxhYmVsVGV4dCkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
|
|
23754
23820
|
function buildRadioIconColor(props) {
|
|
23755
23821
|
if (props.disabled) {
|
|
23756
23822
|
if (props.isInverse) {
|
|
@@ -23769,7 +23835,7 @@ function buildRadioIconColor(props) {
|
|
|
23769
23835
|
function buildErrorBorder(props) {
|
|
23770
23836
|
if (props.hasError) {
|
|
23771
23837
|
if (props.isInverse) {
|
|
23772
|
-
return "0 0 0 2px " + props.theme.colors.
|
|
23838
|
+
return "0 0 0 2px " + props.theme.colors.danger300;
|
|
23773
23839
|
}
|
|
23774
23840
|
return "0 0 0 2px " + props.theme.colors.danger;
|
|
23775
23841
|
}
|
|
@@ -23792,7 +23858,7 @@ var StyledFakeInput$1 = /*#__PURE__*/_styled("span", {
|
|
|
23792
23858
|
return buildDisplayInputFocusStyles(props);
|
|
23793
23859
|
}, ";}}&:after{background:", function (props) {
|
|
23794
23860
|
return buildDisplayInputActiveBackground(props);
|
|
23795
|
-
}, ";}", HiddenInput$1, ":not(:disabled):active+label &{&:after{", DisplayInputActiveStyles, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23861
|
+
}, ";}", HiddenInput$1, ":not(:disabled):active+label &{&:after{", DisplayInputActiveStyles, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRG9DIiwiZmlsZSI6ImluZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgRGlzcGxheUlucHV0U3R5bGVzLCBEaXNwbGF5SW5wdXRBY3RpdmVTdHlsZXMsIGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZCwgYnVpbGREaXNwbGF5SW5wdXRGb2N1c1N0eWxlcywgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9JbnB1dFN0eWxlcyc7XHJcbmltcG9ydCB7IEhpZGRlblN0eWxlcyB9IGZyb20gJy4uLy4uL3V0aWxzL1V0aWxpdHlTdHlsZXMnO1xyXG5pbXBvcnQgeyBSYWRpb0NvbnRleHQgfSBmcm9tICcuLi9SYWRpb0dyb3VwJztcclxuaW1wb3J0IHsgUmFkaW9CdXR0b25DaGVja2VkSWNvbiwgUmFkaW9CdXR0b25VbmNoZWNrZWRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgU3R5bGVkTGFiZWwgfSBmcm9tICcuLi9TZWxlY3Rpb25Db250cm9scy9TdHlsZWRMYWJlbCc7XHJcbmltcG9ydCB7IFN0eWxlZENvbnRhaW5lciB9IGZyb20gJy4uL1NlbGVjdGlvbkNvbnRyb2xzL1N0eWxlZENvbnRhaW5lcic7XHJcbi8vIFVzaW5nIHRoZSBiYXNlIGBzdHlsZWRgIGZyb20gYGVtb3Rpb25gIHVudGlsIGltcG9ydCBtYXBwaW5nIGlzIGZpeGVkOiBodHRwczovL2dpdGh1Yi5jb20vZW1vdGlvbi1qcy9lbW90aW9uL3B1bGwvMTIyMFxyXG4vLyBpbXBvcnQgc3R5bGVkIGZyb20gJy4uLy4uL3RoZW1lL3N0eWxlZCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlR2VuZXJhdGVJZCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgdHJhbnNwYXJlbnRpemUgfSBmcm9tICdwb2xpc2hlZCc7XHJcbmV4cG9ydCB2YXIgUmFkaW9UZXh0UG9zaXRpb247XHJcbihmdW5jdGlvbiAoUmFkaW9UZXh0UG9zaXRpb24pIHtcclxuICAgIFJhZGlvVGV4dFBvc2l0aW9uW1wibGVmdFwiXSA9IFwibGVmdFwiO1xyXG4gICAgUmFkaW9UZXh0UG9zaXRpb25bXCJyaWdodFwiXSA9IFwicmlnaHRcIjtcclxufSkoUmFkaW9UZXh0UG9zaXRpb24gfHwgKFJhZGlvVGV4dFBvc2l0aW9uID0ge30pKTtcclxuY29uc3QgSGlkZGVuTGFiZWxUZXh0ID0gc3R5bGVkLnNwYW4gYFxuICAke0hpZGRlblN0eWxlc307XG5gO1xyXG5jb25zdCBIaWRkZW5JbnB1dCA9IHN0eWxlZC5pbnB1dCBgXG4gICR7SGlkZGVuU3R5bGVzfTtcbmA7XHJcbmZ1bmN0aW9uIGJ1aWxkUmFkaW9JY29uQ29sb3IocHJvcHMpIHtcclxuICAgIGlmIChwcm9wcy5kaXNhYmxlZCkge1xyXG4gICAgICAgIGlmIChwcm9wcy5pc0ludmVyc2UpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRyYW5zcGFyZW50aXplKDAuNiwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwzMDA7XHJcbiAgICB9XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG4gICAgaWYgKHByb3BzLmlzQ2hlY2tlZCkge1xyXG4gICAgICAgIHJldHVybiBwcm9wcy5jb2xvcjtcclxuICAgIH1cclxuICAgIHJldHVybiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMDtcclxufVxyXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRFcnJvckJvcmRlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmhhc0Vycm9yKSB7XHJcbiAgICAgICAgaWYgKHByb3BzLmlzSW52ZXJzZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gYDAgMCAwIDJweCAke3Byb3BzLnRoZW1lLmNvbG9ycy5kYW5nZXIzMDB9YDtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIGAwIDAgMCAycHggJHtwcm9wcy50aGVtZS5jb2xvcnMuZGFuZ2VyfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gYGluaGVyaXRgO1xyXG59XHJcbmNvbnN0IFN0eWxlZEZha2VJbnB1dCA9IHN0eWxlZC5zcGFuIGBcbiAgJHtEaXNwbGF5SW5wdXRTdHlsZXN9O1xuICBjb2xvcjogJHtwcm9wcyA9PiBidWlsZFJhZGlvSWNvbkNvbG9yKHByb3BzKX07XG4gIGN1cnNvcjogJHtwcm9wcyA9PiAocHJvcHMuZGlzYWJsZWQgPyAnbm90LWFsbG93ZWQnIDogJ3BvaW50ZXInKX07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBwcm9wcy50ZXh0UG9zaXRpb24gPT09ICdsZWZ0J1xyXG4gICAgPyBgMCAwIDAgJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gXHJcbiAgICA6IGAwICR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDAgMGB9O1xuICBib3gtc2hhZG93OiAke2J1aWxkRXJyb3JCb3JkZXJ9O1xuXG4gICR7SGlkZGVuSW5wdXR9OmNoZWNrZWQ6bm90ICg6ZGlzYWJsZWQpICsgbGFiZWwgJiB7XG4gICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiB7XHJcbiAgICBpZiAocHJvcHMuaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwO1xyXG4gICAgfVxyXG59fTtcbiAgfVxuXG4gICR7SGlkZGVuSW5wdXR9OmZvY3VzICsgbGFiZWwgJiB7XG4gICAgLy8gZm9jdXMgc3RhdGVcbiAgICAmOmJlZm9yZSB7XG4gICAgICAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0Rm9jdXNTdHlsZXMocHJvcHMpfTtcbiAgICB9XG4gIH1cblxuICAmOmFmdGVyIHtcbiAgICAvLyBhY3RpdmUgc3RhdGVcbiAgICBiYWNrZ3JvdW5kOiAke3Byb3BzID0+IGJ1aWxkRGlzcGxheUlucHV0QWN0aXZlQmFja2dyb3VuZChwcm9wcyl9O1xuICB9XG5cbiAgJHtIaWRkZW5JbnB1dH06bm90KDpkaXNhYmxlZCk6YWN0aXZlICsgbGFiZWwgJiB7XG4gICAgJjphZnRlciB7XG4gICAgICAke0Rpc3BsYXlJbnB1dEFjdGl2ZVN0eWxlc31cbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBSYWRpbyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IGlkID0gdXNlR2VuZXJhdGVJZChwcm9wcy5pZCk7XHJcbiAgICBjb25zdCBjb250ZXh0ID0gUmVhY3QudXNlQ29udGV4dChSYWRpb0NvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCB7IGNvbG9yID0gdGhlbWUuY29sb3JzLnByaW1hcnksIGNvbnRhaW5lclN0eWxlLCBkaXNhYmxlZCwgaW5wdXRTdHlsZSwgaXNJbnZlcnNlLCBpc1RleHRWaXN1YWxseUhpZGRlbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCByZXF1aXJlZCwgdGVzdElkLCB0ZXh0UG9zaXRpb24sIHZhbHVlLCAuLi5vdGhlciB9ID0gcHJvcHM7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ29udGFpbmVyLCB7IHN0eWxlOiBjb250YWluZXJTdHlsZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuSW5wdXQsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGNvbnRleHQuZGVzY3JpcHRpb25JZCwgaWQ6IGlkLCByZWY6IHJlZiwgY2hlY2tlZDogY29udGV4dC5zZWxlY3RlZFZhbHVlID09PSB2YWx1ZSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGRpc2FibGVkOiBkaXNhYmxlZCwgbmFtZTogY29udGV4dC5uYW1lLCByZXF1aXJlZDogY29udGV4dC5yZXF1aXJlZCB8fCByZXF1aXJlZCwgdHlwZTogXCJyYWRpb1wiLCB2YWx1ZTogdmFsdWUsIG9uQmx1cjogY29udGV4dC5vbkJsdXIsIG9uQ2hhbmdlOiBjb250ZXh0Lm9uQ2hhbmdlLCBvbkZvY3VzOiBjb250ZXh0Lm9uRm9jdXMgfSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGFiZWwsIHsgaHRtbEZvcjogaWQsIGlzSW52ZXJzZTogY29udGV4dC5pc0ludmVyc2UgfHwgaXNJbnZlcnNlLCBzdHlsZTogbGFiZWxTdHlsZSB9LFxyXG4gICAgICAgICAgICAhaXNUZXh0VmlzdWFsbHlIaWRkZW4gJiZcclxuICAgICAgICAgICAgICAgIHRleHRQb3NpdGlvbiA9PT0gUmFkaW9UZXh0UG9zaXRpb24ubGVmdCAmJlxyXG4gICAgICAgICAgICAgICAgbGFiZWxUZXh0LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZha2VJbnB1dCwgeyBpc0NoZWNrZWQ6IGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUsIGNvbG9yOiBjb2xvciwgZGlzYWJsZWQ6IGRpc2FibGVkLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlIHx8IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGNvbnRleHQuaGFzRXJyb3IsIHN0eWxlOiBpbnB1dFN0eWxlLCB0ZXh0UG9zaXRpb246IHRleHRQb3NpdGlvbiwgdGhlbWU6IHRoZW1lIH0sIGNvbnRleHQuc2VsZWN0ZWRWYWx1ZSA9PT0gdmFsdWUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvbkNoZWNrZWRJY29uLCBudWxsKSkgOiAoUmVhY3QuY3JlYXRlRWxlbWVudChSYWRpb0J1dHRvblVuY2hlY2tlZEljb24sIG51bGwpKSksXHJcbiAgICAgICAgICAgIGlzVGV4dFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSGlkZGVuTGFiZWxUZXh0LCBudWxsLCBsYWJlbFRleHQpKSA6ICh0ZXh0UG9zaXRpb24gIT09IFJhZGlvVGV4dFBvc2l0aW9uLmxlZnQgJiYgbGFiZWxUZXh0ICYmIGxhYmVsVGV4dCkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1pbmRleC5qcy5tYXAiXX0= */"));
|
|
23796
23862
|
var Radio = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
23797
23863
|
var id = useGenerateId(props.id);
|
|
23798
23864
|
var context = useContext(RadioContext);
|