@commercetools-uikit/selectable-search-input 19.10.0 → 19.12.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.
@@ -123,7 +123,7 @@ const getBackgroundColor = (props, defaultColor) => {
123
123
  }
124
124
  return defaultColor;
125
125
  };
126
- const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/react.css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? "".concat(designSystem.designTokens.heightForInputAsSmall) : "".concat(designSystem.designTokens.heightForInput), ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";padding-left:", designSystem.designTokens.spacing30, ";padding-right:", designSystem.designTokens.spacing30, ";&::placeholder{color:", designSystem.designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designSystem.designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAiKK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */"), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/react.css("&:focus-within{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA4MO","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
126
+ const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/react.css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? `${designSystem.designTokens.heightForInputAsSmall}` : `${designSystem.designTokens.heightForInput}`, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";padding-left:", designSystem.designTokens.spacing30, ";padding-right:", designSystem.designTokens.spacing30, ";&::placeholder{color:", designSystem.designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designSystem.designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAiKK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */"), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/react.css("&:focus-within{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA4MO","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
127
127
  const createSelectableSelectStyles = _ref => {
128
128
  let hasWarning = _ref.hasWarning,
129
129
  hasError = _ref.hasError,
@@ -144,7 +144,7 @@ const createSelectableSelectStyles = _ref => {
144
144
  });
145
145
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
146
146
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
147
- padding: "0 ".concat(designSystem.designTokens.spacing25),
147
+ padding: `0 ${designSystem.designTokens.spacing25}`,
148
148
  borderTopRightRadius: '0',
149
149
  borderBottomRightRadius: '0',
150
150
  borderRight: '0',
@@ -152,8 +152,8 @@ const createSelectableSelectStyles = _ref => {
152
152
  fontSize: isCondensed ? designSystem.designTokens.fontSize20 : designSystem.designTokens.fontSize30,
153
153
  minHeight: isCondensed ? designSystem.designTokens.heightForInputAsSmall : designSystem.designTokens.heightForInput,
154
154
  borderColor: (() => {
155
- if (isDisabled) return "".concat(designSystem.designTokens.borderColorForInputWhenDisabled, " !important");
156
- if (isReadOnly) return "".concat(designSystem.designTokens.borderColorForInputWhenReadonly, " !important");
155
+ if (isDisabled) return `${designSystem.designTokens.borderColorForInputWhenDisabled} !important`;
156
+ if (isReadOnly) return `${designSystem.designTokens.borderColorForInputWhenReadonly} !important`;
157
157
  if (hasError) return designSystem.designTokens.borderColorForInputWhenError;
158
158
  if (hasWarning) return designSystem.designTokens.borderColorForInputWhenWarning;
159
159
  if (dropdownHasFocus) {
@@ -163,7 +163,7 @@ const createSelectableSelectStyles = _ref => {
163
163
  })(),
164
164
  cursor: (() => {
165
165
  if (isDisabled) return 'not-allowed';
166
- if (isReadOnly) return "default";
166
+ if (isReadOnly) return `default`;
167
167
  return 'pointer';
168
168
  })(),
169
169
  backgroundColor: getBackgroundColor({
@@ -285,8 +285,8 @@ const Container = /*#__PURE__*/_styled__default["default"]("div", process.env.NO
285
285
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAmC4B","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  ReactElement,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport IconButton, {\n  type TIconButtonProps,\n} from '@commercetools-uikit/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  _experimentalValue?: 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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Map of components to overwrite the default ones, see what components you can override\n   * <br/>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  selectCustomComponents?: ReactSelectProps['components'];\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TIconButtonProps;\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 [searchOption, setSearchOption] = useState(props.value.option || '');\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  const searchInputValue = props._experimentalValue?.text ?? searchValue;\n  const searchInputOption = props._experimentalValue?.option ?? searchOption;\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 === searchInputOption\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\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 handleTextInputChange = (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: searchInputValue,\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  const handleDropdownChange = useCallback(\n    (nextSelectedOptions) => {\n      setSearchOption(nextSelectedOptions.value);\n      if (props.onChange) {\n        props.onChange({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n            value: nextSelectedOptions.value,\n          },\n        });\n      }\n      textInputRef.current?.focus();\n    },\n    [props.onChange, 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            isCondensed={props.isCondensed ?? false}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            handleDropdownChange={handleDropdownChange}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n            selectCustomComponents={props.selectCustomComponents}\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={searchInputValue}\n            onChange={handleTextInputChange}\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            searchInputValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size={props.isCondensed ? '10' : '20'}\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              size={props.isCondensed ? '20' : '40'}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={css`\n                order: 4;\n                margin-left: ${designTokens.spacing30};\n              `}\n            >\n              <IconButton\n                theme=\"primary\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '10' : '20'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\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"]} */",
286
286
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
287
287
  });
288
- const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
289
- const getDropdownName = name => name ? "".concat(name, ".dropdown") : undefined;
288
+ const getTextInputName = name => name ? `${name}.textInput` : undefined;
289
+ const getDropdownName = name => name ? `${name}.dropdown` : undefined;
290
290
  const defaultProps = {
291
291
  horizontalConstraint: 'scale',
292
292
  isClearable: true,
@@ -303,11 +303,11 @@ const transformDataProps = dataProps => {
303
303
  let _ref2 = _slicedToArray(_ref, 2),
304
304
  key = _ref2[0],
305
305
  value = _ref2[1];
306
- return ["data-".concat(key), value];
306
+ return [`data-${key}`, value];
307
307
  }));
308
308
  };
309
309
  const SelectableSearchInput = props => {
310
- var _props$_experimentalV, _props$_experimentalV2, _props$_experimentalV3, _props$_experimentalV4, _context2, _props$isCondensed;
310
+ var _context2;
311
311
  const _useToggleState = hooks.useToggleState(false),
312
312
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
313
313
  dropdownHasFocus = _useToggleState2[0],
@@ -325,8 +325,8 @@ const SelectableSearchInput = props => {
325
325
  const legacyDataProps = utils.filterDataAttributes(props);
326
326
  const transformedSelectDataProps = transformDataProps(props.selectDataProps);
327
327
  const transformedInputDataProps = transformDataProps(props.inputDataProps);
328
- const searchInputValue = (_props$_experimentalV = (_props$_experimentalV2 = props._experimentalValue) === null || _props$_experimentalV2 === void 0 ? void 0 : _props$_experimentalV2.text) !== null && _props$_experimentalV !== void 0 ? _props$_experimentalV : searchValue;
329
- const searchInputOption = (_props$_experimentalV3 = (_props$_experimentalV4 = props._experimentalValue) === null || _props$_experimentalV4 === void 0 ? void 0 : _props$_experimentalV4.option) !== null && _props$_experimentalV3 !== void 0 ? _props$_experimentalV3 : searchOption;
328
+ const searchInputValue = props._experimentalValue?.text ?? searchValue;
329
+ const searchInputOption = props._experimentalValue?.option ?? searchOption;
330
330
  const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context2 = props.options).call(_context2, option => {
331
331
  if (isOptionObject(option)) {
332
332
  return option.options;
@@ -390,10 +390,9 @@ const SelectableSearchInput = props => {
390
390
  const handleSubmit = event => {
391
391
  event.preventDefault();
392
392
  if (props.onSubmit) {
393
- var _selectedOption$value;
394
393
  props.onSubmit({
395
394
  text: searchInputValue,
396
- option: (_selectedOption$value = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value) !== null && _selectedOption$value !== void 0 ? _selectedOption$value : ''
395
+ option: selectedOption?.value ?? ''
397
396
  });
398
397
  }
399
398
  };
@@ -422,10 +421,9 @@ const SelectableSearchInput = props => {
422
421
  toggleDropdownHasFocus(false);
423
422
  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);
424
423
  const handleContainerBlur = react$1.useCallback(event => {
425
- var _containerRef$current;
426
424
  // ensures that both fields are marked as touched when one of them
427
425
  // is blurred
428
- if (typeof onBlur === 'function' && !((_containerRef$current = containerRef.current) !== null && _containerRef$current !== void 0 && _containerRef$current.contains(event.relatedTarget))) {
426
+ if (typeof onBlur === 'function' && !containerRef.current?.contains(event.relatedTarget)) {
429
427
  onBlur({
430
428
  target: {
431
429
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
@@ -441,7 +439,6 @@ const SelectableSearchInput = props => {
441
439
  }
442
440
  }, [onBlur, selectablSearchInputId, name]);
443
441
  const handleDropdownChange = react$1.useCallback(nextSelectedOptions => {
444
- var _textInputRef$current;
445
442
  setSearchOption(nextSelectedOptions.value);
446
443
  if (props.onChange) {
447
444
  props.onChange({
@@ -452,7 +449,7 @@ const SelectableSearchInput = props => {
452
449
  }
453
450
  });
454
451
  }
455
- (_textInputRef$current = textInputRef.current) === null || _textInputRef$current === void 0 || _textInputRef$current.focus();
452
+ textInputRef.current?.focus();
456
453
  }, [props.onChange, selectablSearchInputId, name]);
457
454
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
458
455
  max: props.horizontalConstraint,
@@ -466,7 +463,7 @@ const SelectableSearchInput = props => {
466
463
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
467
464
  name: getDropdownName(props.name),
468
465
  dropdownHasFocus: dropdownHasFocus,
469
- isCondensed: (_props$isCondensed = props.isCondensed) !== null && _props$isCondensed !== void 0 ? _props$isCondensed : false,
466
+ isCondensed: props.isCondensed ?? false,
470
467
  handleDropdownFocus: handleDropdownFocus,
471
468
  handleDropdownBlur: handleDropdownBlur,
472
469
  handleDropdownChange: handleDropdownChange,
@@ -582,7 +579,7 @@ SelectableSearchInput.getDropdownId = getDropdownName;
582
579
  var SelectableSearchInput$1 = SelectableSearchInput;
583
580
 
584
581
  // NOTE: This string will be replaced on build time with the package version.
585
- var version = "19.10.0";
582
+ var version = "19.11.0";
586
583
 
587
584
  exports["default"] = SelectableSearchInput$1;
588
585
  exports.version = version;
@@ -122,7 +122,7 @@ const getBackgroundColor = (props, defaultColor) => {
122
122
  }
123
123
  return defaultColor;
124
124
  };
125
- const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/react.css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? "".concat(designSystem.designTokens.heightForInputAsSmall) : "".concat(designSystem.designTokens.heightForInput), ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";padding-left:", designSystem.designTokens.spacing30, ";padding-right:", designSystem.designTokens.spacing30, ";&::placeholder{color:", designSystem.designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designSystem.designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" ), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/react.css("&:focus-within{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" )];
125
+ const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/react.css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designSystem.designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? `${designSystem.designTokens.heightForInputAsSmall}` : `${designSystem.designTokens.heightForInput}`, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";padding-left:", designSystem.designTokens.spacing30, ";padding-right:", designSystem.designTokens.spacing30, ";&::placeholder{color:", designSystem.designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designSystem.designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designSystem.designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" ), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/react.css("&:focus-within{border-color:", designSystem.designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" )];
126
126
  const createSelectableSelectStyles = _ref => {
127
127
  let hasWarning = _ref.hasWarning,
128
128
  hasError = _ref.hasError,
@@ -143,7 +143,7 @@ const createSelectableSelectStyles = _ref => {
143
143
  });
144
144
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
145
145
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
146
- padding: "0 ".concat(designSystem.designTokens.spacing25),
146
+ padding: `0 ${designSystem.designTokens.spacing25}`,
147
147
  borderTopRightRadius: '0',
148
148
  borderBottomRightRadius: '0',
149
149
  borderRight: '0',
@@ -151,8 +151,8 @@ const createSelectableSelectStyles = _ref => {
151
151
  fontSize: isCondensed ? designSystem.designTokens.fontSize20 : designSystem.designTokens.fontSize30,
152
152
  minHeight: isCondensed ? designSystem.designTokens.heightForInputAsSmall : designSystem.designTokens.heightForInput,
153
153
  borderColor: (() => {
154
- if (isDisabled) return "".concat(designSystem.designTokens.borderColorForInputWhenDisabled, " !important");
155
- if (isReadOnly) return "".concat(designSystem.designTokens.borderColorForInputWhenReadonly, " !important");
154
+ if (isDisabled) return `${designSystem.designTokens.borderColorForInputWhenDisabled} !important`;
155
+ if (isReadOnly) return `${designSystem.designTokens.borderColorForInputWhenReadonly} !important`;
156
156
  if (hasError) return designSystem.designTokens.borderColorForInputWhenError;
157
157
  if (hasWarning) return designSystem.designTokens.borderColorForInputWhenWarning;
158
158
  if (dropdownHasFocus) {
@@ -162,7 +162,7 @@ const createSelectableSelectStyles = _ref => {
162
162
  })(),
163
163
  cursor: (() => {
164
164
  if (isDisabled) return 'not-allowed';
165
- if (isReadOnly) return "default";
165
+ if (isReadOnly) return `default`;
166
166
  return 'pointer';
167
167
  })(),
168
168
  backgroundColor: getBackgroundColor({
@@ -263,8 +263,8 @@ const Container = /*#__PURE__*/_styled__default["default"]("div", {
263
263
  name: "zjik7",
264
264
  styles: "display:flex"
265
265
  } );
266
- const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
267
- const getDropdownName = name => name ? "".concat(name, ".dropdown") : undefined;
266
+ const getTextInputName = name => name ? `${name}.textInput` : undefined;
267
+ const getDropdownName = name => name ? `${name}.dropdown` : undefined;
268
268
  const defaultProps = {
269
269
  horizontalConstraint: 'scale',
270
270
  isClearable: true,
@@ -281,11 +281,11 @@ const transformDataProps = dataProps => {
281
281
  let _ref2 = _slicedToArray(_ref, 2),
282
282
  key = _ref2[0],
283
283
  value = _ref2[1];
284
- return ["data-".concat(key), value];
284
+ return [`data-${key}`, value];
285
285
  }));
286
286
  };
287
287
  const SelectableSearchInput = props => {
288
- var _props$_experimentalV, _props$_experimentalV2, _props$_experimentalV3, _props$_experimentalV4, _context2, _props$isCondensed;
288
+ var _context2;
289
289
  const _useToggleState = hooks.useToggleState(false),
290
290
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
291
291
  dropdownHasFocus = _useToggleState2[0],
@@ -303,8 +303,8 @@ const SelectableSearchInput = props => {
303
303
  const legacyDataProps = utils.filterDataAttributes(props);
304
304
  const transformedSelectDataProps = transformDataProps(props.selectDataProps);
305
305
  const transformedInputDataProps = transformDataProps(props.inputDataProps);
306
- const searchInputValue = (_props$_experimentalV = (_props$_experimentalV2 = props._experimentalValue) === null || _props$_experimentalV2 === void 0 ? void 0 : _props$_experimentalV2.text) !== null && _props$_experimentalV !== void 0 ? _props$_experimentalV : searchValue;
307
- const searchInputOption = (_props$_experimentalV3 = (_props$_experimentalV4 = props._experimentalValue) === null || _props$_experimentalV4 === void 0 ? void 0 : _props$_experimentalV4.option) !== null && _props$_experimentalV3 !== void 0 ? _props$_experimentalV3 : searchOption;
306
+ const searchInputValue = props._experimentalValue?.text ?? searchValue;
307
+ const searchInputOption = props._experimentalValue?.option ?? searchOption;
308
308
  const optionsWithoutGroups = _flatMapInstanceProperty__default["default"](_context2 = props.options).call(_context2, option => {
309
309
  if (isOptionObject(option)) {
310
310
  return option.options;
@@ -364,10 +364,9 @@ const SelectableSearchInput = props => {
364
364
  const handleSubmit = event => {
365
365
  event.preventDefault();
366
366
  if (props.onSubmit) {
367
- var _selectedOption$value;
368
367
  props.onSubmit({
369
368
  text: searchInputValue,
370
- option: (_selectedOption$value = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value) !== null && _selectedOption$value !== void 0 ? _selectedOption$value : ''
369
+ option: selectedOption?.value ?? ''
371
370
  });
372
371
  }
373
372
  };
@@ -396,10 +395,9 @@ const SelectableSearchInput = props => {
396
395
  toggleDropdownHasFocus(false);
397
396
  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);
398
397
  const handleContainerBlur = react$1.useCallback(event => {
399
- var _containerRef$current;
400
398
  // ensures that both fields are marked as touched when one of them
401
399
  // is blurred
402
- if (typeof onBlur === 'function' && !((_containerRef$current = containerRef.current) !== null && _containerRef$current !== void 0 && _containerRef$current.contains(event.relatedTarget))) {
400
+ if (typeof onBlur === 'function' && !containerRef.current?.contains(event.relatedTarget)) {
403
401
  onBlur({
404
402
  target: {
405
403
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
@@ -415,7 +413,6 @@ const SelectableSearchInput = props => {
415
413
  }
416
414
  }, [onBlur, selectablSearchInputId, name]);
417
415
  const handleDropdownChange = react$1.useCallback(nextSelectedOptions => {
418
- var _textInputRef$current;
419
416
  setSearchOption(nextSelectedOptions.value);
420
417
  if (props.onChange) {
421
418
  props.onChange({
@@ -426,7 +423,7 @@ const SelectableSearchInput = props => {
426
423
  }
427
424
  });
428
425
  }
429
- (_textInputRef$current = textInputRef.current) === null || _textInputRef$current === void 0 || _textInputRef$current.focus();
426
+ textInputRef.current?.focus();
430
427
  }, [props.onChange, selectablSearchInputId, name]);
431
428
  return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
432
429
  max: props.horizontalConstraint,
@@ -440,7 +437,7 @@ const SelectableSearchInput = props => {
440
437
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
441
438
  name: getDropdownName(props.name),
442
439
  dropdownHasFocus: dropdownHasFocus,
443
- isCondensed: (_props$isCondensed = props.isCondensed) !== null && _props$isCondensed !== void 0 ? _props$isCondensed : false,
440
+ isCondensed: props.isCondensed ?? false,
444
441
  handleDropdownFocus: handleDropdownFocus,
445
442
  handleDropdownBlur: handleDropdownBlur,
446
443
  handleDropdownChange: handleDropdownChange,
@@ -516,7 +513,7 @@ SelectableSearchInput.getDropdownId = getDropdownName;
516
513
  var SelectableSearchInput$1 = SelectableSearchInput;
517
514
 
518
515
  // NOTE: This string will be replaced on build time with the package version.
519
- var version = "19.10.0";
516
+ var version = "19.11.0";
520
517
 
521
518
  exports["default"] = SelectableSearchInput$1;
522
519
  exports.version = version;
@@ -96,7 +96,7 @@ const getBackgroundColor = (props, defaultColor) => {
96
96
  }
97
97
  return defaultColor;
98
98
  };
99
- const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? "".concat(designTokens.heightForInputAsSmall) : "".concat(designTokens.heightForInput), ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";padding-left:", designTokens.spacing30, ";padding-right:", designTokens.spacing30, ";&::placeholder{color:", designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAiKK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */"), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/css("&:focus-within{border-color:", designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA4MO","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
99
+ const getSelectableSearchInputContainerStyles = props => [/*#__PURE__*/css("display:flex;align-items:center;background-color:", getBackgroundColor(props, designTokens.backgroundColorForInput), ";border:1px solid ", getInputContainerBorderColor(props), ";border-radius:", designTokens.borderRadiusForInput, ";box-shadow:", getInputBoxShadow(props), ";height:", props.isCondensed ? `${designTokens.heightForInputAsSmall}` : `${designTokens.heightForInput}`, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";padding-left:", designTokens.spacing30, ";padding-right:", designTokens.spacing30, ";&::placeholder{color:", designTokens.colorNeutral60, ";}&:hover{border-color:", getInputContainerBorderColor(props, designTokens.borderColorForInputWhenHovered), ";background-color:", getBackgroundColor(props, designTokens.backgroundColorForInputWhenHovered), ";}&:focus{border-color:", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAiKK","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */"), !props.isDisabled && !props.isReadOnly && /*#__PURE__*/css("&:focus-within{border-color:", designTokens.borderColorForInputWhenFocused, ";box-shadow:inset 0 0 0 1px ", designTokens.borderColorForInputWhenFocused, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA4MO","file":"selectable-search-input.styles.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { type Props as ReactSelectProps } from 'react-select';\nimport { getInputStyles } from '@commercetools-uikit/input-utils';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSelectStyles } from '@commercetools-uikit/select-utils';\n\ntype TInputProps = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst getInputContainerBorderColor = (\n  props: TInputProps,\n  defaultColor: string = designTokens.borderColorForInput\n) => {\n  if (props.isDisabled) {\n    return designTokens.borderColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.borderColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.borderColorForInputWhenWarning;\n  }\n  return defaultColor;\n};\n\nconst getInputFontColor = (props: TInputProps) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForInputWhenReadonly;\n  }\n  if (props.hasError) {\n    return designTokens.fontColorForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.fontColorForInputWhenWarning;\n  }\n  return designTokens.fontColorForInput;\n};\n\nconst getInputBoxShadow = (props: TInputProps) => {\n  if (props.hasError) {\n    return designTokens.shadowForInputWhenError;\n  }\n  if (props.hasWarning) {\n    return designTokens.shadowForInputWhenWarning;\n  }\n  return designTokens.shadowForInput;\n};\n\nconst getSelectableSearchInputStyles = (props: TInputProps) => [\n  getInputStyles(props),\n  css`\n    border: none;\n    box-shadow: none;\n    background: none;\n    &,\n    &:focus,\n    &:focus:not(:read-only) {\n      box-shadow: none;\n    }\n    &:focus,\n    &:hover {\n      background-color: transparent !important;\n    }\n    width: 100%;\n    color: ${getInputFontColor(props)};\n    order: 2;\n    margin-left: ${designTokens.spacing10};\n    padding-left: 0;\n    padding-right: 0;\n  `,\n];\n\nconst getButtonStyles = () => css`\n  border: none;\n  background: none;\n  height: 100%;\n  border-top-right-radius: ${designTokens.borderRadiusForInput};\n  border-bottom-right-radius: ${designTokens.borderRadiusForInput};\n  border-left: none;\n  align-items: center;\n  transition: border-color ${designTokens.transitionStandard},\n    background-color ${designTokens.transitionStandard};\n  transition: border-color ${designTokens.transitionStandard},\n    box-shadow ${designTokens.transitionStandard};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral40)};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorError)};\n    }\n    order: 3;\n    margin-left: ${designTokens.spacing10};\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\n\n    border-radius: 0;\n    order: 1;\n  `,\n];\n\nconst getBackgroundColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.backgroundColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.backgroundColorForInputWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getSelectableSearchInputContainerStyles = (props: TInputProps) => [\n  css`\n    display: flex;\n    align-items: center;\n    background-color: ${getBackgroundColor(\n      props,\n      designTokens.backgroundColorForInput\n    )};\n    border: 1px solid ${getInputContainerBorderColor(props)};\n    border-radius: ${designTokens.borderRadiusForInput};\n    box-shadow: ${getInputBoxShadow(props)};\n    height: ${props.isCondensed\n      ? `${designTokens.heightForInputAsSmall}`\n      : `${designTokens.heightForInput}`};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n    padding-left: ${designTokens.spacing30};\n    padding-right: ${designTokens.spacing30};\n\n    &::placeholder {\n      color: ${designTokens.colorNeutral60};\n    }\n\n    &:hover {\n      border-color: ${getInputContainerBorderColor(\n        props,\n        designTokens.borderColorForInputWhenHovered\n      )};\n      background-color: ${getBackgroundColor(\n        props,\n        designTokens.backgroundColorForInputWhenHovered\n      )};\n    }\n\n    &:focus {\n      border-color: ${designTokens.borderColorForInputWhenFocused};\n    }\n  `,\n  !props.isDisabled &&\n    !props.isReadOnly &&\n    css`\n      &:focus-within {\n        border-color: ${designTokens.borderColorForInputWhenFocused};\n        box-shadow: inset 0 0 0 1px\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\n  isCondensed?: boolean;\n  isDisabled?: boolean;\n  hasError?: boolean;\n  hasWarning?: boolean;\n  isReadOnly?: boolean;\n  menuPortalZIndex?: number;\n  dropdownHasFocus?: boolean;\n  horizontalConstraint?:\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst createSelectableSelectStyles = ({\n  hasWarning,\n  hasError,\n  isCondensed,\n  isDisabled,\n  isReadOnly,\n  menuPortalZIndex,\n  dropdownHasFocus,\n  horizontalConstraint,\n}: TCreateSelectableSelectStyles) => {\n  const selectStyles = createSelectStyles({\n    hasWarning,\n    hasError,\n    menuPortalZIndex,\n    isDisabled,\n    isReadOnly,\n    isCondensed,\n    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: `0 ${designTokens.spacing25}`,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\n      fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,\n      minHeight: isCondensed\n        ? designTokens.heightForInputAsSmall\n        : designTokens.heightForInput,\n      borderColor: (() => {\n        if (isDisabled)\n          return `${designTokens.borderColorForInputWhenDisabled} !important`;\n        if (isReadOnly)\n          return `${designTokens.borderColorForInputWhenReadonly} !important`;\n        if (hasError) return designTokens.borderColorForInputWhenError;\n        if (hasWarning) return designTokens.borderColorForInputWhenWarning;\n        if (dropdownHasFocus) {\n          return designTokens.borderColorForInputWhenFocused;\n        }\n        return designTokens.borderColorForInput;\n      })(),\n      cursor: (() => {\n        if (isDisabled) return 'not-allowed';\n        if (isReadOnly) return `default`;\n        return 'pointer';\n      })(),\n      backgroundColor: getBackgroundColor(\n        {\n          isDisabled,\n          isReadOnly,\n        },\n        base.backgroundColor || ''\n      ),\n      '&:hover': {\n        backgroundColor: getBackgroundColor(\n          {\n            isDisabled,\n            isReadOnly,\n          },\n          designTokens.backgroundColorForInputWhenHovered\n        ),\n      },\n    }),\n    singleValue: (base: TBase) => ({\n      ...base,\n      marginLeft: 0,\n      maxWidth: 'initial',\n      color: getInputFontColor({\n        hasWarning,\n        hasError,\n        isDisabled,\n        isReadOnly,\n      }),\n    }),\n    dropdownIndicator: () => ({\n      fill: isReadOnly\n        ? designTokens.fontColorForInputWhenDisabled\n        : designTokens.colorNeutral60,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
100
100
  const createSelectableSelectStyles = _ref => {
101
101
  let hasWarning = _ref.hasWarning,
102
102
  hasError = _ref.hasError,
@@ -117,7 +117,7 @@ const createSelectableSelectStyles = _ref => {
117
117
  });
118
118
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
119
119
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
120
- padding: "0 ".concat(designTokens.spacing25),
120
+ padding: `0 ${designTokens.spacing25}`,
121
121
  borderTopRightRadius: '0',
122
122
  borderBottomRightRadius: '0',
123
123
  borderRight: '0',
@@ -125,8 +125,8 @@ const createSelectableSelectStyles = _ref => {
125
125
  fontSize: isCondensed ? designTokens.fontSize20 : designTokens.fontSize30,
126
126
  minHeight: isCondensed ? designTokens.heightForInputAsSmall : designTokens.heightForInput,
127
127
  borderColor: (() => {
128
- if (isDisabled) return "".concat(designTokens.borderColorForInputWhenDisabled, " !important");
129
- if (isReadOnly) return "".concat(designTokens.borderColorForInputWhenReadonly, " !important");
128
+ if (isDisabled) return `${designTokens.borderColorForInputWhenDisabled} !important`;
129
+ if (isReadOnly) return `${designTokens.borderColorForInputWhenReadonly} !important`;
130
130
  if (hasError) return designTokens.borderColorForInputWhenError;
131
131
  if (hasWarning) return designTokens.borderColorForInputWhenWarning;
132
132
  if (dropdownHasFocus) {
@@ -136,7 +136,7 @@ const createSelectableSelectStyles = _ref => {
136
136
  })(),
137
137
  cursor: (() => {
138
138
  if (isDisabled) return 'not-allowed';
139
- if (isReadOnly) return "default";
139
+ if (isReadOnly) return `default`;
140
140
  return 'pointer';
141
141
  })(),
142
142
  backgroundColor: getBackgroundColor({
@@ -258,8 +258,8 @@ const Container = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
258
258
  map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.tsx"],"names":[],"mappings":"AAmC4B","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  ReactElement,\n} from 'react';\nimport SecondaryIconButton from '@commercetools-uikit/secondary-icon-button';\nimport IconButton, {\n  type TIconButtonProps,\n} from '@commercetools-uikit/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  _experimentalValue?: 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   * Use this property to reduce the paddings of the component for a ui compact variant\n   */\n  isCondensed?: 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   * Map of components to overwrite the default ones, see what components you can override\n   * <br/>\n   * [Props from React select was used](https://react-select.com/props)\n   */\n  selectCustomComponents?: ReactSelectProps['components'];\n\n  /**\n   * Custom action icon to be displayed on the right side of the input.\n   */\n  rightActionIcon?: ReactElement;\n  /**\n   * Props for the right-action icon-button. Required when rightActionIcon is provided.\n   * At least a `label` and an `onClick` prop/function need to be provided.\n   */\n  rightActionProps?: TIconButtonProps;\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 [searchOption, setSearchOption] = useState(props.value.option || '');\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  const searchInputValue = props._experimentalValue?.text ?? searchValue;\n  const searchInputOption = props._experimentalValue?.option ?? searchOption;\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 === searchInputOption\n  );\n\n  if (props.rightActionIcon && !props.rightActionProps) {\n    warning(\n      false,\n      'SelectableSearchInput: `rightActionIcon` is provided but `rightActionProps` is missing. Provide an object with a `label` and `onClick` property.'\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 handleTextInputChange = (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: searchInputValue,\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  const handleDropdownChange = useCallback(\n    (nextSelectedOptions) => {\n      setSearchOption(nextSelectedOptions.value);\n      if (props.onChange) {\n        props.onChange({\n          target: {\n            id: SelectableSearchInput.getDropdownId(selectablSearchInputId),\n            name: getDropdownName(name),\n            value: nextSelectedOptions.value,\n          },\n        });\n      }\n      textInputRef.current?.focus();\n    },\n    [props.onChange, 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            isCondensed={props.isCondensed ?? false}\n            handleDropdownFocus={handleDropdownFocus}\n            handleDropdownBlur={handleDropdownBlur}\n            handleDropdownChange={handleDropdownChange}\n            textInputRef={textInputRef}\n            selectedOption={selectedOption}\n            dataProps={transformedSelectDataProps}\n            selectCustomComponents={props.selectCustomComponents}\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={searchInputValue}\n            onChange={handleTextInputChange}\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            searchInputValue &&\n            !props.isDisabled &&\n            !props.isReadOnly && (\n              <SecondaryIconButton\n                icon={<CloseIcon />}\n                size={props.isCondensed ? '10' : '20'}\n                label={'clear-button'}\n                onClick={handleClear}\n                css={getClearIconButtonStyles(props)}\n              />\n            )}\n          {props.showSubmitButton && (\n            <SecondaryIconButton\n              icon={<SearchIcon />}\n              size={props.isCondensed ? '20' : '40'}\n              label={'search-button'}\n              onClick={handleSubmit}\n              css={getSearchIconButtonStyles(props)}\n              isDisabled={props.isDisabled}\n            />\n          )}\n\n          {props.rightActionIcon && props.rightActionProps && (\n            <div\n              css={css`\n                order: 4;\n                margin-left: ${designTokens.spacing30};\n              `}\n            >\n              <IconButton\n                theme=\"primary\"\n                isDisabled={props.isDisabled || props.isReadOnly}\n                size={props.isCondensed ? '10' : '20'}\n                icon={props.rightActionIcon}\n                {...props.rightActionProps}\n              />\n            </div>\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"]} */",
259
259
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
260
260
  });
261
- const getTextInputName = name => name ? "".concat(name, ".textInput") : undefined;
262
- const getDropdownName = name => name ? "".concat(name, ".dropdown") : undefined;
261
+ const getTextInputName = name => name ? `${name}.textInput` : undefined;
262
+ const getDropdownName = name => name ? `${name}.dropdown` : undefined;
263
263
  const defaultProps = {
264
264
  horizontalConstraint: 'scale',
265
265
  isClearable: true,
@@ -276,11 +276,11 @@ const transformDataProps = dataProps => {
276
276
  let _ref2 = _slicedToArray(_ref, 2),
277
277
  key = _ref2[0],
278
278
  value = _ref2[1];
279
- return ["data-".concat(key), value];
279
+ return [`data-${key}`, value];
280
280
  }));
281
281
  };
282
282
  const SelectableSearchInput = props => {
283
- var _props$_experimentalV, _props$_experimentalV2, _props$_experimentalV3, _props$_experimentalV4, _context2, _props$isCondensed;
283
+ var _context2;
284
284
  const _useToggleState = useToggleState(false),
285
285
  _useToggleState2 = _slicedToArray(_useToggleState, 2),
286
286
  dropdownHasFocus = _useToggleState2[0],
@@ -298,8 +298,8 @@ const SelectableSearchInput = props => {
298
298
  const legacyDataProps = filterDataAttributes(props);
299
299
  const transformedSelectDataProps = transformDataProps(props.selectDataProps);
300
300
  const transformedInputDataProps = transformDataProps(props.inputDataProps);
301
- const searchInputValue = (_props$_experimentalV = (_props$_experimentalV2 = props._experimentalValue) === null || _props$_experimentalV2 === void 0 ? void 0 : _props$_experimentalV2.text) !== null && _props$_experimentalV !== void 0 ? _props$_experimentalV : searchValue;
302
- const searchInputOption = (_props$_experimentalV3 = (_props$_experimentalV4 = props._experimentalValue) === null || _props$_experimentalV4 === void 0 ? void 0 : _props$_experimentalV4.option) !== null && _props$_experimentalV3 !== void 0 ? _props$_experimentalV3 : searchOption;
301
+ const searchInputValue = props._experimentalValue?.text ?? searchValue;
302
+ const searchInputOption = props._experimentalValue?.option ?? searchOption;
303
303
  const optionsWithoutGroups = _flatMapInstanceProperty(_context2 = props.options).call(_context2, option => {
304
304
  if (isOptionObject(option)) {
305
305
  return option.options;
@@ -363,10 +363,9 @@ const SelectableSearchInput = props => {
363
363
  const handleSubmit = event => {
364
364
  event.preventDefault();
365
365
  if (props.onSubmit) {
366
- var _selectedOption$value;
367
366
  props.onSubmit({
368
367
  text: searchInputValue,
369
- option: (_selectedOption$value = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value) !== null && _selectedOption$value !== void 0 ? _selectedOption$value : ''
368
+ option: selectedOption?.value ?? ''
370
369
  });
371
370
  }
372
371
  };
@@ -395,10 +394,9 @@ const SelectableSearchInput = props => {
395
394
  toggleDropdownHasFocus(false);
396
395
  }, [toggleDropdownHasFocus, onBlur, dropdownName, dropdownId]);
397
396
  const handleContainerBlur = useCallback(event => {
398
- var _containerRef$current;
399
397
  // ensures that both fields are marked as touched when one of them
400
398
  // is blurred
401
- if (typeof onBlur === 'function' && !((_containerRef$current = containerRef.current) !== null && _containerRef$current !== void 0 && _containerRef$current.contains(event.relatedTarget))) {
399
+ if (typeof onBlur === 'function' && !containerRef.current?.contains(event.relatedTarget)) {
402
400
  onBlur({
403
401
  target: {
404
402
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
@@ -414,7 +412,6 @@ const SelectableSearchInput = props => {
414
412
  }
415
413
  }, [onBlur, selectablSearchInputId, name]);
416
414
  const handleDropdownChange = useCallback(nextSelectedOptions => {
417
- var _textInputRef$current;
418
415
  setSearchOption(nextSelectedOptions.value);
419
416
  if (props.onChange) {
420
417
  props.onChange({
@@ -425,7 +422,7 @@ const SelectableSearchInput = props => {
425
422
  }
426
423
  });
427
424
  }
428
- (_textInputRef$current = textInputRef.current) === null || _textInputRef$current === void 0 || _textInputRef$current.focus();
425
+ textInputRef.current?.focus();
429
426
  }, [props.onChange, selectablSearchInputId, name]);
430
427
  return jsx(Constraints.Horizontal, {
431
428
  max: props.horizontalConstraint,
@@ -439,7 +436,7 @@ const SelectableSearchInput = props => {
439
436
  id: SelectableSearchInput.getDropdownId(selectablSearchInputId),
440
437
  name: getDropdownName(props.name),
441
438
  dropdownHasFocus: dropdownHasFocus,
442
- isCondensed: (_props$isCondensed = props.isCondensed) !== null && _props$isCondensed !== void 0 ? _props$isCondensed : false,
439
+ isCondensed: props.isCondensed ?? false,
443
440
  handleDropdownFocus: handleDropdownFocus,
444
441
  handleDropdownBlur: handleDropdownBlur,
445
442
  handleDropdownChange: handleDropdownChange,
@@ -555,6 +552,6 @@ SelectableSearchInput.getDropdownId = getDropdownName;
555
552
  var SelectableSearchInput$1 = SelectableSearchInput;
556
553
 
557
554
  // NOTE: This string will be replaced on build time with the package version.
558
- var version = "19.10.0";
555
+ var version = "19.11.0";
559
556
 
560
557
  export { SelectableSearchInput$1 as default, version };
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": "19.10.0",
4
+ "version": "19.12.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,15 +21,15 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "19.10.0",
25
- "@commercetools-uikit/design-system": "19.10.0",
26
- "@commercetools-uikit/hooks": "19.10.0",
27
- "@commercetools-uikit/icon-button": "19.10.0",
28
- "@commercetools-uikit/icons": "19.10.0",
29
- "@commercetools-uikit/input-utils": "19.10.0",
30
- "@commercetools-uikit/secondary-icon-button": "19.10.0",
31
- "@commercetools-uikit/select-utils": "19.10.0",
32
- "@commercetools-uikit/utils": "19.10.0",
24
+ "@commercetools-uikit/constraints": "19.12.0",
25
+ "@commercetools-uikit/design-system": "19.12.0",
26
+ "@commercetools-uikit/hooks": "19.12.0",
27
+ "@commercetools-uikit/icon-button": "19.12.0",
28
+ "@commercetools-uikit/icons": "19.12.0",
29
+ "@commercetools-uikit/input-utils": "19.12.0",
30
+ "@commercetools-uikit/secondary-icon-button": "19.12.0",
31
+ "@commercetools-uikit/select-utils": "19.12.0",
32
+ "@commercetools-uikit/utils": "19.12.0",
33
33
  "@emotion/react": "^11.10.5",
34
34
  "@emotion/styled": "^11.10.5",
35
35
  "lodash": "4.17.21",