react-magma-dom 4.9.0-next.20 → 4.9.0-next.22
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 +25 -19
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +25 -19
- 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
|
@@ -4867,7 +4867,7 @@ var InputIconPosition;
|
|
|
4867
4867
|
InputIconPosition["right"] = "right";
|
|
4868
4868
|
})(InputIconPosition || (InputIconPosition = {}));
|
|
4869
4869
|
var inputWrapperStyles = function inputWrapperStyles(props) {
|
|
4870
|
-
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":"AA4DQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA6EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmCiD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4870
|
+
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":"AA4DQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.disabled && /*#__PURE__*/css("border-color:", props.isInverse ? curriedTransparentize(0.85, props.theme.colors.neutral100) : props.theme.colors.neutral300, ";background-color:", props.isInverse ? curriedTransparentize(0.9, props.theme.colors.neutral900) : props.theme.colors.neutral200, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " ", props.inputSize === 'large' && /*#__PURE__*/css("height:", props.theme.spaceScale.spacing11, ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA6EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), ";;label:inputWrapperStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmCiD","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4871
4871
|
};
|
|
4872
4872
|
function getInputPadding(props) {
|
|
4873
4873
|
var inputSize = props.inputSize,
|
|
@@ -4919,7 +4919,7 @@ function getInputPadding(props) {
|
|
|
4919
4919
|
return padding;
|
|
4920
4920
|
}
|
|
4921
4921
|
var inputBaseStyles = function inputBaseStyles(props) {
|
|
4922
|
-
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:100%;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, ";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":"AAwJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqLQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " &:-webkit-autofill,&:-webkit-autofill:focus,&:-webkit-autofill:hover,&:-webkit-autofill:active{box-shadow:none!important;-webkit-background-clip:text;-webkit-text-fill-color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, "!important;caret-color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, "!important;};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuI8C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4922
|
+
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:100%;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, ";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":"AAwJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " padding-left:", getInputPadding(props).left, ";padding-right:", getInputPadding(props).right, ";&::placeholder{color:", props.isInverse ? curriedTransparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";}&:focus{outline:0;}&[type='search']{&::-webkit-search-decoration,&::-webkit-search-cancel-button,&::-webkit-search-results-button,&::-webkit-search-results-decoration{display:none;}}", props.disabled && /*#__PURE__*/css("color:", props.isInverse ? curriedTransparentize(0.6, props.theme.colors.neutral100) : curriedTransparentize(0.4, props.theme.colors.neutral500), ";cursor:not-allowed;&::placeholder{color:", props.isInverse ? curriedTransparentize(0.8, props.theme.colors.neutral100) : props.theme.colors.neutral500, ";opacity:", props.isInverse ? 0.4 : 0.6, ";};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqLQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */")), " &:-webkit-autofill,&:-webkit-autofill:focus,&:-webkit-autofill:hover,&:-webkit-autofill:active{box-shadow:none!important;-webkit-background-clip:text;-webkit-text-fill-color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, "!important;caret-color:", props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700, "!important;};label:inputBaseStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuI8C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4923
4923
|
};
|
|
4924
4924
|
var InputContainer = /*#__PURE__*/_styled("div", {
|
|
4925
4925
|
target: "e1jxjjn77",
|
|
@@ -4929,17 +4929,17 @@ var InputContainer = /*#__PURE__*/_styled("div", {
|
|
|
4929
4929
|
styles: "display:flex"
|
|
4930
4930
|
} : {
|
|
4931
4931
|
name: "zjik7",
|
|
4932
|
-
styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiNkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
4932
|
+
styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiNkC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
4933
4933
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$8
|
|
4934
4934
|
});
|
|
4935
4935
|
var InputWrapper = /*#__PURE__*/_styled("div", {
|
|
4936
4936
|
target: "e1jxjjn76",
|
|
4937
4937
|
label: "InputWrapper"
|
|
4938
|
-
})(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoNuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4938
|
+
})(inputWrapperStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoNuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4939
4939
|
var StyledInput = /*#__PURE__*/_styled("input", {
|
|
4940
4940
|
target: "e1jxjjn75",
|
|
4941
4941
|
label: "StyledInput"
|
|
4942
|
-
})(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuNiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4942
|
+
})(inputBaseStyles, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuNiC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4943
4943
|
var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
4944
4944
|
target: "e1jxjjn74",
|
|
4945
4945
|
label: "IconWrapper"
|
|
@@ -4956,8 +4956,8 @@ var IconWrapper$3 = /*#__PURE__*/_styled("span", {
|
|
|
4956
4956
|
return props.theme.spaceScale.spacing03;
|
|
4957
4957
|
};
|
|
4958
4958
|
}, ";", function (props) {
|
|
4959
|
-
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":"AA2OQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4960
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0NgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4959
|
+
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":"AA2OQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4960
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0NgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
4961
4961
|
function getIconButtonSVGSize(props) {
|
|
4962
4962
|
var isClickable = props.isClickable,
|
|
4963
4963
|
iconPosition = props.iconPosition,
|
|
@@ -5047,7 +5047,7 @@ var IconButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
5047
5047
|
return getIconButtonSVGSize(props);
|
|
5048
5048
|
}, ";width:", function (props) {
|
|
5049
5049
|
return getIconButtonSVGSize(props);
|
|
5050
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T+C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5050
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8T+C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5051
5051
|
var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
5052
5052
|
target: "e1jxjjn72",
|
|
5053
5053
|
label: "PasswordButtonContainer"
|
|
@@ -5055,7 +5055,7 @@ var PasswordButtonContainer = /*#__PURE__*/_styled("span", {
|
|
|
5055
5055
|
return props.size === InputSize.large ? -props.buttonWidth - 8 + "px" : -props.buttonWidth - 6 + "px";
|
|
5056
5056
|
}, ",\n ", function (props) {
|
|
5057
5057
|
return props.size === InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
|
|
5058
|
-
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8U4C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5058
|
+
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8U4C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5059
5059
|
function getClearablePosition(props) {
|
|
5060
5060
|
if (props.iconPosition === 'right' && props.icon) {
|
|
5061
5061
|
if (props.inputSize === 'large') {
|
|
@@ -5075,7 +5075,7 @@ var IsClearableContainer = /*#__PURE__*/_styled("span", {
|
|
|
5075
5075
|
return getClearablePosition(props);
|
|
5076
5076
|
}, ",\n ", function (props) {
|
|
5077
5077
|
return props.inputSize === InputSize.large ? props.theme.spaceScale.spacing03 : '6px';
|
|
5078
|
-
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoWyC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5078
|
+
}, "\n );" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoWyC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5079
5079
|
function getIconSize$1(size, theme, iconPosition) {
|
|
5080
5080
|
switch (size) {
|
|
5081
5081
|
case 'large':
|
|
@@ -5116,7 +5116,7 @@ var HelpLinkContainer = /*#__PURE__*/_styled("span", {
|
|
|
5116
5116
|
return getHelpIconButtonSize(props);
|
|
5117
5117
|
}, ";}inset-inline-end:", function (props) {
|
|
5118
5118
|
return isLeftOrHidden(props) ? 'auto' : '0';
|
|
5119
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgY6C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        setValue(event.target.value);\r\n        if (!event.target.value &&\r\n            onDateChange &&\r\n            typeof onDateChange === 'function')\r\n            onDateChange(null);\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5119
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgY6C","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\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\nimport { ChildrenWrapper } from '../StyledButton';\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[\"url\"] = \"url\";\r\n    InputType[\"tel\"] = \"tel\";\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    const 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: 100%;\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    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\n  &:-webkit-autofill,\n  &:-webkit-autofill:focus,\n  &:-webkit-autofill:hover,\n  &:-webkit-autofill:active {\n    box-shadow: none !important;\n    -webkit-background-clip: text;\n    -webkit-text-fill-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n    caret-color: ${props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700} !important;\n  }\n`;\r\nconst InputContainer = styled.div `\n  display: flex;\n`;\r\nexport const InputWrapper = styled.div `\n  ${inputWrapperStyles}\n`;\r\nconst StyledInput = styled.input `\n  ${inputBaseStyles}\n`;\r\nconst IconWrapper = styled.span `\n  bottom: ${props => (props.iconPosition === 'top' ? '45px' : 'inherit')};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  left: ${props => props.iconPosition === 'left' ? props.theme.spaceScale.spacing03 : 'auto'};\n  right: ${props => props.iconPosition === 'right'\r\n    ? props.theme.spaceScale.spacing03\r\n    : props.iconPosition === 'top'\r\n        ? '3px'\r\n        : 'auto'};\n  position: absolute;\n  top: ${props => props.iconPosition === 'top'\r\n    ? 'inherit'\r\n    : props => props.theme.spaceScale.spacing03};\n\n  ${props => props.inputSize === 'large' &&\r\n    css `\n      bottom: ${props.iconPosition === 'top' ? '62px' : 'inherit'};\n      left: ${props.iconPosition === 'left'\r\n        ? props.theme.spaceScale.spacing04\r\n        : 'auto'};\n      right: ${props.iconPosition === 'right'\r\n        ? props.theme.spaceScale.spacing04\r\n        : props.iconPosition === 'top'\r\n            ? '3px'\r\n            : 'auto'};\n      top: ${props.iconPosition === 'top'\r\n        ? 'inherit'\r\n        : props.theme.spaceScale.spacing04};\n    `}\n`;\r\nfunction getIconButtonSVGSize(props) {\r\n    const { isClickable, iconPosition, inputSize, theme } = props;\r\n    if (isClickable && iconPosition === InputIconPosition.top) {\r\n        if (inputSize === InputSize.large) {\r\n            return `${theme.iconSizes.medium}px`;\r\n        }\r\n        return `${theme.iconSizes.small}px`;\r\n    }\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.large}px`;\r\n    }\r\n    return `${theme.iconSizes.medium}px`;\r\n}\r\nfunction getHelpLinkSVGSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return `${theme.iconSizes.medium}px`;\r\n    }\r\n    return `${theme.iconSizes.small}px`;\r\n}\r\nexport function getHelpIconButtonSize(props) {\r\n    const { inputSize, theme } = props;\r\n    if (inputSize === InputSize.large) {\r\n        return theme.spaceScale.spacing09;\r\n    }\r\n    return theme.spaceScale.spacing07;\r\n}\r\nfunction getIconButtonTransform(props) {\r\n    const { isClickable, iconPosition, inputSize, hasChildren, theme } = props;\r\n    const 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 props.theme.spaceScale.spacing13;\r\n        }\r\n        return '72px';\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    : '6px'}\n  );\n`;\r\nfunction getIconSize(size, theme, iconPosition) {\r\n    switch (size) {\r\n        case 'large':\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.medium;\r\n            }\r\n            return theme.iconSizes.large;\r\n        default:\r\n            if (iconPosition === InputIconPosition.top) {\r\n                return theme.iconSizes.small;\r\n            }\r\n            return theme.iconSizes.medium;\r\n    }\r\n}\r\nexport const isLeftOrHidden = ({ labelPosition, isLabelVisuallyHidden, }) => labelPosition === LabelPosition.left || isLabelVisuallyHidden;\r\nexport const HelpLinkContainer = styled.span `\n  position: ${props => (isLeftOrHidden(props) ? 'relative' : 'absolute')};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  height: ${props => (isLeftOrHidden(props) ? 'auto' : 'fit-content')};\n  margin-inline-start: ${props => isLeftOrHidden(props) ? `${props.theme.spaceScale.spacing03}` : 'auto'};\n  transform: translateY(\n    ${props => isLeftOrHidden(props)\r\n    ? '0'\r\n    : `calc(-100% - ${props.theme.spaceScale.spacing03})`}\n  );\n  ${ChildrenWrapper} > svg {\n    height: ${props => getHelpLinkSVGSize(props)};\n    width: ${props => getHelpLinkSVGSize(props)};\n  }\n  button {\n    height: ${props => getHelpIconButtonSize(props)};\n    width: ${props => getHelpIconButtonSize(props)};\n  }\n  inset-inline-end: ${props => (isLeftOrHidden(props) ? 'auto' : '0')};\n`;\r\nexport const InputBase = React.forwardRef((props, forwardedRef) => {\r\n    const { children, containerStyle, defaultValue, disabled, hasCharacterCounter, hasError, icon, iconAriaLabel, iconRef, isClearable, isPasswordInput, isPredictive, maxCount, maxLength, onClear, onIconClick, onIconKeyDown, onDateChange, inputLength, inputSize, inputStyle, inputWrapperStyle, testId, type, setReference, isLabelVisuallyHidden, labelPosition, ...other } = props;\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const iconPosition = icon && onIconClick\r\n        ? InputIconPosition.right\r\n        : icon && !props.iconPosition\r\n            ? InputIconPosition.left\r\n            : props.iconPosition;\r\n    const [value, setValue] = React.useState(props.defaultValue !== undefined && props.defaultValue !== null\r\n        ? props.defaultValue\r\n        : props.value || '');\r\n    const maxLengthNum = !hasCharacterCounter && maxLength ? maxLength : undefined;\r\n    React.useEffect(() => {\r\n        if (props.value !== undefined && props.value !== null) {\r\n            setValue(props.value);\r\n        }\r\n    }, [props.value]);\r\n    const inputRef = React.useRef();\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    function handleClearInput() {\r\n        onClear && typeof onClear === 'function' && onClear();\r\n        setValue('');\r\n        onDateChange && typeof onDateChange === 'function' && onDateChange(null);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleChange(event) {\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(event);\r\n        const isOnDateChange = onDateChange && typeof onDateChange === 'function';\r\n        const { value } = event.target;\r\n        setValue(isOnDateChange ? value : (props.value ?? value));\r\n        if (isOnDateChange && !value) {\r\n            onDateChange(null);\r\n        }\r\n    }\r\n    const passwordBtnWidth = () => {\r\n        const btnWidth = children?.props?.children?.[0]?.ref?.current?.offsetWidth;\r\n        if (typeof btnWidth === 'number') {\r\n            return btnWidth;\r\n        }\r\n        else {\r\n            // When PasswordButton is used inside SchemaRenderer, it doesn't have children.\r\n            // We'll use the default button sizes.\r\n            if (props.inputSize === InputSize.large) {\r\n                return 64;\r\n            }\r\n            return 54;\r\n        }\r\n    };\r\n    return (React.createElement(\"div\", { ref: setReference },\r\n        React.createElement(InputContainer, { style: inputWrapperStyle, \"data-testid\": `${testId}-wrapper` },\r\n            React.createElement(InputWrapper, { disabled: disabled, iconPosition: iconPosition, isInverse: props.isInverse, inputSize: inputSize ?? InputSize.medium, theme: theme, style: containerStyle, hasError: hasError, isClearable: isClearable, width: props.width },\r\n                React.createElement(StyledInput, Object.assign({}, other, { \"aria-invalid\": hasError, disabled: disabled, \"data-testid\": testId, hasCharacterCounter: hasCharacterCounter, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isClearable: type === InputType.search\r\n                        ? isClearable\r\n                        : inputWrapperStyle?.width\r\n                            ? isClearable\r\n                            : isClearable && inputLength > 0, isInverse: useIsInverse(props.isInverse), isPredictive: isPredictive, hasError: hasError, ref: ref, maxLength: maxLengthNum, onChange: handleChange, style: inputStyle, theme: theme, type: type ? type : InputType.text, value: value })),\r\n                icon && !onIconClick && (React.createElement(IconWrapper, { \"aria-label\": iconAriaLabel, iconPosition: iconPosition, inputSize: inputSize ?? InputSize.medium, isInverse: props.isInverse, isPredictive: isPredictive, theme: theme, disabled: disabled }, React.Children.only(React.cloneElement(icon, {\r\n                    size: getIconSize(inputSize ?? InputSize.medium, theme, iconPosition),\r\n                }))))),\r\n            isClearable && value !== '' && (React.createElement(IsClearableContainer, { theme: theme, iconPosition: iconPosition, inputSize: inputSize, icon: icon },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.input.isClearableAriaLabel, disabled: disabled, icon: React.createElement(ClearIcon, null), isInverse: props.isInverse, onClick: handleClearInput, onKeyDown: onIconKeyDown, ref: iconRef, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, testId: \"clear-button\", type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            onIconClick && (React.createElement(IconButtonContainer, { iconPosition: iconPosition, inputSize: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, isClickable: true },\r\n                React.createElement(IconButton, { \"aria-label\": iconAriaLabel, icon: icon, isInverse: props.isInverse, onClick: onIconClick, onKeyDown: onIconKeyDown, ref: iconRef, disabled: disabled, shape: ButtonShape.fill, size: inputSize === InputSize.large\r\n                        ? ButtonSize.medium\r\n                        : ButtonSize.small, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            isPasswordInput ? (React.createElement(PasswordButtonContainer, { size: inputSize === InputSize.large\r\n                    ? InputSize.large\r\n                    : InputSize.medium, theme: theme, buttonWidth: passwordBtnWidth() }, children)) : (React.createElement(HelpLinkContainer, { isLabelVisuallyHidden: isLabelVisuallyHidden || false, inputSize: inputSize ?? InputSize.medium, labelPosition: labelPosition ?? LabelPosition.top, theme: theme }, children)))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
5120
5120
|
var InputBase = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
5121
5121
|
var children = props.children,
|
|
5122
5122
|
containerStyle = props.containerStyle,
|
|
@@ -5165,9 +5165,14 @@ var InputBase = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
5165
5165
|
inputRef.current.focus();
|
|
5166
5166
|
}
|
|
5167
5167
|
function handleChange(event) {
|
|
5168
|
+
var _props$value;
|
|
5168
5169
|
props.onChange && typeof props.onChange === 'function' && props.onChange(event);
|
|
5169
|
-
|
|
5170
|
-
|
|
5170
|
+
var isOnDateChange = onDateChange && typeof onDateChange === 'function';
|
|
5171
|
+
var value = event.target.value;
|
|
5172
|
+
setValue(isOnDateChange ? value : (_props$value = props.value) != null ? _props$value : value);
|
|
5173
|
+
if (isOnDateChange && !value) {
|
|
5174
|
+
onDateChange(null);
|
|
5175
|
+
}
|
|
5171
5176
|
}
|
|
5172
5177
|
var passwordBtnWidth = function passwordBtnWidth() {
|
|
5173
5178
|
var _children$props;
|
|
@@ -5300,13 +5305,13 @@ var Message = /*#__PURE__*/_styled("div", {
|
|
|
5300
5305
|
return props.theme.typeScale.size02.lineHeight;
|
|
5301
5306
|
}, ";margin-top:", function (props) {
|
|
5302
5307
|
return props.inputSize === InputSize.large ? props.theme.spaceScale.spacing03 : props.theme.spaceScale.spacing02;
|
|
5303
|
-
}, ";text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0IyQiIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+
|
|
5308
|
+
}, ";text-align:left;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0IyQiIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gcHJvcHMuaW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDNcclxuICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuYDtcclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBmbGV4LXNocmluazogMDtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG5gO1xyXG5leHBvcnQgY29uc3QgSW5wdXRNZXNzYWdlID0gKHsgY2hpbGRyZW4sIGlkLCBpc0ludmVyc2UsIGhhc0Vycm9yLCBtYXhDb3VudCwgLi4ub3RoZXIgfSkgPT4ge1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICAvL0NvbmRpdGlvbmFsIHdyYXBwZXIgYmFzZWQgb24gbWF4Q291bnQgb3IgaGFzRXJyb3IsIGFsbG93cyBDaGFyYWN0ZXIgQ291bnRlciBvciBoYXNFcnJvciBwcm9wIHRvIHJlbmRlciB3aXRob3V0IHRoZSBBbm5vdW5jZSBjb21wb25lbnQgZm9yIGFjY2Vzc2liaWxpdHkgcHVycG9zZXMuXHJcbiAgICBmdW5jdGlvbiBBbm5vdW5jZVdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobWF4Q291bnQgfHwgaGFzRXJyb3IpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFubm91bmNlV3JhcHBlciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1lc3NhZ2UsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogXCJpbnB1dE1lc3NhZ2VcIiwgaWQ6IGlkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGhhc0Vycm9yLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGhhc0Vycm9yICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KEljb25XcmFwcGVyLCB7IFwiYXJpYS1sYWJlbFwiOiBcIkVycm9yXCIsIHJvbGU6IFwiaW1nXCIsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFcnJvckljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLnNtYWxsLCBjb2xvcjogaXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmRhbmdlcjMwMCA6IHVuZGVmaW5lZCB9KSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsIGNoaWxkcmVuKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5wdXRNZXNzYWdlLmpzLm1hcCJdfQ== */"));
|
|
5304
5309
|
var IconWrapper$4 = /*#__PURE__*/_styled("span", {
|
|
5305
5310
|
target: "e1egx0lj0",
|
|
5306
5311
|
label: "IconWrapper"
|
|
5307
5312
|
})("display:inline-flex;flex-shrink:0;padding-right:", function (props) {
|
|
5308
5313
|
return props.theme.spaceScale.spacing02;
|
|
5309
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJnQyIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+
|
|
5314
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIklucHV0TWVzc2FnZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEJnQyIsImZpbGUiOiJJbnB1dE1lc3NhZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5pbXBvcnQgeyBFcnJvckljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBJbnB1dFNpemUgfSBmcm9tICcuLi9JbnB1dEJhc2UnO1xyXG5mdW5jdGlvbiBCdWlsZE1lc3NhZ2VDb2xvcihwcm9wcykge1xyXG4gICAgY29uc3QgeyBpc0ludmVyc2UsIGhhc0Vycm9yLCB0aGVtZSB9ID0gcHJvcHM7XHJcbiAgICBpZiAoaXNJbnZlcnNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGhhc0Vycm9yXHJcbiAgICAgICAgICAgID8gdGhlbWUuY29sb3JzLmRhbmdlcjIwMFxyXG4gICAgICAgICAgICA6IHRyYW5zcGFyZW50aXplKDAuMywgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDApO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGhhc0Vycm9yID8gdGhlbWUuY29sb3JzLmRhbmdlciA6IHRoZW1lLmNvbG9ycy5uZXV0cmFsNTAwO1xyXG59XHJcbmNvbnN0IE1lc3NhZ2UgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9yZGVyUmFkaXVzfTtcbiAgY29sb3I6ICR7cHJvcHMgPT4gQnVpbGRNZXNzYWdlQ29sb3IocHJvcHMpfTtcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIuZm9udFNpemV9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGxldHRlci1zcGFjaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGV0dGVyU3BhY2luZ307XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gcHJvcHMuaW5wdXRTaXplID09PSBJbnB1dFNpemUubGFyZ2VcclxuICAgID8gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDNcclxuICAgIDogcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDJ9O1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuYDtcclxuY29uc3QgSWNvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBmbGV4LXNocmluazogMDtcbiAgcGFkZGluZy1yaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMn07XG5gO1xyXG5leHBvcnQgY29uc3QgSW5wdXRNZXNzYWdlID0gKHsgY2hpbGRyZW4sIGlkLCBpc0ludmVyc2UsIGhhc0Vycm9yLCBtYXhDb3VudCwgLi4ub3RoZXIgfSkgPT4ge1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICAvL0NvbmRpdGlvbmFsIHdyYXBwZXIgYmFzZWQgb24gbWF4Q291bnQgb3IgaGFzRXJyb3IsIGFsbG93cyBDaGFyYWN0ZXIgQ291bnRlciBvciBoYXNFcnJvciBwcm9wIHRvIHJlbmRlciB3aXRob3V0IHRoZSBBbm5vdW5jZSBjb21wb25lbnQgZm9yIGFjY2Vzc2liaWxpdHkgcHVycG9zZXMuXHJcbiAgICBmdW5jdGlvbiBBbm5vdW5jZVdyYXBwZXIocHJvcHMpIHtcclxuICAgICAgICBpZiAobWF4Q291bnQgfHwgaGFzRXJyb3IpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEFubm91bmNlV3JhcHBlciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1lc3NhZ2UsIE9iamVjdC5hc3NpZ24oe30sIG90aGVyLCB7IFwiZGF0YS10ZXN0aWRcIjogXCJpbnB1dE1lc3NhZ2VcIiwgaWQ6IGlkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgaGFzRXJyb3I6IGhhc0Vycm9yLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGhhc0Vycm9yICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KEljb25XcmFwcGVyLCB7IFwiYXJpYS1sYWJlbFwiOiBcIkVycm9yXCIsIHJvbGU6IFwiaW1nXCIsIHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChFcnJvckljb24sIHsgc2l6ZTogdGhlbWUuaWNvblNpemVzLnNtYWxsLCBjb2xvcjogaXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLmRhbmdlcjMwMCA6IHVuZGVmaW5lZCB9KSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsIGNoaWxkcmVuKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9SW5wdXRNZXNzYWdlLmpzLm1hcCJdfQ== */"));
|
|
5310
5315
|
var InputMessage = function InputMessage(_ref) {
|
|
5311
5316
|
var children = _ref.children,
|
|
5312
5317
|
id = _ref.id,
|
|
@@ -5315,9 +5320,9 @@ var InputMessage = function InputMessage(_ref) {
|
|
|
5315
5320
|
maxCount = _ref.maxCount,
|
|
5316
5321
|
other = _objectWithoutPropertiesLoose(_ref, _excluded$m);
|
|
5317
5322
|
var theme = useContext(ThemeContext);
|
|
5318
|
-
//Conditional wrapper based on maxCount, allows Character Counter to render without the Announce component for accessibility purposes.
|
|
5323
|
+
//Conditional wrapper based on maxCount or hasError, allows Character Counter or hasError prop to render without the Announce component for accessibility purposes.
|
|
5319
5324
|
function AnnounceWrapper(props) {
|
|
5320
|
-
if (maxCount) {
|
|
5325
|
+
if (maxCount || hasError) {
|
|
5321
5326
|
return props.children;
|
|
5322
5327
|
}
|
|
5323
5328
|
return createElement(Announce, null, props.children);
|
|
@@ -6176,7 +6181,7 @@ var StyledFormFieldContainer = /*#__PURE__*/_styled("div", {
|
|
|
6176
6181
|
return props.labelWidth && props.labelPosition === LabelPosition.left ? props.labelWidth + "%" : '';
|
|
6177
6182
|
}, ";margin-top:", function (props) {
|
|
6178
6183
|
return props.inputSize === 'large' ? '19px' : '';
|
|
6179
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRDIiwiZmlsZSI6IkZvcm1GaWVsZENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBDaGFyYWN0ZXJDb3VudGVyIH0gZnJvbSAnLi4vQ2hhcmFjdGVyQ291bnRlcic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICAgIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gKHByb3BzLmlucHV0U2l6ZSA9PT0gJ2xhcmdlJyA/ICcxOXB4JyA6ICcnKX07XG4gIH1cbmA7XHJcbi8vIElucHV0IGFuZCBoZWxwZXIgdGV4dCA8ZGl2PiB3cmFwcGVyIGJhc2VkIG9uIGxhYmVsUG9zaXRpb24uXHJcbmNvbnN0IFN0eWxlZElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuYDtcclxuLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIElucHV0LCBlcnJvck1lc3NhZ2UsIGhlbHBlck1lc3NhZ2UsIGFuZCBDaGFyYWN0ZXJDb3VudGVyIGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbmZ1bmN0aW9uIElucHV0UG9zaXRpb25XcmFwcGVyKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXRXcmFwcGVyLCBudWxsLCBwcm9wcy5jaGlsZHJlbik7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbn1cclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGNvdW50UHJvcHMgPSBtYXhDb3VudCB8fCBtYXhMZW5ndGg7XHJcbiAgICBjb25zdCBkZXNjcmlwdGlvbklkID0gZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UgfHwgY291bnRQcm9wcyA/
|
|
6184
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTRDIiwiZmlsZSI6IkZvcm1GaWVsZENvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgSW52ZXJzZUNvbnRleHQsIHVzZUlzSW52ZXJzZSB9IGZyb20gJy4uLy4uL2ludmVyc2UnO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBDaGFyYWN0ZXJDb3VudGVyIH0gZnJvbSAnLi4vQ2hhcmFjdGVyQ291bnRlcic7XHJcbmltcG9ydCB7IElucHV0TWVzc2FnZSB9IGZyb20gJy4uL0lucHV0L0lucHV0TWVzc2FnZSc7XHJcbmltcG9ydCB7IExhYmVsLCBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgU3R5bGVkRm9ybUZpZWxkQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbH07XG4gIGZvbnQtZmFtaWx5OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLmJvZHlGb250fTtcbiAgZGlzcGxheTogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFBvc2l0aW9uID09PSBMYWJlbFBvc2l0aW9uLmxlZnQgPyAnZmxleCcgOiAnJ307XG4gIGxhYmVsIHtcbiAgICBmbGV4LWJhc2lzOiAke3Byb3BzID0+IHByb3BzLmxhYmVsV2lkdGggJiYgcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0XHJcbiAgICA/IGAke3Byb3BzLmxhYmVsV2lkdGh9JWBcclxuICAgIDogJyd9O1xuICAgIG1hcmdpbi10b3A6ICR7cHJvcHMgPT4gKHByb3BzLmlucHV0U2l6ZSA9PT0gJ2xhcmdlJyA/ICcxOXB4JyA6ICcnKX07XG4gIH1cbmA7XHJcbi8vIElucHV0IGFuZCBoZWxwZXIgdGV4dCA8ZGl2PiB3cmFwcGVyIGJhc2VkIG9uIGxhYmVsUG9zaXRpb24uXHJcbmNvbnN0IFN0eWxlZElucHV0V3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBmbGV4OiAxIDEgYXV0bztcbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuYDtcclxuLy8gSWYgdGhlIGxhYmVsUG9zaXRpb24gaXMgc2V0IHRvICdsZWZ0JyB0aGVuIGEgPGRpdj4gd3JhcHMgdGhlIElucHV0LCBlcnJvck1lc3NhZ2UsIGhlbHBlck1lc3NhZ2UsIGFuZCBDaGFyYWN0ZXJDb3VudGVyIGZvciBwcm9wZXIgc3R5bGluZyBhbGlnbm1lbnQuXHJcbmZ1bmN0aW9uIElucHV0UG9zaXRpb25XcmFwcGVyKHByb3BzKSB7XHJcbiAgICBpZiAocHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0KSB7XHJcbiAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSW5wdXRXcmFwcGVyLCBudWxsLCBwcm9wcy5jaGlsZHJlbik7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gcHJvcHMuY2hpbGRyZW47XHJcbn1cclxuZXhwb3J0IGNvbnN0IEZvcm1GaWVsZENvbnRhaW5lciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYWN0aW9uYWJsZSA9IHRydWUsIGNoaWxkcmVuLCBjb250YWluZXJTdHlsZSwgZXJyb3JNZXNzYWdlLCBmaWVsZElkLCBoYXNDaGFyYWN0ZXJDb3VudGVyID0gdHJ1ZSwgaGVscGVyTWVzc2FnZSwgaWNvblBvc2l0aW9uLCBpbnB1dFNpemUsIGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZVByb3AsIGlzTGFiZWxWaXN1YWxseUhpZGRlbiwgbGFiZWxQb3NpdGlvbiwgbGFiZWxTdHlsZSwgbGFiZWxUZXh0LCBsYWJlbFdpZHRoLCBtYXhDb3VudCwgbWF4TGVuZ3RoLCBtZXNzYWdlU3R5bGUsIHRlc3RJZCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IGNvdW50UHJvcHMgPSBtYXhDb3VudCB8fCBtYXhMZW5ndGg7XHJcbiAgICBjb25zdCBkZXNjcmlwdGlvbklkID0gZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UgfHwgY291bnRQcm9wcyA/IGAke2ZpZWxkSWR9X19kZXNjYCA6IG51bGw7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciwgT2JqZWN0LmFzc2lnbih7fSwgcmVzdCwgeyBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIGlucHV0U2l6ZTogaW5wdXRTaXplLCBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoLCByZWY6IHJlZiwgc3R5bGU6IGNvbnRhaW5lclN0eWxlLCB0aGVtZTogdGhlbWUgfSksXHJcbiAgICAgICAgICAgIGxhYmVsVGV4dCAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChMYWJlbCwgeyBhY3Rpb25hYmxlOiBhY3Rpb25hYmxlLCBodG1sRm9yOiBmaWVsZElkLCBpY29uUG9zaXRpb246IGljb25Qb3NpdGlvbiwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgc2l6ZTogaW5wdXRTaXplLCBzdHlsZTogbGFiZWxTdHlsZSB9LCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4gPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWaXN1YWxseUhpZGRlbiwgbnVsbCwgbGFiZWxUZXh0KSkgOiAobGFiZWxUZXh0KSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KElucHV0UG9zaXRpb25XcmFwcGVyLCB7IGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIGxhYmVsV2lkdGg6IGxhYmVsV2lkdGggfSxcclxuICAgICAgICAgICAgICAgIGNoaWxkcmVuLFxyXG4gICAgICAgICAgICAgICAgdHlwZW9mIGNvdW50UHJvcHMgPT09ICdudW1iZXInICYmIGhhc0NoYXJhY3RlckNvdW50ZXIgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hhcmFjdGVyQ291bnRlciwgeyBoYXNDaGFyYWN0ZXJDb3VudGVyOiBoYXNDaGFyYWN0ZXJDb3VudGVyLCBpZDogZGVzY3JpcHRpb25JZCwgaW5wdXRMZW5ndGg6IGlucHV0TGVuZ3RoLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgbWF4Q291bnQ6IG1heENvdW50LCBtYXhMZW5ndGg6IG1heExlbmd0aCwgdGVzdElkOiB0ZXN0SWQgJiYgYCR7dGVzdElkfS1jaGFyYWN0ZXItY291bnRlcmAgfSkpLFxyXG4gICAgICAgICAgICAgICAgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dE1lc3NhZ2UsIHsgXCJhcmlhLWRlc2NyaWJlZGJ5XCI6IGVycm9yTWVzc2FnZSA/IGAke2Vycm9yTWVzc2FnZX1gIDogYCR7aGVscGVyTWVzc2FnZX1gLCBoYXNFcnJvcjogISFlcnJvck1lc3NhZ2UsIGlkOiBkZXNjcmlwdGlvbklkLCBpc0ludmVyc2U6IGlzSW52ZXJzZSwgc3R5bGU6IG1lc3NhZ2VTdHlsZSB9LCAoZXJyb3JNZXNzYWdlIHx8IGhlbHBlck1lc3NhZ2UpICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLCBlcnJvck1lc3NhZ2UgPyBlcnJvck1lc3NhZ2UgOiBoZWxwZXJNZXNzYWdlKSkpKSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Gb3JtRmllbGRDb250YWluZXIuanMubWFwIl19 */"));
|
|
6180
6185
|
// Input and helper text <div> wrapper based on labelPosition.
|
|
6181
6186
|
var StyledInputWrapper = /*#__PURE__*/_styled("div", {
|
|
6182
6187
|
target: "em9iy460",
|
|
@@ -6186,7 +6191,7 @@ var StyledInputWrapper = /*#__PURE__*/_styled("div", {
|
|
|
6186
6191
|
styles: "flex:1 1 auto;align-self:center"
|
|
6187
6192
|
} : {
|
|
6188
6193
|
name: "118yi7l",
|
|
6189
|
-
styles: "flex:1 1 auto;align-self:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JzQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+
|
|
6194
|
+
styles: "flex:1 1 auto;align-self:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZvcm1GaWVsZENvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0JzQyIsImZpbGUiOiJGb3JtRmllbGRDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQ2hhcmFjdGVyQ291bnRlciB9IGZyb20gJy4uL0NoYXJhY3RlckNvdW50ZXInO1xyXG5pbXBvcnQgeyBJbnB1dE1lc3NhZ2UgfSBmcm9tICcuLi9JbnB1dC9JbnB1dE1lc3NhZ2UnO1xyXG5pbXBvcnQgeyBMYWJlbCwgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4uL0xhYmVsJztcclxuaW1wb3J0IHsgVmlzdWFsbHlIaWRkZW4gfSBmcm9tICcuLi9WaXN1YWxseUhpZGRlbic7XHJcbmNvbnN0IFN0eWxlZEZvcm1GaWVsZENvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIGRpc3BsYXk6ICR7cHJvcHMgPT4gcHJvcHMubGFiZWxQb3NpdGlvbiA9PT0gTGFiZWxQb3NpdGlvbi5sZWZ0ID8gJ2ZsZXgnIDogJyd9O1xuICBsYWJlbCB7XG4gICAgZmxleC1iYXNpczogJHtwcm9wcyA9PiBwcm9wcy5sYWJlbFdpZHRoICYmIHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdFxyXG4gICAgPyBgJHtwcm9wcy5sYWJlbFdpZHRofSVgXHJcbiAgICA6ICcnfTtcbiAgICBtYXJnaW4tdG9wOiAke3Byb3BzID0+IChwcm9wcy5pbnB1dFNpemUgPT09ICdsYXJnZScgPyAnMTlweCcgOiAnJyl9O1xuICB9XG5gO1xyXG4vLyBJbnB1dCBhbmQgaGVscGVyIHRleHQgPGRpdj4gd3JhcHBlciBiYXNlZCBvbiBsYWJlbFBvc2l0aW9uLlxyXG5jb25zdCBTdHlsZWRJbnB1dFdyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZmxleDogMSAxIGF1dG87XG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbmA7XHJcbi8vIElmIHRoZSBsYWJlbFBvc2l0aW9uIGlzIHNldCB0byAnbGVmdCcgdGhlbiBhIDxkaXY+IHdyYXBzIHRoZSBJbnB1dCwgZXJyb3JNZXNzYWdlLCBoZWxwZXJNZXNzYWdlLCBhbmQgQ2hhcmFjdGVyQ291bnRlciBmb3IgcHJvcGVyIHN0eWxpbmcgYWxpZ25tZW50LlxyXG5mdW5jdGlvbiBJbnB1dFBvc2l0aW9uV3JhcHBlcihwcm9wcykge1xyXG4gICAgaWYgKHByb3BzLmxhYmVsUG9zaXRpb24gPT09IExhYmVsUG9zaXRpb24ubGVmdCkge1xyXG4gICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZElucHV0V3JhcHBlciwgbnVsbCwgcHJvcHMuY2hpbGRyZW4pO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIHByb3BzLmNoaWxkcmVuO1xyXG59XHJcbmV4cG9ydCBjb25zdCBGb3JtRmllbGRDb250YWluZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgcmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IGFjdGlvbmFibGUgPSB0cnVlLCBjaGlsZHJlbiwgY29udGFpbmVyU3R5bGUsIGVycm9yTWVzc2FnZSwgZmllbGRJZCwgaGFzQ2hhcmFjdGVyQ291bnRlciA9IHRydWUsIGhlbHBlck1lc3NhZ2UsIGljb25Qb3NpdGlvbiwgaW5wdXRTaXplLCBpbnB1dExlbmd0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBpc0xhYmVsVmlzdWFsbHlIaWRkZW4sIGxhYmVsUG9zaXRpb24sIGxhYmVsU3R5bGUsIGxhYmVsVGV4dCwgbGFiZWxXaWR0aCwgbWF4Q291bnQsIG1heExlbmd0aCwgbWVzc2FnZVN0eWxlLCB0ZXN0SWQsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCBjb3VudFByb3BzID0gbWF4Q291bnQgfHwgbWF4TGVuZ3RoO1xyXG4gICAgY29uc3QgZGVzY3JpcHRpb25JZCA9IGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlIHx8IGNvdW50UHJvcHMgPyBgJHtmaWVsZElkfV9fZGVzY2AgOiBudWxsO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRGb3JtRmllbGRDb250YWluZXIsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCBpbnB1dFNpemU6IGlucHV0U2l6ZSwgbGFiZWxQb3NpdGlvbjogbGFiZWxQb3NpdGlvbiwgbGFiZWxXaWR0aDogbGFiZWxXaWR0aCwgcmVmOiByZWYsIHN0eWxlOiBjb250YWluZXJTdHlsZSwgdGhlbWU6IHRoZW1lIH0pLFxyXG4gICAgICAgICAgICBsYWJlbFRleHQgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGFiZWwsIHsgYWN0aW9uYWJsZTogYWN0aW9uYWJsZSwgaHRtbEZvcjogZmllbGRJZCwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb24sIGxhYmVsUG9zaXRpb246IGxhYmVsUG9zaXRpb24sIHNpemU6IGlucHV0U2l6ZSwgc3R5bGU6IGxhYmVsU3R5bGUgfSwgaXNMYWJlbFZpc3VhbGx5SGlkZGVuID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsIGxhYmVsVGV4dCkpIDogKGxhYmVsVGV4dCkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dFBvc2l0aW9uV3JhcHBlciwgeyBsYWJlbFBvc2l0aW9uOiBsYWJlbFBvc2l0aW9uLCBsYWJlbFdpZHRoOiBsYWJlbFdpZHRoIH0sXHJcbiAgICAgICAgICAgICAgICBjaGlsZHJlbixcclxuICAgICAgICAgICAgICAgIHR5cGVvZiBjb3VudFByb3BzID09PSAnbnVtYmVyJyAmJiBoYXNDaGFyYWN0ZXJDb3VudGVyICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KENoYXJhY3RlckNvdW50ZXIsIHsgaGFzQ2hhcmFjdGVyQ291bnRlcjogaGFzQ2hhcmFjdGVyQ291bnRlciwgaWQ6IGRlc2NyaXB0aW9uSWQsIGlucHV0TGVuZ3RoOiBpbnB1dExlbmd0aCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIG1heENvdW50OiBtYXhDb3VudCwgbWF4TGVuZ3RoOiBtYXhMZW5ndGgsIHRlc3RJZDogdGVzdElkICYmIGAke3Rlc3RJZH0tY2hhcmFjdGVyLWNvdW50ZXJgIH0pKSxcclxuICAgICAgICAgICAgICAgIChlcnJvck1lc3NhZ2UgfHwgaGVscGVyTWVzc2FnZSkgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5wdXRNZXNzYWdlLCB7IFwiYXJpYS1kZXNjcmliZWRieVwiOiBlcnJvck1lc3NhZ2UgPyBgJHtlcnJvck1lc3NhZ2V9YCA6IGAke2hlbHBlck1lc3NhZ2V9YCwgaGFzRXJyb3I6ICEhZXJyb3JNZXNzYWdlLCBpZDogZGVzY3JpcHRpb25JZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHN0eWxlOiBtZXNzYWdlU3R5bGUgfSwgKGVycm9yTWVzc2FnZSB8fCBoZWxwZXJNZXNzYWdlKSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCwgZXJyb3JNZXNzYWdlID8gZXJyb3JNZXNzYWdlIDogaGVscGVyTWVzc2FnZSkpKSkpKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Rm9ybUZpZWxkQ29udGFpbmVyLmpzLm1hcCJdfQ== */",
|
|
6190
6195
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$c
|
|
6191
6196
|
});
|
|
6192
6197
|
// If the labelPosition is set to 'left' then a <div> wraps the Input, errorMessage, helperMessage, and CharacterCounter for proper styling alignment.
|
|
@@ -6256,6 +6261,7 @@ var FormFieldContainer = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
6256
6261
|
maxLength: maxLength,
|
|
6257
6262
|
testId: testId && testId + "-character-counter"
|
|
6258
6263
|
}), (errorMessage || helperMessage) && createElement(InputMessage, {
|
|
6264
|
+
"aria-describedby": errorMessage ? "" + errorMessage : "" + helperMessage,
|
|
6259
6265
|
hasError: !!errorMessage,
|
|
6260
6266
|
id: descriptionId,
|
|
6261
6267
|
isInverse: isInverse,
|