@commercetools-uikit/selectable-search-input 17.1.0 → 18.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -99,19 +99,19 @@ const getInputBoxShadow = props => {
99
99
  }
100
100
  return designSystem.designTokens.shadowForInput;
101
101
  };
102
- const getSelectableSearchInputStyles = props => [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA6EK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
103
- const getButtonStyles = () => /*#__PURE__*/react.css("border:none;background:none;height:100%;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";margin-right:", designSystem.designTokens.marginRightForClearInputIcon, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA+FiC","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */");
102
+ const getSelectableSearchInputStyles = props => [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA6EK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
103
+ const getButtonStyles = () => /*#__PURE__*/react.css("border:none;background:none;height:100%;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";margin-right:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA+FiC","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */");
104
104
  const getIconColor = (props, defaultColor) => {
105
105
  if (props.isDisabled) {
106
106
  return designSystem.designTokens.fontColorForInputWhenDisabled;
107
107
  }
108
108
  if (props.isReadOnly) {
109
- return designSystem.designTokens.fontColorForSearchInputIconWhenReadonly;
109
+ return designSystem.designTokens.colorNeutral60;
110
110
  }
111
111
  return defaultColor;
112
112
  };
113
- const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIcon), ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA0HK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
114
- const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.marginRightForSearchInputIcon, ";fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIcon), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSearchIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAuIK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
113
+ const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("fill:", getIconColor(props, designSystem.designTokens.colorNeutral40), ";&:hover{fill:", getIconColor(props, designSystem.designTokens.colorError), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA0HK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
114
+ const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.spacing25, ";fill:", getIconColor(props, designSystem.designTokens.colorNeutral60), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designSystem.designTokens.colorPrimary), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSearchIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAoIK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
115
115
  const getBackgroundColor = (props, defaultColor) => {
116
116
  if (props.isDisabled) {
117
117
  return designSystem.designTokens.backgroundColorForInputWhenDisabled;
@@ -121,7 +121,7 @@ const getBackgroundColor = (props, defaultColor) => {
121
121
  }
122
122
  return defaultColor;
123
123
  };
124
- 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:", designSystem.designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";&::placeholder{color:", designSystem.designTokens.placeholderFontColorForInput, ";}&: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":"AA+JK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\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:", designSystem.designTokens.boxShadowForDatetimeInputWhenHovered, " ", 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":"AAuMO","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
124
+ 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:", designSystem.designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";&::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":"AAyJK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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":"AAiMO","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
125
125
  const createSelectableSelectStyles = _ref => {
126
126
  let hasWarning = _ref.hasWarning,
127
127
  hasError = _ref.hasError,
@@ -140,7 +140,7 @@ const createSelectableSelectStyles = _ref => {
140
140
  });
141
141
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
142
142
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
143
- padding: designSystem.designTokens.paddingForSelectableSearchInputDropdown,
143
+ padding: "0 ".concat(designSystem.designTokens.spacing25),
144
144
  borderTopRightRadius: '0',
145
145
  borderBottomRightRadius: '0',
146
146
  borderRight: '0',
@@ -182,7 +182,7 @@ const createSelectableSelectStyles = _ref => {
182
182
  })
183
183
  }),
184
184
  dropdownIndicator: () => ({
185
- fill: isReadOnly ? designSystem.designTokens.fontColorForInputWhenDisabled : designSystem.designTokens.fontColorForSelectInputIcon
185
+ fill: isReadOnly ? designSystem.designTokens.fontColorForInputWhenDisabled : designSystem.designTokens.colorNeutral60
186
186
  })
187
187
  });
188
188
  };
@@ -553,7 +553,7 @@ SelectableSearchInput.getDropdownId = getDropdownName;
553
553
  var SelectableSearchInput$1 = SelectableSearchInput;
554
554
 
555
555
  // NOTE: This string will be replaced on build time with the package version.
556
- var version = "17.1.0";
556
+ var version = "18.0.0";
557
557
 
558
558
  exports["default"] = SelectableSearchInput$1;
559
559
  exports.version = version;
@@ -99,18 +99,18 @@ const getInputBoxShadow = props => {
99
99
  return designSystem.designTokens.shadowForInput;
100
100
  };
101
101
  const getSelectableSearchInputStyles = props => [inputUtils.getInputStyles(props), /*#__PURE__*/react.css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + ("" ), "" )];
102
- const getButtonStyles = () => /*#__PURE__*/react.css("border:none;background:none;height:100%;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";margin-right:", designSystem.designTokens.marginRightForClearInputIcon, ";" + ("" ), "" );
102
+ const getButtonStyles = () => /*#__PURE__*/react.css("border:none;background:none;height:100%;border-top-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designSystem.designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",box-shadow ", designSystem.designTokens.transitionStandard, ";margin-right:", designSystem.designTokens.spacing20, ";" + ("" ), "" );
103
103
  const getIconColor = (props, defaultColor) => {
104
104
  if (props.isDisabled) {
105
105
  return designSystem.designTokens.fontColorForInputWhenDisabled;
106
106
  }
107
107
  if (props.isReadOnly) {
108
- return designSystem.designTokens.fontColorForSearchInputIconWhenReadonly;
108
+ return designSystem.designTokens.colorNeutral60;
109
109
  }
110
110
  return defaultColor;
111
111
  };
112
- const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIcon), ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForClearInputIconWhenHovered), ";}" + ("" ), "" )];
113
- const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.marginRightForSearchInputIcon, ";fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIcon), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designSystem.designTokens.fontColorForSearchInputIconWhenHovered), ";}" + ("" ), "" )];
112
+ const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("fill:", getIconColor(props, designSystem.designTokens.colorNeutral40), ";&:hover{fill:", getIconColor(props, designSystem.designTokens.colorError), ";}" + ("" ), "" )];
113
+ const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.spacing25, ";fill:", getIconColor(props, designSystem.designTokens.colorNeutral60), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designSystem.designTokens.colorPrimary), ";}" + ("" ), "" )];
114
114
  const getBackgroundColor = (props, defaultColor) => {
115
115
  if (props.isDisabled) {
116
116
  return designSystem.designTokens.backgroundColorForInputWhenDisabled;
@@ -120,7 +120,7 @@ const getBackgroundColor = (props, defaultColor) => {
120
120
  }
121
121
  return defaultColor;
122
122
  };
123
- 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:", designSystem.designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";&::placeholder{color:", designSystem.designTokens.placeholderFontColorForInput, ";}&: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:", designSystem.designTokens.boxShadowForDatetimeInputWhenHovered, " ", designSystem.designTokens.borderColorForInputWhenFocused, ";}" + ("" ), "" )];
123
+ 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:", designSystem.designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ";&::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, ";}" + ("" ), "" )];
124
124
  const createSelectableSelectStyles = _ref => {
125
125
  let hasWarning = _ref.hasWarning,
126
126
  hasError = _ref.hasError,
@@ -139,7 +139,7 @@ const createSelectableSelectStyles = _ref => {
139
139
  });
140
140
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
141
141
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
142
- padding: designSystem.designTokens.paddingForSelectableSearchInputDropdown,
142
+ padding: "0 ".concat(designSystem.designTokens.spacing25),
143
143
  borderTopRightRadius: '0',
144
144
  borderBottomRightRadius: '0',
145
145
  borderRight: '0',
@@ -181,7 +181,7 @@ const createSelectableSelectStyles = _ref => {
181
181
  })
182
182
  }),
183
183
  dropdownIndicator: () => ({
184
- fill: isReadOnly ? designSystem.designTokens.fontColorForInputWhenDisabled : designSystem.designTokens.fontColorForSelectInputIcon
184
+ fill: isReadOnly ? designSystem.designTokens.fontColorForInputWhenDisabled : designSystem.designTokens.colorNeutral60
185
185
  })
186
186
  });
187
187
  };
@@ -493,7 +493,7 @@ SelectableSearchInput.getDropdownId = getDropdownName;
493
493
  var SelectableSearchInput$1 = SelectableSearchInput;
494
494
 
495
495
  // NOTE: This string will be replaced on build time with the package version.
496
- var version = "17.1.0";
496
+ var version = "18.0.0";
497
497
 
498
498
  exports["default"] = SelectableSearchInput$1;
499
499
  exports.version = version;
@@ -73,19 +73,19 @@ const getInputBoxShadow = props => {
73
73
  }
74
74
  return designTokens.shadowForInput;
75
75
  };
76
- const getSelectableSearchInputStyles = props => [getInputStyles(props), /*#__PURE__*/css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA6EK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
77
- const getButtonStyles = () => /*#__PURE__*/css("border:none;background:none;height:100%;border-top-right-radius:", designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";transition:border-color ", designTokens.transitionStandard, ",box-shadow ", designTokens.transitionStandard, ";margin-right:", designTokens.marginRightForClearInputIcon, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA+FiC","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */");
76
+ const getSelectableSearchInputStyles = props => [getInputStyles(props), /*#__PURE__*/css("border:none;box-shadow:none;background:none;&,&:focus,&:focus:not(:read-only){box-shadow:none;}&:focus,&:hover{background-color:transparent!important;}width:100%;color:", getInputFontColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getSelectableSearchInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA6EK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
77
+ const getButtonStyles = () => /*#__PURE__*/css("border:none;background:none;height:100%;border-top-right-radius:", designTokens.borderRadiusForInput, ";border-bottom-right-radius:", designTokens.borderRadiusForInput, ";border-left:none;align-items:center;transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";transition:border-color ", designTokens.transitionStandard, ",box-shadow ", designTokens.transitionStandard, ";margin-right:", designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:getButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA+FiC","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */");
78
78
  const getIconColor = (props, defaultColor) => {
79
79
  if (props.isDisabled) {
80
80
  return designTokens.fontColorForInputWhenDisabled;
81
81
  }
82
82
  if (props.isReadOnly) {
83
- return designTokens.fontColorForSearchInputIconWhenReadonly;
83
+ return designTokens.colorNeutral60;
84
84
  }
85
85
  return defaultColor;
86
86
  };
87
- const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/css("fill:", getIconColor(props, designTokens.fontColorForClearInputIcon), ";&:hover{fill:", getIconColor(props, designTokens.fontColorForClearInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA0HK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
88
- const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/css("margin-right:", designTokens.marginRightForSearchInputIcon, ";fill:", getIconColor(props, designTokens.fontColorForSearchInputIcon), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designTokens.fontColorForSearchInputIconWhenHovered), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSearchIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAuIK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
87
+ const getClearIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/css("fill:", getIconColor(props, designTokens.colorNeutral40), ";&:hover{fill:", getIconColor(props, designTokens.colorError), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getClearIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AA0HK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
88
+ const getSearchIconButtonStyles = props => [getButtonStyles(), /*#__PURE__*/css("margin-right:", designTokens.spacing25, ";fill:", getIconColor(props, designTokens.colorNeutral60), ";cursor:", props.isReadOnly ? 'default' : 'pointer', ";&:hover{fill:", getIconColor(props, designTokens.colorPrimary), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:getSearchIconButtonStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["selectable-search-input.styles.ts"],"names":[],"mappings":"AAoIK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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"]} */")];
89
89
  const getBackgroundColor = (props, defaultColor) => {
90
90
  if (props.isDisabled) {
91
91
  return designTokens.backgroundColorForInputWhenDisabled;
@@ -95,7 +95,7 @@ const getBackgroundColor = (props, defaultColor) => {
95
95
  }
96
96
  return defaultColor;
97
97
  };
98
- 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:", designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";&::placeholder{color:", designTokens.placeholderFontColorForInput, ";}&: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":"AA+JK","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\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:", designTokens.boxShadowForDatetimeInputWhenHovered, " ", 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":"AAuMO","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  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  `,\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  margin-right: ${designTokens.marginRightForClearInputIcon};\n`;\n\nconst getIconColor = (props: TInputProps, defaultColor: string) => {\n  if (props.isDisabled) {\n    return designTokens.fontColorForInputWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForSearchInputIconWhenReadonly;\n  }\n  return defaultColor;\n};\n\nconst getClearIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    fill: ${getIconColor(props, designTokens.fontColorForClearInputIcon)};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForClearInputIconWhenHovered\n      )};\n    }\n  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.marginRightForSearchInputIcon};\n    fill: ${getIconColor(props, designTokens.fontColorForSearchInputIcon)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(\n        props,\n        designTokens.fontColorForSearchInputIconWhenHovered\n      )};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\n\n    &::placeholder {\n      color: ${designTokens.placeholderFontColorForInput};\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: ${designTokens.boxShadowForDatetimeInputWhenHovered}\n          ${designTokens.borderColorForInputWhenFocused};\n      }\n    `,\n];\n\ntype TBase = {\n  backgroundColor?: string;\n  color?: string;\n};\n\ntype TCreateSelectableSelectStyles = {\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  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    horizontalConstraint,\n  });\n\n  return {\n    ...selectStyles,\n    control: (base: TBase, state: ReactSelectProps) => ({\n      ...selectStyles.control(base, state),\n      padding: designTokens.paddingForSelectableSearchInputDropdown,\n      borderTopRightRadius: '0',\n      borderBottomRightRadius: '0',\n      borderRight: '0',\n      height: '100%',\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.fontColorForSelectInputIcon,\n    }),\n  };\n};\n\nexport {\n  getSelectableSearchInputStyles,\n  getSelectableSearchInputContainerStyles,\n  getClearIconButtonStyles,\n  getSearchIconButtonStyles,\n  getBackgroundColor,\n  createSelectableSelectStyles,\n};\n"]} */")];
98
+ 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:", designTokens.heightForInput, ";box-sizing:border-box;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;width:", props.horizontalConstraint === 'auto' ? 'auto' : '100%', ";transition:border-color ", designTokens.transitionStandard, ",background-color ", designTokens.transitionStandard, ";&::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":"AAyJK","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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":"AAiMO","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  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  `,\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  margin-right: ${designTokens.spacing20};\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  `,\n];\n\nconst getSearchIconButtonStyles = (props: TInputProps) => [\n  getButtonStyles(),\n  css`\n    margin-right: ${designTokens.spacing25};\n    fill: ${getIconColor(props, designTokens.colorNeutral60)};\n    cursor: ${props.isReadOnly ? 'default' : 'pointer'};\n    &:hover {\n      fill: ${getIconColor(props, designTokens.colorPrimary)};\n    }\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: ${designTokens.heightForInput};\n    box-sizing: border-box;\n    border-top-left-radius: 0;\n    border-bottom-left-radius: 0;\n    margin-left: 0;\n    width: ${props.horizontalConstraint === 'auto' ? 'auto' : '100%'};\n    transition: border-color ${designTokens.transitionStandard},\n      background-color ${designTokens.transitionStandard};\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  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  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    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      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
99
  const createSelectableSelectStyles = _ref => {
100
100
  let hasWarning = _ref.hasWarning,
101
101
  hasError = _ref.hasError,
@@ -114,7 +114,7 @@ const createSelectableSelectStyles = _ref => {
114
114
  });
115
115
  return _objectSpread$2(_objectSpread$2({}, selectStyles), {}, {
116
116
  control: (base, state) => _objectSpread$2(_objectSpread$2({}, selectStyles.control(base, state)), {}, {
117
- padding: designTokens.paddingForSelectableSearchInputDropdown,
117
+ padding: "0 ".concat(designTokens.spacing25),
118
118
  borderTopRightRadius: '0',
119
119
  borderBottomRightRadius: '0',
120
120
  borderRight: '0',
@@ -156,7 +156,7 @@ const createSelectableSelectStyles = _ref => {
156
156
  })
157
157
  }),
158
158
  dropdownIndicator: () => ({
159
- fill: isReadOnly ? designTokens.fontColorForInputWhenDisabled : designTokens.fontColorForSelectInputIcon
159
+ fill: isReadOnly ? designTokens.fontColorForInputWhenDisabled : designTokens.colorNeutral60
160
160
  })
161
161
  });
162
162
  };
@@ -527,6 +527,6 @@ SelectableSearchInput.getDropdownId = getDropdownName;
527
527
  var SelectableSearchInput$1 = SelectableSearchInput;
528
528
 
529
529
  // NOTE: This string will be replaced on build time with the package version.
530
- var version = "17.1.0";
530
+ var version = "18.0.0";
531
531
 
532
532
  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": "17.1.0",
4
+ "version": "18.0.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,14 +21,14 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/constraints": "17.1.0",
25
- "@commercetools-uikit/design-system": "17.1.0",
26
- "@commercetools-uikit/hooks": "17.1.0",
27
- "@commercetools-uikit/icons": "17.1.0",
28
- "@commercetools-uikit/input-utils": "17.1.0",
29
- "@commercetools-uikit/secondary-icon-button": "17.1.0",
30
- "@commercetools-uikit/select-utils": "17.1.0",
31
- "@commercetools-uikit/utils": "17.1.0",
24
+ "@commercetools-uikit/constraints": "18.0.0",
25
+ "@commercetools-uikit/design-system": "18.0.0",
26
+ "@commercetools-uikit/hooks": "18.0.0",
27
+ "@commercetools-uikit/icons": "18.0.0",
28
+ "@commercetools-uikit/input-utils": "18.0.0",
29
+ "@commercetools-uikit/secondary-icon-button": "18.0.0",
30
+ "@commercetools-uikit/select-utils": "18.0.0",
31
+ "@commercetools-uikit/utils": "18.0.0",
32
32
  "@emotion/react": "^11.10.5",
33
33
  "@emotion/styled": "^11.10.5",
34
34
  "lodash": "4.17.21",