@commercetools-uikit/selectable-search-input 16.12.0 → 17.0.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.
package/README.md CHANGED
@@ -47,6 +47,8 @@ const Example = () => (
47
47
  { value: 'one', label: 'One' },
48
48
  { value: 'two', label: 'Two' },
49
49
  ]}
50
+ selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}
51
+ inputDataProps={[{ 'prop-3': 'value-1' }, { 'prop-4': 'value-2' }]}
50
52
  />
51
53
  );
52
54
 
@@ -87,6 +89,8 @@ export default Example;
87
89
  | `closeMenuOnSelect` | `ReactSelectProps['closeMenuOnSelect']` | | | Whether the menu should close after a value is selected. Defaults to `true`.&#xA;<br>&#xA;[Props from React select was used](https://react-select.com/props) |
88
90
  | `menuHorizontalConstraint` | `union`<br/>Possible values:<br/>`3 , 4 , 5` | | `3` | Horizontal size limit for the dropdown menu. |
89
91
  | `showSubmitButton` | `boolean` | | `true` | Show submit button in the input |
92
+ | `selectDataProps` | `Record<string, string>` | | | used to pass `data-*` props to the select component.&#xA;eg: selectDataProps={\[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]} |
93
+ | `inputDataProps` | `Record<string, string>` | | | used to pass `data-*` props to the input element.&#xA;eg: inputDataProps={\[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]} |
90
94
 
91
95
  ## Signatures
92
96
 
@@ -14,6 +14,9 @@ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
15
  var _styled = require('@emotion/styled/base');
16
16
  var _pt = require('prop-types');
17
+ var _Object$fromEntries = require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
18
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
19
+ var _Object$entries = require('@babel/runtime-corejs3/core-js-stable/object/entries');
17
20
  var _flatMapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat-map');
18
21
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
19
22
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
@@ -44,6 +47,9 @@ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$def
44
47
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
45
48
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
46
49
  var _pt__default = /*#__PURE__*/_interopDefault(_pt);
50
+ var _Object$fromEntries__default = /*#__PURE__*/_interopDefault(_Object$fromEntries);
51
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
52
+ var _Object$entries__default = /*#__PURE__*/_interopDefault(_Object$entries);
47
53
  var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
48
54
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
49
55
  var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
@@ -181,22 +187,25 @@ const createSelectableSelectStyles = _ref => {
181
187
  });
182
188
  };
183
189
 
184
- const _excluded = ["id"];
190
+ const _excluded = ["id", "dataProps"];
185
191
  function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
186
192
  function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
187
193
  const SingleValue = _ref => {
188
194
  let id = _ref.id,
195
+ dataProps = _ref.dataProps,
189
196
  props = _objectWithoutProperties(_ref, _excluded);
190
197
  return jsxRuntime.jsx(Select.components.SingleValue, _objectSpread$1(_objectSpread$1({}, props), {}, {
191
- children: jsxRuntime.jsx("label", {
192
- htmlFor: id,
198
+ children: jsxRuntime.jsx("label", _objectSpread$1(_objectSpread$1({
199
+ htmlFor: id
200
+ }, dataProps), {}, {
193
201
  children: props.children
194
- })
202
+ }))
195
203
  }));
196
204
  };
197
205
  SingleValue.propTypes = process.env.NODE_ENV !== "production" ? {
198
- id: _pt__default["default"].string,
199
- children: _pt__default["default"].node
206
+ children: _pt__default["default"].node,
207
+ dataProps: _pt__default["default"].objectOf(_pt__default["default"].string),
208
+ id: _pt__default["default"].string
200
209
  } : {};
201
210
  const SelectableSelect = props => {
202
211
  const intl = reactIntl.useIntl();
@@ -234,9 +243,10 @@ const SelectableSelect = props => {
234
243
  maxMenuHeight: props.maxMenuHeight,
235
244
  closeMenuOnSelect: props.closeMenuOnSelect,
236
245
  components: {
237
- SingleValue: innerProps => jsxRuntime.jsx(SingleValue, _objectSpread$1(_objectSpread$1({}, innerProps), {}, {
238
- id: props.id
239
- })),
246
+ SingleValue: innerProps => jsxRuntime.jsx(SingleValue, _objectSpread$1({
247
+ id: props.id,
248
+ dataProps: props.dataProps
249
+ }, innerProps)),
240
250
  DropdownIndicator: selectUtils.DropdownIndicator
241
251
  },
242
252
  options: props.options,
@@ -262,12 +272,13 @@ SelectableSelect.propTypes = process.env.NODE_ENV !== "production" ? {
262
272
  handleDropdownFocus: _pt__default["default"].func.isRequired,
263
273
  handleDropdownBlur: _pt__default["default"].func.isRequired,
264
274
  textInputRef: _pt__default["default"].any.isRequired,
265
- selectedOption: _pt__default["default"].any
275
+ selectedOption: _pt__default["default"].any,
276
+ dataProps: _pt__default["default"].objectOf(_pt__default["default"].string)
266
277
  } : {};
267
278
  var SelectableSelect$1 = SelectableSelect;
268
279
 
269
280
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
270
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
281
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context5 = ownKeys(Object(source))).call(_context5, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
271
282
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
272
283
  const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
273
284
  target: "encv1cf0"
@@ -280,7 +291,7 @@ const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NO
280
291
  } : {
281
292
  name: "zjik7",
282
293
  styles: "display:flex",
283
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA+B4B","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */",
294
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA+B4B","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */",
284
295
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
285
296
  });
286
297
  const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
@@ -295,8 +306,17 @@ const defaultProps = {
295
306
  };
296
307
  const selectableSearchInputSequentialId = utils.createSequentialId('selectable-search-input-');
297
308
  const isOptionObject = option => option.options !== undefined;
298
- const SelectableSearchInput = props => {
309
+ const transformDataProps = dataProps => {
299
310
  var _context;
311
+ return _Object$fromEntries__default["default"](_mapInstanceProperty__default["default"](_context = _Object$entries__default["default"](dataProps || {})).call(_context, _ref => {
312
+ let _ref2 = _slicedToArray(_ref, 2),
313
+ key = _ref2[0],
314
+ value = _ref2[1];
315
+ return ["data-".concat(key), value];
316
+ }));
317
+ };
318
+ const SelectableSearchInput = props => {
319
+ var _context2;
300
320
  const _useToggleState = hooks.useToggleState(false),
301
321
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
302
322
  dropdownHasFocus = _useToggleState2[0],
@@ -307,7 +327,10 @@ const SelectableSearchInput = props => {
307
327
  setSearchValue = _useState2[1];
308
328
  const containerRef = react$1.useRef(null);
309
329
  const textInputRef = react$1.useRef(null);
310
- const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context = props.options).call(_context, option => {
330
+ const legacyDataProps = utils.filterDataAttributes(props);
331
+ const transformedSelectDataProps = transformDataProps(props.selectDataProps);
332
+ const transformedInputDataProps = transformDataProps(props.inputDataProps);
333
+ const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context2 = props.options).call(_context2, option => {
311
334
  if (isOptionObject(option)) {
312
335
  return option.options;
313
336
  }
@@ -432,11 +455,12 @@ const SelectableSearchInput = props => {
432
455
  handleDropdownFocus: handleDropdownFocus,
433
456
  handleDropdownBlur: handleDropdownBlur,
434
457
  textInputRef: textInputRef,
435
- selectedOption: selectedOption
458
+ selectedOption: selectedOption,
459
+ dataProps: transformedSelectDataProps
436
460
  }))
437
461
  }), jsxRuntime.jsxs("div", {
438
- css: [getSelectableSearchInputContainerStyles(props), dropdownHasFocus && !props.isReadOnly && /*#__PURE__*/react.css("border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";&:hover{border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAsZiB","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAkZU","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"],
439
- children: [jsxRuntime.jsx("input", _objectSpread(_objectSpread({
462
+ css: [getSelectableSearchInputContainerStyles(props), dropdownHasFocus && !props.isReadOnly && /*#__PURE__*/react.css("border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";&:hover{border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA6aiB","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAyaU","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"],
463
+ children: [jsxRuntime.jsx("input", _objectSpread(_objectSpread(_objectSpread({
440
464
  ref: textInputRef,
441
465
  id: SelectableSearchInput.getTextInputId(selectablSearchInputId),
442
466
  name: getTextInputName(props.name),
@@ -453,7 +477,7 @@ const SelectableSearchInput = props => {
453
477
  "aria-readonly": props.isReadOnly,
454
478
  contentEditable: !props.isReadOnly,
455
479
  css: getSelectableSearchInputStyles(props)
456
- }, utils.filterDataAttributes(props)), {}, {
480
+ }, transformedInputDataProps), legacyDataProps), {}, {
457
481
  /* ARIA */
458
482
  "aria-invalid": props['aria-invalid'],
459
483
  "aria-errormessage": props['aria-errormessage'],
@@ -514,20 +538,22 @@ SelectableSearchInput.propTypes = process.env.NODE_ENV !== "production" ? {
514
538
  }))]).isRequired,
515
539
  menuPortalZIndex: _pt__default["default"].number,
516
540
  menuHorizontalConstraint: _pt__default["default"].oneOf([3, 4, 5]),
517
- showSubmitButton: _pt__default["default"].bool
541
+ showSubmitButton: _pt__default["default"].bool,
542
+ selectDataProps: _pt__default["default"].objectOf(_pt__default["default"].string),
543
+ inputDataProps: _pt__default["default"].objectOf(_pt__default["default"].string)
518
544
  } : {};
519
545
  SelectableSearchInput.displayName = 'SelectableSearchInput';
520
546
  SelectableSearchInput.defaultProps = defaultProps;
521
547
  SelectableSearchInput.isEmpty = formValue => {
522
- var _context2;
523
- return !formValue || _trimInstanceProperty__default["default"](_context2 = formValue.text).call(_context2) === '';
548
+ var _context3;
549
+ return !formValue || _trimInstanceProperty__default["default"](_context3 = formValue.text).call(_context3) === '';
524
550
  };
525
551
  SelectableSearchInput.getTextInputId = getTextInputName;
526
552
  SelectableSearchInput.getDropdownId = getDropdownName;
527
553
  var SelectableSearchInput$1 = SelectableSearchInput;
528
554
 
529
555
  // NOTE: This string will be replaced on build time with the package version.
530
- var version = "16.12.0";
556
+ var version = "17.0.0";
531
557
 
532
558
  exports["default"] = SelectableSearchInput$1;
533
559
  exports.version = version;
@@ -14,6 +14,9 @@ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
14
14
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
15
15
  var _styled = require('@emotion/styled/base');
16
16
  require('prop-types');
17
+ var _Object$fromEntries = require('@babel/runtime-corejs3/core-js-stable/object/from-entries');
18
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
19
+ var _Object$entries = require('@babel/runtime-corejs3/core-js-stable/object/entries');
17
20
  var _flatMapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/flat-map');
18
21
  var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
19
22
  var _trimInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/trim');
@@ -43,6 +46,9 @@ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_O
43
46
  var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
44
47
  var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
45
48
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
49
+ var _Object$fromEntries__default = /*#__PURE__*/_interopDefault(_Object$fromEntries);
50
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
51
+ var _Object$entries__default = /*#__PURE__*/_interopDefault(_Object$entries);
46
52
  var _flatMapInstanceProperty__default = /*#__PURE__*/_interopDefault(_flatMapInstanceProperty);
47
53
  var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
48
54
  var _trimInstanceProperty__default = /*#__PURE__*/_interopDefault(_trimInstanceProperty);
@@ -180,17 +186,19 @@ const createSelectableSelectStyles = _ref => {
180
186
  });
181
187
  };
182
188
 
183
- const _excluded = ["id"];
189
+ const _excluded = ["id", "dataProps"];
184
190
  function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
185
191
  function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
186
192
  const SingleValue = _ref => {
187
193
  let id = _ref.id,
194
+ dataProps = _ref.dataProps,
188
195
  props = _objectWithoutProperties(_ref, _excluded);
189
196
  return jsxRuntime.jsx(Select.components.SingleValue, _objectSpread$1(_objectSpread$1({}, props), {}, {
190
- children: jsxRuntime.jsx("label", {
191
- htmlFor: id,
197
+ children: jsxRuntime.jsx("label", _objectSpread$1(_objectSpread$1({
198
+ htmlFor: id
199
+ }, dataProps), {}, {
192
200
  children: props.children
193
- })
201
+ }))
194
202
  }));
195
203
  };
196
204
  SingleValue.propTypes = {};
@@ -230,9 +238,10 @@ const SelectableSelect = props => {
230
238
  maxMenuHeight: props.maxMenuHeight,
231
239
  closeMenuOnSelect: props.closeMenuOnSelect,
232
240
  components: {
233
- SingleValue: innerProps => jsxRuntime.jsx(SingleValue, _objectSpread$1(_objectSpread$1({}, innerProps), {}, {
234
- id: props.id
235
- })),
241
+ SingleValue: innerProps => jsxRuntime.jsx(SingleValue, _objectSpread$1({
242
+ id: props.id,
243
+ dataProps: props.dataProps
244
+ }, innerProps)),
236
245
  DropdownIndicator: selectUtils.DropdownIndicator
237
246
  },
238
247
  options: props.options,
@@ -257,7 +266,7 @@ SelectableSelect.propTypes = {};
257
266
  var SelectableSelect$1 = SelectableSelect;
258
267
 
259
268
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
260
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
269
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context5 = ownKeys(Object(source))).call(_context5, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
261
270
  const Container = /*#__PURE__*/_styled__default["default"]("div", {
262
271
  target: "encv1cf0"
263
272
  } )({
@@ -276,8 +285,17 @@ const defaultProps = {
276
285
  };
277
286
  const selectableSearchInputSequentialId = utils.createSequentialId('selectable-search-input-');
278
287
  const isOptionObject = option => option.options !== undefined;
279
- const SelectableSearchInput = props => {
288
+ const transformDataProps = dataProps => {
280
289
  var _context;
290
+ return _Object$fromEntries__default["default"](_mapInstanceProperty__default["default"](_context = _Object$entries__default["default"](dataProps || {})).call(_context, _ref => {
291
+ let _ref2 = _slicedToArray(_ref, 2),
292
+ key = _ref2[0],
293
+ value = _ref2[1];
294
+ return ["data-".concat(key), value];
295
+ }));
296
+ };
297
+ const SelectableSearchInput = props => {
298
+ var _context2;
281
299
  const _useToggleState = hooks.useToggleState(false),
282
300
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
283
301
  dropdownHasFocus = _useToggleState2[0],
@@ -288,7 +306,10 @@ const SelectableSearchInput = props => {
288
306
  setSearchValue = _useState2[1];
289
307
  const containerRef = react$1.useRef(null);
290
308
  const textInputRef = react$1.useRef(null);
291
- const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context = props.options).call(_context, option => {
309
+ const legacyDataProps = utils.filterDataAttributes(props);
310
+ const transformedSelectDataProps = transformDataProps(props.selectDataProps);
311
+ const transformedInputDataProps = transformDataProps(props.inputDataProps);
312
+ const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context2 = props.options).call(_context2, option => {
292
313
  if (isOptionObject(option)) {
293
314
  return option.options;
294
315
  }
@@ -411,11 +432,12 @@ const SelectableSearchInput = props => {
411
432
  handleDropdownFocus: handleDropdownFocus,
412
433
  handleDropdownBlur: handleDropdownBlur,
413
434
  textInputRef: textInputRef,
414
- selectedOption: selectedOption
435
+ selectedOption: selectedOption,
436
+ dataProps: transformedSelectDataProps
415
437
  }))
416
438
  }), jsxRuntime.jsxs("div", {
417
439
  css: [getSelectableSearchInputContainerStyles(props), dropdownHasFocus && !props.isReadOnly && /*#__PURE__*/react.css("border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";&:hover{border-left-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" ), "" , "" ],
418
- children: [jsxRuntime.jsx("input", _objectSpread(_objectSpread({
440
+ children: [jsxRuntime.jsx("input", _objectSpread(_objectSpread(_objectSpread({
419
441
  ref: textInputRef,
420
442
  id: SelectableSearchInput.getTextInputId(selectablSearchInputId),
421
443
  name: getTextInputName(props.name),
@@ -432,7 +454,7 @@ const SelectableSearchInput = props => {
432
454
  "aria-readonly": props.isReadOnly,
433
455
  contentEditable: !props.isReadOnly,
434
456
  css: getSelectableSearchInputStyles(props)
435
- }, utils.filterDataAttributes(props)), {}, {
457
+ }, transformedInputDataProps), legacyDataProps), {}, {
436
458
  /* ARIA */
437
459
  "aria-invalid": props['aria-invalid'],
438
460
  "aria-errormessage": props['aria-errormessage'],
@@ -463,15 +485,15 @@ SelectableSearchInput.propTypes = {};
463
485
  SelectableSearchInput.displayName = 'SelectableSearchInput';
464
486
  SelectableSearchInput.defaultProps = defaultProps;
465
487
  SelectableSearchInput.isEmpty = formValue => {
466
- var _context2;
467
- return !formValue || _trimInstanceProperty__default["default"](_context2 = formValue.text).call(_context2) === '';
488
+ var _context3;
489
+ return !formValue || _trimInstanceProperty__default["default"](_context3 = formValue.text).call(_context3) === '';
468
490
  };
469
491
  SelectableSearchInput.getTextInputId = getTextInputName;
470
492
  SelectableSearchInput.getDropdownId = getDropdownName;
471
493
  var SelectableSearchInput$1 = SelectableSearchInput;
472
494
 
473
495
  // NOTE: This string will be replaced on build time with the package version.
474
- var version = "16.12.0";
496
+ var version = "17.0.0";
475
497
 
476
498
  exports["default"] = SelectableSearchInput$1;
477
499
  exports.version = version;
@@ -10,6 +10,9 @@ import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
10
10
  import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
11
11
  import _styled from '@emotion/styled/base';
12
12
  import _pt from 'prop-types';
13
+ import _Object$fromEntries from '@babel/runtime-corejs3/core-js-stable/object/from-entries';
14
+ import _mapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/map';
15
+ import _Object$entries from '@babel/runtime-corejs3/core-js-stable/object/entries';
13
16
  import _flatMapInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/flat-map';
14
17
  import _findInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/find';
15
18
  import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
@@ -17,7 +20,7 @@ import { useCallback, useState, useRef } from 'react';
17
20
  import SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';
18
21
  import Constraints from '@commercetools-uikit/constraints';
19
22
  import { CloseIcon, SearchIcon } from '@commercetools-uikit/icons';
20
- import { createSequentialId, warning, filterDataAttributes } from '@commercetools-uikit/utils';
23
+ import { createSequentialId, filterDataAttributes, warning } from '@commercetools-uikit/utils';
21
24
  import { createSelectStyles, DropdownIndicator, messages, warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';
22
25
  import { css } from '@emotion/react';
23
26
  import { getInputStyles } from '@commercetools-uikit/input-utils';
@@ -158,22 +161,25 @@ const createSelectableSelectStyles = _ref => {
158
161
  });
159
162
  };
160
163
 
161
- const _excluded = ["id"];
164
+ const _excluded = ["id", "dataProps"];
162
165
  function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
163
166
  function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
164
167
  const SingleValue = _ref => {
165
168
  let id = _ref.id,
169
+ dataProps = _ref.dataProps,
166
170
  props = _objectWithoutProperties(_ref, _excluded);
167
171
  return jsx(components.SingleValue, _objectSpread$1(_objectSpread$1({}, props), {}, {
168
- children: jsx("label", {
169
- htmlFor: id,
172
+ children: jsx("label", _objectSpread$1(_objectSpread$1({
173
+ htmlFor: id
174
+ }, dataProps), {}, {
170
175
  children: props.children
171
- })
176
+ }))
172
177
  }));
173
178
  };
174
179
  SingleValue.propTypes = process.env.NODE_ENV !== "production" ? {
175
- id: _pt.string,
176
- children: _pt.node
180
+ children: _pt.node,
181
+ dataProps: _pt.objectOf(_pt.string),
182
+ id: _pt.string
177
183
  } : {};
178
184
  const SelectableSelect = props => {
179
185
  const intl = useIntl();
@@ -211,9 +217,10 @@ const SelectableSelect = props => {
211
217
  maxMenuHeight: props.maxMenuHeight,
212
218
  closeMenuOnSelect: props.closeMenuOnSelect,
213
219
  components: {
214
- SingleValue: innerProps => jsx(SingleValue, _objectSpread$1(_objectSpread$1({}, innerProps), {}, {
215
- id: props.id
216
- })),
220
+ SingleValue: innerProps => jsx(SingleValue, _objectSpread$1({
221
+ id: props.id,
222
+ dataProps: props.dataProps
223
+ }, innerProps)),
217
224
  DropdownIndicator
218
225
  },
219
226
  options: props.options,
@@ -239,12 +246,13 @@ SelectableSelect.propTypes = process.env.NODE_ENV !== "production" ? {
239
246
  handleDropdownFocus: _pt.func.isRequired,
240
247
  handleDropdownBlur: _pt.func.isRequired,
241
248
  textInputRef: _pt.any.isRequired,
242
- selectedOption: _pt.any
249
+ selectedOption: _pt.any,
250
+ dataProps: _pt.objectOf(_pt.string)
243
251
  } : {};
244
252
  var SelectableSelect$1 = SelectableSelect;
245
253
 
246
254
  function ownKeys(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
247
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context3, _context4; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context3 = ownKeys(Object(source), !0)).call(_context3, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context4 = ownKeys(Object(source))).call(_context4, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
255
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context4, _context5; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context4 = ownKeys(Object(source), !0)).call(_context4, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context5 = ownKeys(Object(source))).call(_context5, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
248
256
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
249
257
  const Container = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
250
258
  target: "encv1cf0"
@@ -257,7 +265,7 @@ const Container = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
257
265
  } : {
258
266
  name: "zjik7",
259
267
  styles: "display:flex",
260
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA+B4B","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */",
268
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA+B4B","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */",
261
269
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
262
270
  });
263
271
  const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
@@ -272,8 +280,17 @@ const defaultProps = {
272
280
  };
273
281
  const selectableSearchInputSequentialId = createSequentialId('selectable-search-input-');
274
282
  const isOptionObject = option => option.options !== undefined;
275
- const SelectableSearchInput = props => {
283
+ const transformDataProps = dataProps => {
276
284
  var _context;
285
+ return _Object$fromEntries(_mapInstanceProperty(_context = _Object$entries(dataProps || {})).call(_context, _ref => {
286
+ let _ref2 = _slicedToArray(_ref, 2),
287
+ key = _ref2[0],
288
+ value = _ref2[1];
289
+ return ["data-".concat(key), value];
290
+ }));
291
+ };
292
+ const SelectableSearchInput = props => {
293
+ var _context2;
277
294
  const _useToggleState = useToggleState(false),
278
295
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
279
296
  dropdownHasFocus = _useToggleState2[0],
@@ -284,7 +301,10 @@ const SelectableSearchInput = props => {
284
301
  setSearchValue = _useState2[1];
285
302
  const containerRef = useRef(null);
286
303
  const textInputRef = useRef(null);
287
- const optionsWithoutGroups = _flatMapInstanceProperty(_context = props.options).call(_context, option => {
304
+ const legacyDataProps = filterDataAttributes(props);
305
+ const transformedSelectDataProps = transformDataProps(props.selectDataProps);
306
+ const transformedInputDataProps = transformDataProps(props.inputDataProps);
307
+ const optionsWithoutGroups = _flatMapInstanceProperty(_context2 = props.options).call(_context2, option => {
288
308
  if (isOptionObject(option)) {
289
309
  return option.options;
290
310
  }
@@ -409,11 +429,12 @@ const SelectableSearchInput = props => {
409
429
  handleDropdownFocus: handleDropdownFocus,
410
430
  handleDropdownBlur: handleDropdownBlur,
411
431
  textInputRef: textInputRef,
412
- selectedOption: selectedOption
432
+ selectedOption: selectedOption,
433
+ dataProps: transformedSelectDataProps
413
434
  }))
414
435
  }), jsxs("div", {
415
- css: [getSelectableSearchInputContainerStyles(props), dropdownHasFocus && !props.isReadOnly && /*#__PURE__*/css("border-left-color:", designTokens.borderColorForInputWhenFocused, ";&:hover{border-left-color:", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAsZiB","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAkZU","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...filterDataAttributes(props)}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"],
416
- children: [jsx("input", _objectSpread(_objectSpread({
436
+ css: [getSelectableSearchInputContainerStyles(props), dropdownHasFocus && !props.isReadOnly && /*#__PURE__*/css("border-left-color:", designTokens.borderColorForInputWhenFocused, ";&:hover{border-left-color:", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AA6aiB","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:SelectableSearchInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAyaU","file":"selectable-search-input.tsx","sourcesContent":["import {\n  type MouseEvent,\n  type KeyboardEvent,\n  type ChangeEvent,\n  type ReactNode,\n  useState,\n  useCallback,\n  useRef,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport Constraints from '@commercetools-uikit/constraints';\nimport { SearchIcon, CloseIcon } from '@commercetools-uikit/icons';\nimport {\n  createSequentialId,\n  filterDataAttributes,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { warnIfMenuPortalPropsAreMissing } from '@commercetools-uikit/select-utils';\nimport {\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getSelectableSearchInputContainerStyles,\n  getSelectableSearchInputStyles,\n} from './selectable-search-input.styles';\nimport SelectableSelect from './selectable-select';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport styled from '@emotion/styled';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\n\nconst Container = styled.div`\n  display: flex;\n`;\n\nconst getTextInputName = (name?: string) =>\n  name ? `${name}.textInput` : undefined;\n\nconst getDropdownName = (name?: string) =>\n  name ? `${name}.dropdown` : undefined;\n\nexport type TCustomEvent = {\n  target: {\n    id?: string;\n    name?: string;\n    value?: string | string[] | null;\n  };\n  persist?: () => void;\n};\n\nexport type TValue = {\n  text: string;\n  option: string;\n};\n\nexport type TOption = {\n  value: string;\n  label?: ReactNode;\n};\n\nexport type TOptionObject = {\n  options: TOption[];\n};\n\nexport type TOptions = TOption[] | TOptionObject[];\n\nexport type TSelectableSearchInputProps = {\n  /**\n   * Used as HTML id property. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML autocomplete property\n   */\n  autoComplete?: string;\n  /**\n   * Indicate if the value entered in the input is invalid.\n   */\n  'aria-invalid'?: boolean;\n  /**\n   * HTML ID of an element containing an error message related to the input.\n   */\n  'aria-errormessage'?: string;\n  /**\n   * Used as HTML name of the input component property.\n   */\n  name?: string;\n  /**\n   * Value of the input. Consists of text input and selected option.\n   */\n  value: TValue;\n  /**\n   * Called with the event of the input or dropdown when either the selectable dropdown or the text input have changed.\n   * The change event from the text input has a suffix of `.textInput` and the change event from the dropdown has a suffix of `.dropdown`.\n   */\n  onChange?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is blurred\n   */\n  onBlur?: (event: TCustomEvent) => void;\n  /**\n   * Called when input is focused\n   */\n  onFocus?: (event: TCustomEvent) => void;\n  /**\n   * Handler when the search button is clicked.\n   */\n  onSubmit: (value: TValue) => void;\n  /**\n   * Handler when the clear button is clicked.\n   */\n  onReset?: () => void;\n  /**\n   * Focus the input on initial render\n   */\n  isAutofocussed?: boolean;\n  /**\n   * Indicates that the input cannot be modified (e.g not authorized, or changes currently saving).\n   */\n  isDisabled?: boolean;\n  /**\n   * Indicates that the field is displaying read-only content\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates if the input has invalid values\n   */\n  hasError?: boolean;\n  /**\n   * Indicates if the input has warning values\n   */\n  hasWarning?: boolean;\n  /**\n   * Placeholder text for the input\n   */\n  placeholder?: string;\n  /**\n   * Indicates if the input should be cleared when the clear button is clicked.\n   * Defaults to true.\n   *\n   */\n  isClearable?: boolean;\n  /**\n   * Horizontal size limit of the input fields.\n   */\n  horizontalConstraint?: 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';\n  /**\n   * Array of options that populate the select menu\n   */\n  options: TOptions;\n  /**\n   * z-index value for the menu portal\n   * <br>\n   * Use in conjunction with `menuPortalTarget`\n   */\n  menuPortalZIndex?: number;\n  /**\n   * Dom element to portal the select menu to\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuPortalTarget?: ReactSelectProps['menuPortalTarget'];\n  /**\n   * whether the menu should block scroll while open\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  menuShouldBlockScroll?: ReactSelectProps['menuShouldBlockScroll'];\n  /**\n   * Handle change events on the menu input\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  onMenuInputChange?: ReactSelectProps['onInputChange'];\n  /**\n   * Can be used to render a custom value when there are no options (either because of no search results, or all options have been used, or there were none in the first place). Gets called with { inputValue: String }.\n   * <br />\n   * `inputValue` will be an empty string when no search text is present.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  noMenuOptionsMessage?: ReactSelectProps['noOptionsMessage'];\n  /**\n   * Whether to enable search functionality.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  isMenuSearchable?: ReactSelectProps['isSearchable'];\n  /**\n   * Maximum height of the menu before scrolling\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  maxMenuHeight?: ReactSelectProps['maxMenuHeight'];\n  /**\n   * Whether the menu should close after a value is selected. Defaults to `true`.\n   * <br>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];\n  /**\n   * Horizontal size limit for the dropdown menu.\n   */\n  menuHorizontalConstraint?: 3 | 4 | 5;\n  /**\n   * Show submit button in the input\n   */\n  showSubmitButton?: boolean;\n  /**\n   *  used to pass data-* props to the select component.\n   * eg: selectDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  selectDataProps?: Record<string, string>;\n  /**\n   *  used to pass data-* props to the input element.\n   * eg: inputDataProps={[{ 'prop-1': 'value-1' }, { 'prop-2': 'value-2' }]}\n   */\n  inputDataProps?: Record<string, string>;\n};\n\nconst defaultProps: Pick<\n  TSelectableSearchInputProps,\n  | 'horizontalConstraint'\n  | 'isClearable'\n  | 'menuHorizontalConstraint'\n  | 'showSubmitButton'\n  | 'menuPortalZIndex'\n  | 'options'\n> = {\n  horizontalConstraint: 'scale',\n  isClearable: true,\n  menuHorizontalConstraint: 3,\n  showSubmitButton: true,\n  menuPortalZIndex: 1,\n  options: [],\n};\n\nconst selectableSearchInputSequentialId = createSequentialId(\n  'selectable-search-input-'\n);\n\nconst isOptionObject = (\n  option: TOption | TOptionObject\n): option is TOptionObject => (option as TOptionObject).options !== undefined;\n\nconst transformDataProps = (dataProps?: Record<string, string>) =>\n  Object.fromEntries(\n    Object.entries(dataProps || {}).map(([key, value]) => [\n      `data-${key}`,\n      value,\n    ])\n  );\n\nconst SelectableSearchInput = (props: TSelectableSearchInputProps) => {\n  const [dropdownHasFocus, toggleDropdownHasFocus] = useToggleState(false);\n  const [searchValue, setSearchValue] = useState(props.value.text || '');\n  const containerRef = useRef<HTMLDivElement>(null);\n  const textInputRef = useRef<HTMLInputElement>(null);\n\n  const legacyDataProps = filterDataAttributes(props);\n  const transformedSelectDataProps = transformDataProps(props.selectDataProps);\n  const transformedInputDataProps = transformDataProps(props.inputDataProps);\n\n  const optionsWithoutGroups = props.options.flatMap((option) => {\n    if (isOptionObject(option)) {\n      return option.options;\n    }\n    return option;\n  });\n\n  const selectedOption = optionsWithoutGroups.find(\n    (option) => option.value === props.value.option\n  );\n\n  const selectablSearchInputId = useFieldId(\n    props.id,\n    selectableSearchInputSequentialId\n  );\n\n  if (!props.isReadOnly) {\n    warning(\n      typeof props.onChange === 'function',\n      'SelectableSearchInput: `onChange` is required when is not read only.'\n    );\n  }\n\n  warnIfMenuPortalPropsAreMissing({\n    menuPortalZIndex: props.menuPortalZIndex,\n    menuPortalTarget: props.menuPortalTarget,\n    componentName: 'SelectableSearchInput',\n  });\n\n  const { onFocus, onBlur, name } = props;\n  const handleTextInputFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onFocus, selectablSearchInputId, name]);\n\n  const handleTextInputBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(name),\n        },\n      });\n    }\n  }, [onBlur, selectablSearchInputId, name]);\n\n  const handleClear = () => {\n    setSearchValue('');\n    if (props.onReset) {\n      props.onReset();\n    }\n  };\n\n  const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(event.target.value);\n    if (props.onChange) {\n      props.onChange({\n        target: {\n          id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n          name: getTextInputName(props.name),\n          value: event.target.value,\n        },\n      });\n    }\n  };\n\n  const handleSubmit = (\n    event:\n      | KeyboardEvent<HTMLButtonElement>\n      | MouseEvent<HTMLButtonElement>\n      | KeyboardEvent<HTMLInputElement>\n  ) => {\n    event.preventDefault();\n    if (props.onSubmit) {\n      props.onSubmit({\n        text: searchValue,\n        option: selectedOption?.value ?? '',\n      });\n    }\n  };\n\n  const dropdownName = getDropdownName(props.name);\n  const dropdownId = SelectableSearchInput.getDropdownId(\n    selectablSearchInputId\n  );\n\n  const handleDropdownFocus = useCallback(() => {\n    if (onFocus) {\n      onFocus({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(true);\n  }, [onFocus, toggleDropdownHasFocus, dropdownName, dropdownId]);\n\n  const handleDropdownBlur = useCallback(() => {\n    if (onBlur) {\n      onBlur({\n        target: {\n          id: dropdownId,\n          name: dropdownName,\n        },\n      });\n    }\n    toggleDropdownHasFocus(false);\n  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);\n\n  const handleContainerBlur = useCallback(\n    (event) => {\n      // ensures that both fields are marked as touched when one of them\n      // is blurred\n      if (\n        typeof onBlur === 'function' &&\n        !containerRef.current?.contains(event.relatedTarget)\n      ) {\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n          },\n        });\n        onBlur({\n          target: {\n            id: SelectableSearchInput.getTextInputId(selectablSearchInputId),\n            name: getTextInputName(name),\n          },\n        });\n      }\n    },\n    [onBlur, selectablSearchInputId, name]\n  );\n\n  return (\n    <Constraints.Horizontal max={props.horizontalConstraint}>\n      <Container\n        ref={containerRef}\n        onBlur={handleContainerBlur}\n        data-testid=\"selectable-search-input-container\"\n      >\n        <Constraints.Horizontal max={props.menuHorizontalConstraint}>\n          <SelectableSelect\n            {...props}\n            id={SelectableSearchInput.getDropdownId(selectablSearchInputId)}\n            name={getDropdownName(props.name)}\n            dropdownHasFocus={dropdownHasFocus}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n          />\n        </Constraints.Horizontal>\n        <div\n          css={[\n            getSelectableSearchInputContainerStyles(props),\n            dropdownHasFocus &&\n              !props.isReadOnly &&\n              css`\n                border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                &:hover {\n                  border-left-color: ${designTokens.borderColorForInputWhenFocused};\n                }\n              `,\n          ]}\n        >\n          <input\n            ref={textInputRef}\n            id={SelectableSearchInput.getTextInputId(selectablSearchInputId)}\n            name={getTextInputName(props.name)}\n            type=\"text\"\n            value={searchValue}\n            onChange={handleChange}\n            onBlur={handleTextInputBlur}\n            onFocus={handleTextInputFocus}\n            disabled={props.isDisabled}\n            placeholder={props.placeholder}\n            readOnly={props.isReadOnly}\n            autoFocus={props.isAutofocussed}\n            autoComplete={props.autoComplete}\n            aria-readonly={props.isReadOnly}\n            contentEditable={!props.isReadOnly}\n            css={getSelectableSearchInputStyles(props)}\n            {...transformedInputDataProps}\n            {...legacyDataProps}\n            /* ARIA */\n            aria-invalid={props['aria-invalid']}\n            aria-errormessage={props['aria-errormessage']}\n            data-testid=\"selectable-input\"\n            onKeyDown={(event) => {\n              if (!props.isReadOnly && event.key === 'Enter') {\n                handleSubmit(event);\n              }\n            }}\n          />\n          {props.isClearable &&\n            searchValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size=\"medium\"\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n        </div>\n      </Container>\n    </Constraints.Horizontal>\n  );\n};\n\nSelectableSearchInput.displayName = 'SelectableSearchInput';\nSelectableSearchInput.defaultProps = defaultProps;\nSelectableSearchInput.isEmpty = (\n  formValue: TSelectableSearchInputProps['value']\n) => !formValue || formValue.text.trim() === '';\nSelectableSearchInput.getTextInputId = getTextInputName;\nSelectableSearchInput.getDropdownId = getDropdownName;\n\nexport default SelectableSearchInput;\n"]} */"],
437
+ children: [jsx("input", _objectSpread(_objectSpread(_objectSpread({
417
438
  ref: textInputRef,
418
439
  id: SelectableSearchInput.getTextInputId(selectablSearchInputId),
419
440
  name: getTextInputName(props.name),
@@ -430,7 +451,7 @@ const SelectableSearchInput = props => {
430
451
  "aria-readonly": props.isReadOnly,
431
452
  contentEditable: !props.isReadOnly,
432
453
  css: getSelectableSearchInputStyles(props)
433
- }, filterDataAttributes(props)), {}, {
454
+ }, transformedInputDataProps), legacyDataProps), {}, {
434
455
  /* ARIA */
435
456
  "aria-invalid": props['aria-invalid'],
436
457
  "aria-errormessage": props['aria-errormessage'],
@@ -491,19 +512,21 @@ SelectableSearchInput.propTypes = process.env.NODE_ENV !== "production" ? {
491
512
  }))]).isRequired,
492
513
  menuPortalZIndex: _pt.number,
493
514
  menuHorizontalConstraint: _pt.oneOf([3, 4, 5]),
494
- showSubmitButton: _pt.bool
515
+ showSubmitButton: _pt.bool,
516
+ selectDataProps: _pt.objectOf(_pt.string),
517
+ inputDataProps: _pt.objectOf(_pt.string)
495
518
  } : {};
496
519
  SelectableSearchInput.displayName = 'SelectableSearchInput';
497
520
  SelectableSearchInput.defaultProps = defaultProps;
498
521
  SelectableSearchInput.isEmpty = formValue => {
499
- var _context2;
500
- return !formValue || _trimInstanceProperty(_context2 = formValue.text).call(_context2) === '';
522
+ var _context3;
523
+ return !formValue || _trimInstanceProperty(_context3 = formValue.text).call(_context3) === '';
501
524
  };
502
525
  SelectableSearchInput.getTextInputId = getTextInputName;
503
526
  SelectableSearchInput.getDropdownId = getDropdownName;
504
527
  var SelectableSearchInput$1 = SelectableSearchInput;
505
528
 
506
529
  // NOTE: This string will be replaced on build time with the package version.
507
- var version = "16.12.0";
530
+ var version = "17.0.0";
508
531
 
509
532
  export { SelectableSearchInput$1 as default, version };
@@ -51,6 +51,8 @@ export type TSelectableSearchInputProps = {
51
51
  closeMenuOnSelect?: ReactSelectProps['closeMenuOnSelect'];
52
52
  menuHorizontalConstraint?: 3 | 4 | 5;
53
53
  showSubmitButton?: boolean;
54
+ selectDataProps?: Record<string, string>;
55
+ inputDataProps?: Record<string, string>;
54
56
  };
55
57
  declare const SelectableSearchInput: {
56
58
  (props: TSelectableSearchInputProps): import("@emotion/react/jsx-runtime").JSX.Element;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/selectable-search-input",
3
3
  "description": "A controlled selectable search input component for single-line strings with validation states.",
4
- "version": "16.12.0",
4
+ "version": "17.0.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,14 +21,14 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "16.12.0",
25
- "@commercetools-uikit/design-system": "16.12.0",
26
- "@commercetools-uikit/hooks": "16.12.0",
27
- "@commercetools-uikit/icons": "16.12.0",
28
- "@commercetools-uikit/input-utils": "16.12.0",
29
- "@commercetools-uikit/secondary-icon-button": "16.12.0",
30
- "@commercetools-uikit/select-utils": "16.12.0",
31
- "@commercetools-uikit/utils": "16.12.0",
24
+ "@commercetools-uikit/constraints": "17.0.0",
25
+ "@commercetools-uikit/design-system": "17.0.0",
26
+ "@commercetools-uikit/hooks": "17.0.0",
27
+ "@commercetools-uikit/icons": "17.0.0",
28
+ "@commercetools-uikit/input-utils": "17.0.0",
29
+ "@commercetools-uikit/secondary-icon-button": "17.0.0",
30
+ "@commercetools-uikit/select-utils": "17.0.0",
31
+ "@commercetools-uikit/utils": "17.0.0",
32
32
  "@emotion/react": "^11.10.5",
33
33
  "@emotion/styled": "^11.10.5",
34
34
  "lodash": "4.17.21",