@orfium/ictinus 4.68.0 → 4.69.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -29,10 +29,20 @@ var MultiFilter = function MultiFilter(_ref) {
29
29
  searchValue = _ref.searchValue,
30
30
  isLoading = _ref.isLoading,
31
31
  hasSelectAllOption = _ref.hasSelectAllOption;
32
+
33
+ var filterInputRef = _react["default"].useRef(null);
34
+
35
+ var handleClick = function handleClick() {
36
+ var _filterInputRef$curre;
37
+
38
+ filterInputRef == null ? void 0 : (_filterInputRef$curre = filterInputRef.current) == null ? void 0 : _filterInputRef$curre.focus();
39
+ };
40
+
32
41
  return (0, _react2.jsx)("div", {
33
42
  css: (0, _Filter.menuStyle)()
34
43
  }, (0, _react2.jsx)("div", {
35
- css: (0, _MultiFilter.textFieldWrapper)()
44
+ css: (0, _MultiFilter.textFieldWrapper)(),
45
+ onClick: handleClick
36
46
  }, (0, _react2.jsx)(_MultiTextFieldBase["default"], {
37
47
  selectedOptions: selectedItems,
38
48
  onInput: onInput,
@@ -42,7 +52,8 @@ var MultiFilter = function MultiFilter(_ref) {
42
52
  value: searchValue,
43
53
  placeholder: "Search",
44
54
  isResponsive: true,
45
- isLoading: isLoading
55
+ isLoading: isLoading,
56
+ ref: filterInputRef
46
57
  })), (0, _react2.jsx)("div", {
47
58
  css: (0, _MultiFilter.optionsWrapper)()
48
59
  }, (0, _react2.jsx)(_Options["default"], {
@@ -29,7 +29,7 @@ var _TextInputBase2 = require("../TextInputBase/TextInputBase.style");
29
29
 
30
30
  var _react2 = require("@emotion/react");
31
31
 
32
- var _excluded = ["selectedOptions", "value", "disabled", "locked", "status", "lean", "dark", "readOnly", "label", "id", "placeholder", "required", "styleType", "onOptionDelete", "onClearAllOptions", "isLoading", "rightIcon", "isInteractive", "isResponsive", "isTextfield", "sx"];
32
+ var _excluded = ["selectedOptions", "value", "disabled", "locked", "status", "lean", "dark", "readOnly", "label", "id", "placeholder", "required", "styleType", "onOptionDelete", "onClearAllOptions", "isLoading", "isInteractive", "isResponsive", "isTextfield", "onKeyDown", "sx"];
33
33
 
34
34
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
35
35
 
@@ -59,13 +59,13 @@ var MultiTextFieldBase = /*#__PURE__*/_react["default"].forwardRef(function (pro
59
59
  onOptionDelete = props.onOptionDelete,
60
60
  onClearAllOptions = props.onClearAllOptions,
61
61
  isLoading = props.isLoading,
62
- rightIcon = props.rightIcon,
63
62
  _props$isInteractive = props.isInteractive,
64
63
  isInteractive = _props$isInteractive === void 0 ? true : _props$isInteractive,
65
64
  _props$isResponsive = props.isResponsive,
66
65
  isResponsive = _props$isResponsive === void 0 ? false : _props$isResponsive,
67
66
  _props$isTextfield = props.isTextfield,
68
67
  isTextfield = _props$isTextfield === void 0 ? false : _props$isTextfield,
68
+ onKeyDown = props.onKeyDown,
69
69
  sx = props.sx,
70
70
  rest = _objectWithoutPropertiesLoose(props, _excluded);
71
71
 
@@ -80,9 +80,9 @@ var MultiTextFieldBase = /*#__PURE__*/_react["default"].forwardRef(function (pro
80
80
  locked: locked,
81
81
  hasValue: hasValue,
82
82
  value: value,
83
- rightIcon: rightIcon,
84
83
  onOptionDelete: onOptionDelete,
85
- onClearAllOptions: onClearAllOptions
84
+ onClearAllOptions: onClearAllOptions,
85
+ onKeyDown: onKeyDown
86
86
  }),
87
87
  inputPlaceholder = _useMultiTextFieldBas.inputPlaceholder,
88
88
  handleKeyDown = _useMultiTextFieldBas.handleKeyDown,
@@ -5,10 +5,10 @@ declare type Props = {
5
5
  hasValue: boolean;
6
6
  isTextfield?: boolean;
7
7
  } & Pick<MultiTextFieldBase, 'value' | 'onOptionDelete' | 'onClearAllOptions'> & Omit<TextFieldProps, 'size'>;
8
- declare const useMultiTextFieldBaseUtils: ({ isTextfield, label, placeholder, required, locked, hasValue, value, rightIcon, onOptionDelete, onClearAllOptions, }: Props) => {
8
+ declare const useMultiTextFieldBaseUtils: ({ isTextfield, label, placeholder, required, locked, hasValue, value, onOptionDelete, onClearAllOptions, onKeyDown, }: Props) => {
9
9
  inputPlaceholder: string | undefined;
10
10
  handleKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void;
11
- icon: JSX.Element | undefined;
11
+ icon: import("@emotion/react/jsx-runtime").JSX.Element | undefined;
12
12
  hasLabel: boolean;
13
13
  TextfieldRef: React.RefObject<HTMLDivElement>;
14
14
  };
@@ -25,9 +25,9 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
25
25
  locked = _ref.locked,
26
26
  hasValue = _ref.hasValue,
27
27
  value = _ref.value,
28
- rightIcon = _ref.rightIcon,
29
28
  onOptionDelete = _ref.onOptionDelete,
30
- onClearAllOptions = _ref.onClearAllOptions;
29
+ onClearAllOptions = _ref.onClearAllOptions,
30
+ onKeyDown = _ref.onKeyDown;
31
31
 
32
32
  var TextfieldRef = _react["default"].useRef(null);
33
33
 
@@ -60,21 +60,13 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
60
60
  if (value === '' && event.key === 'Backspace') {
61
61
  onOptionDelete();
62
62
  }
63
- };
64
-
65
- var icon = (0, _react.useMemo)(function () {
66
- if (rightIcon) {
67
- if (typeof rightIcon === 'string') {
68
- return (0, _react2.jsx)(_Icon["default"], {
69
- name: rightIcon,
70
- size: 20,
71
- color: theme.utils.getColor('lightGrey', 650)
72
- });
73
- }
74
63
 
75
- return rightIcon;
64
+ if (onKeyDown) {
65
+ onKeyDown(event);
76
66
  }
67
+ };
77
68
 
69
+ var icon = (0, _react.useMemo)(function () {
78
70
  var handleClick = function handleClick() {
79
71
  if (!hasValue || locked) {
80
72
  return undefined;
@@ -94,7 +86,7 @@ var useMultiTextFieldBaseUtils = function useMultiTextFieldBaseUtils(_ref) {
94
86
  }
95
87
 
96
88
  return undefined;
97
- }, [hasValue, iconName, locked, onClearAllOptions, rightIcon, theme.utils]);
89
+ }, [hasValue, iconName, locked, onClearAllOptions, theme.utils]);
98
90
  return {
99
91
  inputPlaceholder: inputPlaceholder,
100
92
  handleKeyDown: handleKeyDown,
@@ -157,15 +157,6 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
157
157
  handleSelectedOption(option);
158
158
  };
159
159
 
160
- var handleOnKeyDown = function handleOnKeyDown(e) {
161
- var isBackspaceKey = e.keyCode === 8;
162
-
163
- if (isBackspaceKey) {
164
- setInputValue(emptyValue);
165
- debouncedOnChange('');
166
- }
167
- };
168
-
169
160
  var debouncedOnChange = _react["default"].useCallback((0, _debounce["default"])(function (term) {
170
161
  asyncSearch(term);
171
162
  }, 400), []);
@@ -286,6 +277,25 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
286
277
 
287
278
 
288
279
  var hasNoOptionsAndIsCreatable = creatable && filteredOptions.length === 1 && filteredOptions[0].isCreated;
280
+
281
+ var handleSingleKeyDown = function handleSingleKeyDown(event) {
282
+ var isBackspace = event.key === 'Backspace';
283
+
284
+ if (isBackspace) {
285
+ setInputValue(emptyValue);
286
+ debouncedOnChange('');
287
+ }
288
+ };
289
+
290
+ var handleMultiKeyDown = function handleMultiKeyDown(event) {
291
+ var isEnter = event.key === 'Enter';
292
+
293
+ if (hasNoOptionsAndIsCreatable && isEnter) {
294
+ handleMultiSelectOptionClick(filteredOptions[0]);
295
+ setSearchValue('');
296
+ }
297
+ };
298
+
289
299
  return (0, _react2.jsx)(_ClickAwayListener["default"], {
290
300
  onClick: function onClick() {
291
301
  setOpen(false);
@@ -314,11 +324,13 @@ var Select = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
314
324
  }, restInputProps, {
315
325
  status: status,
316
326
  value: textFieldValue,
317
- autoComplete: "off"
327
+ ref: combinedRefs,
328
+ autoComplete: "off",
329
+ onKeyDown: handleMultiKeyDown
318
330
  })) : (0, _react2.jsx)(_TextField["default"], _extends({
319
331
  styleType: styleType,
320
332
  rightIcon: rightIconRender,
321
- onKeyDown: handleOnKeyDown,
333
+ onKeyDown: handleSingleKeyDown,
322
334
  onInput: handleOnInput,
323
335
  onChange: ON_CHANGE_MOCK,
324
336
  readOnly: !isSearchable,
@@ -3,6 +3,8 @@
3
3
  exports.__esModule = true;
4
4
  exports["default"] = void 0;
5
5
 
6
+ var _useCombinedRefs = _interopRequireDefault(require("../../hooks/useCombinedRefs"));
7
+
6
8
  var _useTheme = _interopRequireDefault(require("../../hooks/useTheme"));
7
9
 
8
10
  var _omit = _interopRequireDefault(require("lodash/omit"));
@@ -45,7 +47,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
45
47
  } : {
46
48
  name: "1rlc0zw-TextField",
47
49
  styles: "width:100% ;label:TextField;",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AAoIe","file":"../../../src/components/TextField/TextField.tsx","sourcesContent":["import useTheme from 'hooks/useTheme';\nimport omit from 'lodash/omit';\nimport React, { InputHTMLAttributes } from 'react';\nimport { DEFAULT_SIZE } from 'utils/size-utils';\n\nimport { TestProps } from '../../utils/types';\nimport Icon from '../Icon';\nimport Label from '../Label';\nimport { IconWrapper } from './components/commons';\nimport useMultiTextFieldUtils from './hooks/useMultiTextFieldUtils';\nimport { AcceptedIconNames } from 'components/Icon/types';\nimport MultiTextFieldBase from 'components/MultiTextFieldBase/MultiTextFieldBase';\nimport { SelectOption } from 'components/Select/Select';\nimport TextInputBase, { Props as TextInputWrapperProps } from 'components/TextInputBase';\nimport { inputStyle } from 'components/TextInputBase/TextInputBase.style';\n\nexport type Props = {\n  /** The id of the text field that will be used as for in label too */\n  id?: string;\n  /** Callback fired when the `input` is blurred. */\n  onBlur?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` is changed. */\n  onChange?: React.ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` is focused. */\n  onFocus?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` has a key down event. */\n  onKeyDown?: React.KeyboardEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` value typed is changed */\n  onInput?: React.EventHandler<any>;\n  /** @deprecated This is a compatibility prop that will be removed in the next version, along with the min-width value\n   * of the TextField. It will be replaced by a fullWidth prop. */\n  hasMinWidthCompat?: boolean;\n  /** If true the user can enter multiple values by pressing 'Enter' */\n  multi?: boolean;\n  /** The initial multi values */\n  multiValues?: string[];\n  /** Maximum multi values */\n  maxMultiValues?: number;\n  /** A callback for when a Chip value is created */\n  onMultiValueCreate?: (value?: string) => void;\n  /** A callback for when a Chip value is deleted */\n  onMultiValueDelete?: (value?: string) => void;\n  /** A callback for when all values are deleted (the Clear All icon is clicked) */\n  onClearAllValues?: () => void;\n  /** The handler of multi values. If you pass a different handler function here it will change the way multi values are being calculated */\n  multiValuesHandler?: (tags: string) => string | string[];\n} & TextInputWrapperProps;\n\nexport type InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;\n\nconsole.warn(\n  'Deprecation warning! min-width will be removed from the component in v5 of ictinus. ' +\n    'hasMinWidthCompat prop has been added to temporarily disable min-width when necessary'\n);\n\nconst TextField = React.forwardRef<HTMLInputElement, Props & InputProps & TestProps>(\n  (props, ref) => {\n    const {\n      id = undefined,\n      rightIcon = null,\n      leftIcon = null,\n      label,\n      placeholder = '',\n      required = false,\n      disabled,\n      locked = false,\n      size = DEFAULT_SIZE,\n      dark = false,\n      lean,\n      hintMsg: __hintMsg,\n      styleType: __styleType,\n      readOnly,\n      status,\n      hasMinWidthCompat = true,\n      onInput,\n      multi = false,\n      multiValues = [],\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      multiValuesHandler = (value) => value,\n      ...rest\n    } = props;\n    const theme = useTheme();\n\n    const getIcon = (icon: AcceptedIconNames | JSX.Element | null) =>\n      icon ? (\n        typeof icon === 'string' ? (\n          <Icon\n            name={icon as AcceptedIconNames}\n            size={24}\n            color={theme.utils.getColor('lightGrey', 650)}\n          />\n        ) : (\n          icon\n        )\n      ) : null;\n\n    const {\n      inputValue,\n      values,\n      handleValueDelete,\n      handleClearAllValues,\n      handleKeyDown,\n      handleTyping,\n    } = useMultiTextFieldUtils({\n      multiValues,\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      onInput,\n      multiValuesHandler,\n    });\n\n    return multi ? (\n      <MultiTextFieldBase\n        {...props}\n        isTextfield\n        onOptionDelete={handleValueDelete as (option?: string | SelectOption) => void}\n        onClearAllOptions={handleClearAllValues}\n        label={label}\n        onInput={handleTyping}\n        onKeyDown={handleKeyDown}\n        selectedOptions={values}\n        value={inputValue}\n      />\n    ) : (\n      <React.Fragment>\n        <TextInputBase {...props} hasMinWidthCompat={hasMinWidthCompat}>\n          {leftIcon && <IconWrapper iconPosition={'left'}>{getIcon(leftIcon)}</IconWrapper>}\n          <div css={{ width: '100% ' }}>\n            <input\n              readOnly={readOnly}\n              css={inputStyle({ label, placeholder, size, dark, lean })}\n              placeholder={!label && placeholder ? `${placeholder} ${required ? '*' : ''}` : label}\n              required={required}\n              id={id}\n              disabled={disabled || locked}\n              onInput={onInput}\n              {...omit(rest, 'dataTestId')}\n              ref={ref}\n            />\n            {label && (\n              <Label\n                size={size}\n                htmlFor={id}\n                label={label}\n                required={required}\n                animateToTop={Boolean(rest.value)}\n                error={status === 'error'}\n              />\n            )}\n          </div>\n          {rightIcon && !locked && (\n            <IconWrapper iconPosition={'right'}>{getIcon(rightIcon)}</IconWrapper>\n          )}\n          {locked && (\n            <IconWrapper iconPosition={'right'}>\n              <Icon\n                name=\"lock\"\n                size={size === 'md' ? 20 : 16}\n                color={theme.utils.getColor('lightGrey', 650)}\n              />\n            </IconWrapper>\n          )}\n        </TextInputBase>\n      </React.Fragment>\n    );\n  }\n);\n\nTextField.displayName = 'TextField';\n\nexport default TextField;\n"]} */",
50
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextField/TextField.tsx"],"names":[],"mappings":"AAgJiB","file":"../../../src/components/TextField/TextField.tsx","sourcesContent":["import useCombinedRefs from 'hooks/useCombinedRefs';\nimport useTheme from 'hooks/useTheme';\nimport omit from 'lodash/omit';\nimport React, { InputHTMLAttributes } from 'react';\nimport { DEFAULT_SIZE } from 'utils/size-utils';\n\nimport { TestProps } from '../../utils/types';\nimport Icon from '../Icon';\nimport Label from '../Label';\nimport { IconWrapper } from './components/commons';\nimport useMultiTextFieldUtils from './hooks/useMultiTextFieldUtils';\nimport { AcceptedIconNames } from 'components/Icon/types';\nimport MultiTextFieldBase from 'components/MultiTextFieldBase/MultiTextFieldBase';\nimport { SelectOption } from 'components/Select/Select';\nimport TextInputBase, { Props as TextInputWrapperProps } from 'components/TextInputBase';\nimport { inputStyle } from 'components/TextInputBase/TextInputBase.style';\n\nexport type Props = {\n  /** The id of the text field that will be used as for in label too */\n  id?: string;\n  /** Callback fired when the `input` is blurred. */\n  onBlur?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` is changed. */\n  onChange?: React.ChangeEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` is focused. */\n  onFocus?: React.FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n  /** Callback fired when the `input` has a key down event. */\n  onKeyDown?: React.KeyboardEventHandler<HTMLTextAreaElement | HTMLInputElement>;\n  /** Callback fired when the `input` value typed is changed */\n  onInput?: React.EventHandler<any>;\n  /** @deprecated This is a compatibility prop that will be removed in the next version, along with the min-width value\n   * of the TextField. It will be replaced by a fullWidth prop. */\n  hasMinWidthCompat?: boolean;\n  /** If true the user can enter multiple values by pressing 'Enter' */\n  multi?: boolean;\n  /** The initial multi values */\n  multiValues?: string[];\n  /** Maximum multi values */\n  maxMultiValues?: number;\n  /** A callback for when a Chip value is created */\n  onMultiValueCreate?: (value?: string) => void;\n  /** A callback for when a Chip value is deleted */\n  onMultiValueDelete?: (value?: string) => void;\n  /** A callback for when all values are deleted (the Clear All icon is clicked) */\n  onClearAllValues?: () => void;\n  /** The handler of multi values. If you pass a different handler function here it will change the way multi values are being calculated */\n  multiValuesHandler?: (tags: string) => string | string[];\n} & TextInputWrapperProps;\n\nexport type InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;\n\nconsole.warn(\n  'Deprecation warning! min-width will be removed from the component in v5 of ictinus. ' +\n    'hasMinWidthCompat prop has been added to temporarily disable min-width when necessary'\n);\n\nconst TextField = React.forwardRef<HTMLInputElement, Props & InputProps & TestProps>(\n  (props, ref) => {\n    const {\n      id = undefined,\n      rightIcon = null,\n      leftIcon = null,\n      label,\n      placeholder = '',\n      required = false,\n      disabled,\n      locked = false,\n      size = DEFAULT_SIZE,\n      dark = false,\n      lean,\n      hintMsg: __hintMsg,\n      styleType: __styleType,\n      readOnly,\n      status,\n      hasMinWidthCompat = true,\n      onInput,\n      multi = false,\n      multiValues = [],\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      multiValuesHandler = (value) => value,\n      ...rest\n    } = props;\n    const theme = useTheme();\n\n    const inputRef = React.useRef<HTMLInputElement>(null);\n    const combinedRefs = useCombinedRefs(inputRef, ref);\n\n    const getIcon = (icon: AcceptedIconNames | JSX.Element | null) =>\n      icon ? (\n        typeof icon === 'string' ? (\n          <Icon\n            name={icon as AcceptedIconNames}\n            size={24}\n            color={theme.utils.getColor('lightGrey', 650)}\n          />\n        ) : (\n          icon\n        )\n      ) : null;\n\n    const handleClick = () => {\n      if (!locked && !disabled) {\n        combinedRefs.current?.focus();\n      }\n    };\n\n    const {\n      inputValue,\n      values,\n      handleValueDelete,\n      handleClearAllValues,\n      handleKeyDown,\n      handleTyping,\n    } = useMultiTextFieldUtils({\n      multiValues,\n      maxMultiValues,\n      onMultiValueCreate,\n      onMultiValueDelete,\n      onClearAllValues,\n      onInput,\n      multiValuesHandler,\n    });\n\n    return (\n      <div onClick={handleClick}>\n        {multi ? (\n          <MultiTextFieldBase\n            {...props}\n            isTextfield\n            onOptionDelete={handleValueDelete as (option?: string | SelectOption) => void}\n            onClearAllOptions={handleClearAllValues}\n            label={label}\n            onInput={handleTyping}\n            onKeyDown={handleKeyDown}\n            selectedOptions={values}\n            value={inputValue}\n            ref={combinedRefs}\n          />\n        ) : (\n          <TextInputBase {...props} hasMinWidthCompat={hasMinWidthCompat}>\n            {leftIcon && <IconWrapper iconPosition={'left'}>{getIcon(leftIcon)}</IconWrapper>}\n            <div css={{ width: '100% ' }}>\n              <input\n                readOnly={readOnly}\n                css={inputStyle({ label, placeholder, size, dark, lean, disabled, locked })}\n                placeholder={\n                  !label && placeholder ? `${placeholder} ${required ? '*' : ''}` : label\n                }\n                required={required}\n                id={id}\n                disabled={disabled || locked}\n                onInput={onInput}\n                {...omit(rest, 'dataTestId')}\n                ref={combinedRefs}\n              />\n              {label && (\n                <Label\n                  size={size}\n                  htmlFor={id}\n                  label={label}\n                  required={required}\n                  animateToTop={Boolean(rest.value)}\n                  error={status === 'error'}\n                />\n              )}\n            </div>\n            {rightIcon && !locked && (\n              <IconWrapper iconPosition={'right'}>{getIcon(rightIcon)}</IconWrapper>\n            )}\n            {locked && (\n              <IconWrapper iconPosition={'right'}>\n                <Icon\n                  name=\"lock\"\n                  size={size === 'md' ? 20 : 16}\n                  color={theme.utils.getColor('lightGrey', 650)}\n                />\n              </IconWrapper>\n            )}\n          </TextInputBase>\n        )}\n      </div>\n    );\n  }\n);\n\nTextField.displayName = 'TextField';\n\nexport default TextField;\n"]} */",
49
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
52
  };
51
53
 
@@ -92,6 +94,10 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
92
94
 
93
95
  var theme = (0, _useTheme["default"])();
94
96
 
97
+ var inputRef = _react["default"].useRef(null);
98
+
99
+ var combinedRefs = (0, _useCombinedRefs["default"])(inputRef, ref);
100
+
95
101
  var getIcon = function getIcon(icon) {
96
102
  return icon ? typeof icon === 'string' ? (0, _react2.jsx)(_Icon["default"], {
97
103
  name: icon,
@@ -100,6 +106,14 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
100
106
  }) : icon : null;
101
107
  };
102
108
 
109
+ var handleClick = function handleClick() {
110
+ if (!locked && !disabled) {
111
+ var _combinedRefs$current;
112
+
113
+ (_combinedRefs$current = combinedRefs.current) == null ? void 0 : _combinedRefs$current.focus();
114
+ }
115
+ };
116
+
103
117
  var _useMultiTextFieldUti = (0, _useMultiTextFieldUtils["default"])({
104
118
  multiValues: multiValues,
105
119
  maxMultiValues: maxMultiValues,
@@ -116,7 +130,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
116
130
  handleKeyDown = _useMultiTextFieldUti.handleKeyDown,
117
131
  handleTyping = _useMultiTextFieldUti.handleTyping;
118
132
 
119
- return multi ? (0, _react2.jsx)(_MultiTextFieldBase["default"], _extends({}, props, {
133
+ return (0, _react2.jsx)("div", {
134
+ onClick: handleClick
135
+ }, multi ? (0, _react2.jsx)(_MultiTextFieldBase["default"], _extends({}, props, {
120
136
  isTextfield: true,
121
137
  onOptionDelete: handleValueDelete,
122
138
  onClearAllOptions: handleClearAllValues,
@@ -124,8 +140,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
124
140
  onInput: handleTyping,
125
141
  onKeyDown: handleKeyDown,
126
142
  selectedOptions: values,
127
- value: inputValue
128
- })) : (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)(_TextInputBase["default"], _extends({}, props, {
143
+ value: inputValue,
144
+ ref: combinedRefs
145
+ })) : (0, _react2.jsx)(_TextInputBase["default"], _extends({}, props, {
129
146
  hasMinWidthCompat: hasMinWidthCompat
130
147
  }), leftIcon && (0, _react2.jsx)(_commons.IconWrapper, {
131
148
  iconPosition: 'left'
@@ -138,7 +155,9 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
138
155
  placeholder: placeholder,
139
156
  size: size,
140
157
  dark: dark,
141
- lean: lean
158
+ lean: lean,
159
+ disabled: disabled,
160
+ locked: locked
142
161
  }),
143
162
  placeholder: !label && placeholder ? placeholder + " " + (required ? '*' : '') : label,
144
163
  required: required,
@@ -146,7 +165,7 @@ var TextField = /*#__PURE__*/_react["default"].forwardRef(function (props, ref)
146
165
  disabled: disabled || locked,
147
166
  onInput: onInput
148
167
  }, (0, _omit["default"])(rest, 'dataTestId'), {
149
- ref: ref
168
+ ref: combinedRefs
150
169
  })), label && (0, _react2.jsx)(_Label["default"], {
151
170
  size: size,
152
171
  htmlFor: id,
@@ -71,7 +71,9 @@ var TextInputBase = function TextInputBase(_ref) {
71
71
  }, (0, _react2.jsx)("div", {
72
72
  css: (0, _TextInputBase.textFieldStyle)({
73
73
  lean: lean,
74
- sx: sx
74
+ sx: sx,
75
+ disabled: disabled,
76
+ locked: locked
75
77
  })
76
78
  }, children)), hintMsg && status !== 'normal' && hintMessageToShow);
77
79
  };
@@ -6,6 +6,6 @@ import { Props } from './TextInputBase';
6
6
  * in custom implementation needed eg: datepicker
7
7
  * */
8
8
  export declare const wrapperStyle: ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) => (theme: Theme) => SerializedStyles;
9
- export declare const textFieldStyle: ({ lean, sx }: Props) => (theme: Theme) => SerializedStyles;
10
- export declare const inputStyle: ({ label, placeholder, size, dark, sx }: Props) => (theme: Theme) => SerializedStyles;
9
+ export declare const textFieldStyle: ({ lean, sx, disabled, locked }: Props) => (theme: Theme) => SerializedStyles;
10
+ export declare const inputStyle: ({ label, placeholder, size, dark, sx, disabled, locked }: Props) => (theme: Theme) => SerializedStyles;
11
11
  export declare const errorMsgStyle: ({ status }: Props) => (theme: Theme) => SerializedStyles;
@@ -87,8 +87,8 @@ var wrapperStyle = function wrapperStyle(_ref) {
87
87
  borderRadius: theme.spacing.xsm,
88
88
  userSelect: 'none',
89
89
  opacity: disabled ? (0, _states.getDisabled)().opacity : 1,
90
- cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'auto'
91
- }, textFieldSize, wrapperStyleSwitch(theme, colorScheme, lean, error, Boolean(disabled || locked), isInteractive), sx == null ? void 0 : sx.wrapper), process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RVciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RVciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
90
+ cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text'
91
+ }, textFieldSize, wrapperStyleSwitch(theme, colorScheme, lean, error, Boolean(disabled || locked), isInteractive), sx == null ? void 0 : sx.wrapper), process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAwEW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAwEW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
92
92
  );
93
93
  };
94
94
  };
@@ -97,7 +97,9 @@ exports.wrapperStyle = wrapperStyle;
97
97
 
98
98
  var textFieldStyle = function textFieldStyle(_ref2) {
99
99
  var lean = _ref2.lean,
100
- sx = _ref2.sx;
100
+ sx = _ref2.sx,
101
+ disabled = _ref2.disabled,
102
+ locked = _ref2.locked;
101
103
  return function (theme) {
102
104
  return (
103
105
  /*#__PURE__*/
@@ -111,10 +113,11 @@ var textFieldStyle = function textFieldStyle(_ref2) {
111
113
  verticalAlign: 'top',
112
114
  width: 'fill-available',
113
115
  padding: !lean ? "0 " + theme.spacing.md : '',
116
+ cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text',
114
117
  '> div': {
115
118
  position: 'relative'
116
119
  }
117
- }, sx == null ? void 0 : sx.textField), process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR1ciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzR1ciLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
120
+ }, sx == null ? void 0 : sx.textField), process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAsGW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:textFieldStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AAsGW","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
118
121
  );
119
122
  };
120
123
  };
@@ -127,7 +130,9 @@ var inputStyle = function inputStyle(_ref3) {
127
130
  _ref3$size = _ref3.size,
128
131
  size = _ref3$size === void 0 ? _sizeUtils.DEFAULT_SIZE : _ref3$size,
129
132
  dark = _ref3.dark,
130
- sx = _ref3.sx;
133
+ sx = _ref3.sx,
134
+ disabled = _ref3.disabled,
135
+ locked = _ref3.locked;
131
136
  return function (theme) {
132
137
  return (
133
138
  /*#__PURE__*/
@@ -146,7 +151,8 @@ var inputStyle = function inputStyle(_ref3) {
146
151
  width: 0,
147
152
  minWidth: '100%',
148
153
  '& + label': {
149
- fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12']
154
+ fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],
155
+ cursor: disabled || locked ? (0, _states.getDisabled)().cursor : 'text'
150
156
  },
151
157
  '&:focus': {
152
158
  outline: 'none'
@@ -168,7 +174,7 @@ var inputStyle = function inputStyle(_ref3) {
168
174
  '&:disabled': {
169
175
  cursor: 'not-allowed'
170
176
  }
171
- }, sx == null ? void 0 : sx.input), process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwSEkiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwSEkiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
177
+ }, sx == null ? void 0 : sx.input), process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA2HI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:inputStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA2HI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
172
178
  );
173
179
  };
174
180
  };
@@ -195,7 +201,7 @@ var errorMsgStyle = function errorMsgStyle(_ref4) {
195
201
  alignItems: 'stretch',
196
202
  padding: "0 " + (0, _utils.rem)(2)
197
203
  }
198
- }, process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0S0kiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RleHRJbnB1dEJhc2UvVGV4dElucHV0QmFzZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0S0kiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9UZXh0SW5wdXRCYXNlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5pbXBvcnQgeyBERUZBVUxUX1NJWkUsIGdldFRleHRGaWVsZFNpemUgfSBmcm9tICd1dGlscy9zaXplLXV0aWxzJztcblxuaW1wb3J0IHsgZ2V0RGlzYWJsZWQsIGdldEhvdmVyLCBnZXRQcmVzc2VkIH0gZnJvbSAnLi4vLi4vdGhlbWUvc3RhdGVzJztcbmltcG9ydCB7IENvbG9yU2NoZW1lIH0gZnJvbSAnLi4vLi4vdGhlbWUvdHlwZXMnO1xuaW1wb3J0IHsgdGV4dElucHV0Q29uZmlnIH0gZnJvbSAnLi9jb25maWcnO1xuaW1wb3J0IHsgUHJvcHMgfSBmcm9tICcuL1RleHRJbnB1dEJhc2UnO1xuaW1wb3J0IHsgTEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lORyB9IGZyb20gJ2NvbXBvbmVudHMvTGFiZWwvTGFiZWwuc3R5bGUnO1xuXG5jb25zdCB3cmFwcGVyU3R5bGVTd2l0Y2ggPSAoXG4gIHRoZW1lOiBUaGVtZSxcbiAgY29sb3JTY2hlbWU6IENvbG9yU2NoZW1lID0gJ2xpZ2h0JyxcbiAgbGVhbj86IGJvb2xlYW4sXG4gIGVycm9yPzogYm9vbGVhbixcbiAgZGlzYWJsZWQ/OiBib29sZWFuLFxuICBpc0ludGVyYWN0aXZlPzogYm9vbGVhblxuKSA9PiB7XG4gIGlmIChsZWFuKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogJ3RyYW5zcGFyZW50JyxcbiAgICB9O1xuICB9XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIGNvbnN0IGJhY2tncm91bmRDb2xvciA9XG4gICAgY29sb3JTY2hlbWUgPT09ICdkYXJrJyA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDcwMCkgOiB0aGVtZS5wYWxldHRlLndoaXRlO1xuICBjb25zdCBib3JkZXJDb2xvck5hbWUgPSAhZXJyb3IgPyBib3JkZXJDb25maWcuY29sb3IucHJlc3NlZC5uYW1lIDogYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWU7XG4gIGNvbnN0IGJvcmRlckNvbG9yU2hhZGUgPSAhZXJyb3JcbiAgICA/IGJvcmRlckNvbmZpZy5jb2xvci5wcmVzc2VkLnNoYWRlXG4gICAgOiBib3JkZXJDb25maWcuY29sb3IuZXJyb3Iuc2hhZGU7XG5cbiAgY29uc3QgZXZlbnRzID0gZGlzYWJsZWRcbiAgICA/IHtcbiAgICAgICAgJyY6Zm9jdXMtd2l0aGluJzoge1xuICAgICAgICAgIGJveFNoYWRvdzogYDAgMCAwICR7cmVtKDEpfSB0cmFuc3BhcmVudGAsXG4gICAgICAgIH0sXG4gICAgICB9XG4gICAgOiB7XG4gICAgICAgICcmOmhvdmVyJzoge1xuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogZ2V0SG92ZXIoeyB0aGVtZSB9KS5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAgIH0sXG4gICAgICAgICcmOmZvY3VzLXdpdGhpbic6IHtcbiAgICAgICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGggKyAxKX0gJHt0aGVtZS51dGlscy5nZXRDb2xvcihcbiAgICAgICAgICAgIGJvcmRlckNvbG9yTmFtZSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yU2hhZGVcbiAgICAgICAgICApfWAsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiBnZXRQcmVzc2VkKHsgdGhlbWUgfSkuYmFja2dyb3VuZENvbG9yLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICByZXR1cm4ge1xuICAgIGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZENvbG9yLFxuICAgIC4uLihpc0ludGVyYWN0aXZlID8gZXZlbnRzIDoge30pLFxuICB9O1xufTtcblxuLyoqXG4gKiB0aGlzIHdyYXBwZXIgbXVzdCByZW1haW4gc2ltcGxlIGFuZCBub3QgbWVzcyB3aXRoIGNoaWxkcmVuIHByb3BlcnRpZXMgYXMgaXQgd2lsbCBiZSB1c2VkXG4gKiBpbiBjdXN0b20gaW1wbGVtZW50YXRpb24gbmVlZGVkIGVnOiBkYXRlcGlja2VyXG4gKiAqL1xuZXhwb3J0IGNvbnN0IHdyYXBwZXJTdHlsZSA9XG4gICh7IGRpc2FibGVkLCBsb2NrZWQsIHN0YXR1cywgbGVhbiwgZGFyaywgc2l6ZSwgc3gsIGlzSW50ZXJhY3RpdmUsIGhhc01pbldpZHRoQ29tcGF0IH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PiB7XG4gICAgY29uc3QgY29sb3JTY2hlbWUgPSBkYXJrID8gJ2RhcmsnIDogdGhlbWUuY29sb3JTY2hlbWU7XG4gICAgY29uc3QgZXJyb3IgPSBzdGF0dXMgPT09ICdlcnJvcic7XG4gICAgY29uc3QgdGV4dEZpZWxkU2l6ZSA9ICFsZWFuXG4gICAgICA/IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQsIHNpemUpXG4gICAgICA6IGdldFRleHRGaWVsZFNpemUoaGFzTWluV2lkdGhDb21wYXQpO1xuICAgIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1tjb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gICAgcmV0dXJuIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgdHJhbnNpdGlvbjogYGJhY2tncm91bmQtY29sb3IgMC4yNXMsIGJveC1zaGFkb3cgMC4yNXMsIGJvcmRlci1jb2xvciAwLjI1c2AsXG4gICAgICBib3hTaGFkb3c6IGAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfSAke1xuICAgICAgICBlcnJvclxuICAgICAgICAgID8gdGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmVycm9yLm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5lcnJvci5zaGFkZSlcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKVxuICAgICAgfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnNwYWNpbmcueHNtLFxuICAgICAgdXNlclNlbGVjdDogJ25vbmUnLFxuICAgICAgb3BhY2l0eTogZGlzYWJsZWQgPyBnZXREaXNhYmxlZCgpLm9wYWNpdHkgOiAxLFxuICAgICAgY3Vyc29yOiBkaXNhYmxlZCB8fCBsb2NrZWQgPyBnZXREaXNhYmxlZCgpLmN1cnNvciA6ICdhdXRvJyxcbiAgICAgIC4uLnRleHRGaWVsZFNpemUsXG4gICAgICAuLi53cmFwcGVyU3R5bGVTd2l0Y2goXG4gICAgICAgIHRoZW1lLFxuICAgICAgICBjb2xvclNjaGVtZSxcbiAgICAgICAgbGVhbixcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIEJvb2xlYW4oZGlzYWJsZWQgfHwgbG9ja2VkKSxcbiAgICAgICAgaXNJbnRlcmFjdGl2ZVxuICAgICAgKSxcbiAgICAgIC4uLnN4Py53cmFwcGVyLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkU3R5bGUgPVxuICAoeyBsZWFuLCBzeCB9OiBQcm9wcykgPT5cbiAgKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4ge1xuICAgIHJldHVybiBjc3Moe1xuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgICAgZmxleERpcmVjdGlvbjogJ3JvdycsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIHZlcnRpY2FsQWxpZ246ICd0b3AnLFxuICAgICAgd2lkdGg6ICdmaWxsLWF2YWlsYWJsZScsXG4gICAgICBwYWRkaW5nOiAhbGVhbiA/IGAwICR7dGhlbWUuc3BhY2luZy5tZH1gIDogJycsXG5cbiAgICAgICc+IGRpdic6IHtcbiAgICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB9LFxuXG4gICAgICAuLi5zeD8udGV4dEZpZWxkLFxuICAgIH0pO1xuICB9O1xuXG5leHBvcnQgY29uc3QgaW5wdXRTdHlsZSA9XG4gICh7IGxhYmVsLCBwbGFjZWhvbGRlciwgc2l6ZSA9IERFRkFVTFRfU0laRSwgZGFyaywgc3ggfTogUHJvcHMpID0+XG4gICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+XG4gICAgY3NzKHtcbiAgICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gICAgICBib3JkZXI6ICdub25lJyxcbiAgICAgIGNvbG9yOlxuICAgICAgICB0aGVtZS5jb2xvclNjaGVtZSA9PT0gJ2RhcmsnIHx8IGRhcmtcbiAgICAgICAgICA/IHRoZW1lLnBhbGV0dGUud2hpdGVcbiAgICAgICAgICA6IHRoZW1lLnV0aWxzLmdldENvbG9yKCdkYXJrR3JleScsIDg1MCksXG4gICAgICBkaXNwbGF5OiAnYmxvY2snLFxuICAgICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgICB0b3A6IGxhYmVsID8gcmVtKDcpIDogdW5kZWZpbmVkLFxuICAgICAgekluZGV4OiAxLFxuICAgICAgZm9udFNpemU6IHRoZW1lLnR5cG9ncmFwaHkuZm9udFNpemVzW3NpemUgPT09ICdtZCcgPyAnMTUnIDogJzEyJ10sXG4gICAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgICB3aWR0aDogMCxcbiAgICAgIG1pbldpZHRoOiAnMTAwJScsXG5cbiAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgIGZvbnRTaXplOiB0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbWQnID8gJzE1JyA6ICcxMiddLFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMnOiB7XG4gICAgICAgIG91dGxpbmU6ICdub25lJyxcbiAgICAgIH0sXG5cbiAgICAgICcmOjpwbGFjZWhvbGRlcic6IHtcbiAgICAgICAgY29sb3I6ICFsYWJlbCAmJiBwbGFjZWhvbGRlciA/IHRoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApIDogJ3RyYW5zcGFyZW50JyxcbiAgICAgIH0sXG5cbiAgICAgICcmOm5vdCg6Zm9jdXMpOnBsYWNlaG9sZGVyLXNob3duJzoge1xuICAgICAgICAnJiArIGxhYmVsJzoge1xuICAgICAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6Zm9jdXMsICY6bm90KDpwbGFjZWhvbGRlci1zaG93biknOiB7XG4gICAgICAgICcmICsgbGFiZWwnOiB7XG4gICAgICAgICAgdHJhbnNmb3JtOiBgdHJhbnNsYXRlKCR7TEFCRUxfVFJBTlNGT1JNX0xFRlRfU1BBQ0lOR30sIC0zNSUpIHNjYWxlKDAuOClgLFxuICAgICAgICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkLFxuICAgICAgICB9LFxuICAgICAgfSxcblxuICAgICAgJyY6ZGlzYWJsZWQnOiB7XG4gICAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICAgIH0sXG4gICAgICAuLi5zeD8uaW5wdXQsXG4gICAgfSk7XG5cbmV4cG9ydCBjb25zdCBlcnJvck1zZ1N0eWxlID1cbiAgKHsgc3RhdHVzIH06IFByb3BzKSA9PlxuICAodGhlbWU6IFRoZW1lKTogU2VyaWFsaXplZFN0eWxlcyA9PlxuICAgIGNzcyh7XG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBjb2xvcjpcbiAgICAgICAgc3RhdHVzID09PSAnZXJyb3InXG4gICAgICAgICAgPyB0aGVtZS51dGlscy5nZXRDb2xvcignZXJyb3InLCA1NTAsICdub3JtYWwnKVxuICAgICAgICAgIDogdGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDY1MCksXG4gICAgICBmb250U2l6ZTogdGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbJzEyJ10sXG4gICAgICBsaW5lSGVpZ2h0OiAxLFxuICAgICAgcGFkZGluZzogYCR7cmVtKDgpfSAwIDBgLFxuICAgICAgc3ZnOiB7XG4gICAgICAgIHBhZGRpbmc6IGAwICR7cmVtKDIpfWAsXG4gICAgICB9LFxuXG4gICAgICBzcGFuOiB7XG4gICAgICAgIGFsaWduSXRlbXM6ICdzdHJldGNoJyxcbiAgICAgICAgcGFkZGluZzogYDAgJHtyZW0oMil9YCxcbiAgICAgIH0sXG4gICAgfSk7XG4iXX0= */")
204
+ }, process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA+KI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:errorMsgStyle;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/TextInputBase/TextInputBase.style.ts"],"names":[],"mappings":"AA+KI","file":"../../../src/components/TextInputBase/TextInputBase.style.ts","sourcesContent":["import { css, SerializedStyles } from '@emotion/react';\nimport { Theme } from 'theme';\nimport { rem } from 'theme/utils';\nimport { DEFAULT_SIZE, getTextFieldSize } from 'utils/size-utils';\n\nimport { getDisabled, getHover, getPressed } from '../../theme/states';\nimport { ColorScheme } from '../../theme/types';\nimport { textInputConfig } from './config';\nimport { Props } from './TextInputBase';\nimport { LABEL_TRANSFORM_LEFT_SPACING } from 'components/Label/Label.style';\n\nconst wrapperStyleSwitch = (\n  theme: Theme,\n  colorScheme: ColorScheme = 'light',\n  lean?: boolean,\n  error?: boolean,\n  disabled?: boolean,\n  isInteractive?: boolean\n) => {\n  if (lean) {\n    return {\n      backgroundColor: 'transparent',\n    };\n  }\n  const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n  const backgroundColor =\n    colorScheme === 'dark' ? theme.utils.getColor('darkGrey', 700) : theme.palette.white;\n  const borderColorName = !error ? borderConfig.color.pressed.name : borderConfig.color.error.name;\n  const borderColorShade = !error\n    ? borderConfig.color.pressed.shade\n    : borderConfig.color.error.shade;\n\n  const events = disabled\n    ? {\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(1)} transparent`,\n        },\n      }\n    : {\n        '&:hover': {\n          backgroundColor: getHover({ theme }).backgroundColor,\n        },\n        '&:focus-within': {\n          boxShadow: `0 0 0 ${rem(borderConfig.width + 1)} ${theme.utils.getColor(\n            borderColorName,\n            borderColorShade\n          )}`,\n          backgroundColor: getPressed({ theme }).backgroundColor,\n        },\n      };\n\n  return {\n    backgroundColor: backgroundColor,\n    ...(isInteractive ? events : {}),\n  };\n};\n\n/**\n * this wrapper must remain simple and not mess with children properties as it will be used\n * in custom implementation needed eg: datepicker\n * */\nexport const wrapperStyle =\n  ({ disabled, locked, status, lean, dark, size, sx, isInteractive, hasMinWidthCompat }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    const colorScheme = dark ? 'dark' : theme.colorScheme;\n    const error = status === 'error';\n    const textFieldSize = !lean\n      ? getTextFieldSize(hasMinWidthCompat, size)\n      : getTextFieldSize(hasMinWidthCompat);\n    const borderConfig = textInputConfig.types[colorScheme].outlined.border;\n\n    return css({\n      display: 'flex',\n      alignItems: 'center',\n      position: 'relative',\n      transition: `background-color 0.25s, box-shadow 0.25s, border-color 0.25s`,\n      boxShadow: `0 0 0 ${rem(borderConfig.width)} ${\n        error\n          ? theme.utils.getColor(borderConfig.color.error.name, borderConfig.color.error.shade)\n          : theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)\n      }`,\n      borderRadius: theme.spacing.xsm,\n      userSelect: 'none',\n      opacity: disabled ? getDisabled().opacity : 1,\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n      ...textFieldSize,\n      ...wrapperStyleSwitch(\n        theme,\n        colorScheme,\n        lean,\n        error,\n        Boolean(disabled || locked),\n        isInteractive\n      ),\n      ...sx?.wrapper,\n    });\n  };\n\nexport const textFieldStyle =\n  ({ lean, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles => {\n    return css({\n      position: 'relative',\n      display: 'inline-flex',\n      flexDirection: 'row',\n      alignItems: 'center',\n      verticalAlign: 'top',\n      width: 'fill-available',\n      padding: !lean ? `0 ${theme.spacing.md}` : '',\n      cursor: disabled || locked ? getDisabled().cursor : 'text',\n\n      '> div': {\n        position: 'relative',\n      },\n\n      ...sx?.textField,\n    });\n  };\n\nexport const inputStyle =\n  ({ label, placeholder, size = DEFAULT_SIZE, dark, sx, disabled, locked }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      background: 'transparent',\n      border: 'none',\n      color:\n        theme.colorScheme === 'dark' || dark\n          ? theme.palette.white\n          : theme.utils.getColor('darkGrey', 850),\n      display: 'block',\n      position: 'relative',\n      top: label ? rem(7) : undefined,\n      zIndex: 1,\n      fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n      textOverflow: 'ellipsis',\n      width: 0,\n      minWidth: '100%',\n\n      '& + label': {\n        fontSize: theme.typography.fontSizes[size === 'md' ? '15' : '12'],\n\n        cursor: disabled || locked ? getDisabled().cursor : 'text',\n      },\n\n      '&:focus': {\n        outline: 'none',\n      },\n\n      '&::placeholder': {\n        color: !label && placeholder ? theme.utils.getColor('lightGrey', 650) : 'transparent',\n      },\n\n      '&:not(:focus):placeholder-shown': {\n        '& + label': {\n          fontWeight: 'normal',\n        },\n      },\n\n      '&:focus, &:not(:placeholder-shown)': {\n        '& + label': {\n          transform: `translate(${LABEL_TRANSFORM_LEFT_SPACING}, -35%) scale(0.8)`,\n          fontWeight: theme.typography.weights.bold,\n        },\n      },\n\n      '&:disabled': {\n        cursor: 'not-allowed',\n      },\n      ...sx?.input,\n    });\n\nexport const errorMsgStyle =\n  ({ status }: Props) =>\n  (theme: Theme): SerializedStyles =>\n    css({\n      display: 'flex',\n      color:\n        status === 'error'\n          ? theme.utils.getColor('error', 550, 'normal')\n          : theme.utils.getColor('lightGrey', 650),\n      fontSize: theme.typography.fontSizes['12'],\n      lineHeight: 1,\n      padding: `${rem(8)} 0 0`,\n      svg: {\n        padding: `0 ${rem(2)}`,\n      },\n\n      span: {\n        alignItems: 'stretch',\n        padding: `0 ${rem(2)}`,\n      },\n    });\n"]} */")
199
205
  );
200
206
  };
201
207
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@orfium/ictinus",
3
- "version": "4.68.0",
3
+ "version": "4.69.0",
4
4
  "main": "./dist/index.js",
5
5
  "types": "./dist/index.d.ts",
6
6
  "license": "MIT",