@infomaximum/ui-kit 0.14.7 → 0.14.9-1

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.
Files changed (36) hide show
  1. package/dist/components/Alert/Alert.js +4 -4
  2. package/dist/components/Avatar/Avatar.js +1 -1
  3. package/dist/components/BaseSelect/BaseSelect.js +8 -8
  4. package/dist/components/BaseSelect/components/SelectOptionList/SelectOptionList.js +2 -2
  5. package/dist/components/BaseTooltip/BaseTooltip.js +2 -2
  6. package/dist/components/Button/Button.js +3 -3
  7. package/dist/components/Checkbox/Checkbox.js +6 -6
  8. package/dist/components/Checkbox/components/Group/Group.js +1 -1
  9. package/dist/components/Dropdown/components/Divider/Divider.js +1 -1
  10. package/dist/components/Dropdown/components/Group/Group.js +5 -5
  11. package/dist/components/Dropdown/components/Item/Item.js +6 -6
  12. package/dist/components/Dropdown/components/Menu/Menu.js +4 -4
  13. package/dist/components/Input/Input.js +5 -5
  14. package/dist/components/InputNumber/InputNumber.js +5 -5
  15. package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.js +3 -2
  16. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.js +3 -2
  17. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.d.ts +3 -4
  18. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.js +15 -4
  19. package/dist/components/Message/components/Message/Message.js +4 -4
  20. package/dist/components/Popconfirm/components/PopconfirmFloatingElement/PopconfirmFloatingElement.js +7 -7
  21. package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.js +3 -3
  22. package/dist/components/Radio/Radio.js +2 -2
  23. package/dist/components/Radio/components/RadioInternal/RadioInternal.js +1 -1
  24. package/dist/components/Select/components/SelectOption/SelectOption.js +5 -5
  25. package/dist/components/Switch/Switch.js +1 -1
  26. package/dist/components/Tabs/Tabs.js +1 -1
  27. package/dist/components/Tabs/components/TabBar/TabBar.js +4 -4
  28. package/dist/components/Tabs/components/TabItem/TabItem.js +4 -4
  29. package/dist/components/Tag/Tag.js +3 -2
  30. package/dist/components/Tag/Tag.types.d.ts +1 -0
  31. package/dist/components/Tag/components/Checkable/Checkable.js +1 -1
  32. package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.js +1 -1
  33. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.js +9 -9
  34. package/dist/components/Upload/components/InternalUpload/InternalUpload.js +1 -1
  35. package/dist/components/Upload/components/UploadListItem/UploadListItem.js +1 -1
  36. package/package.json +1 -1
@@ -287,7 +287,7 @@ const BaseSelectComponent = ({
287
287
  };
288
288
  const renderPlaceholder = () => {
289
289
  var _a2;
290
- return /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.placeholder(theme), (_a2 = styles == null ? void 0 : styles.placeholder) == null ? void 0 : _a2.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:renderPlaceholder;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAoYU","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: placeholder });
290
+ return /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.placeholder(theme), (_a2 = styles == null ? void 0 : styles.placeholder) == null ? void 0 : _a2.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:renderPlaceholder;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAoYU","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: placeholder });
291
291
  };
292
292
  const withClearButton = allowClear && !!filteredActiveValues.length;
293
293
  const inputValue = mode === "multiple" || isSelectOpen ? searchValue ?? searchInputValue : (_b = currentLabel[0]) == null ? void 0 : _b.toString();
@@ -325,17 +325,17 @@ const BaseSelectComponent = ({
325
325
  isItemHidden,
326
326
  getCurrentSelectingValue
327
327
  };
328
- return /* @__PURE__ */ jsx(baseSelectContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.wrapper(theme), (_c = styles == null ? void 0 : styles.wrapper) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA0bQ","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], tabIndex: 1, onKeyDown: keyDownHandler, onFocus: focusHandle, onBlur: blurHandle, autoFocus, ref: controlRef, children: [
329
- /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.body(theme), (_d = styles == null ? void 0 : styles.body) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAmcU","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], onClick: clickHandle, ref: refs.setReference, children: [
330
- /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.prefixAndContent(theme), (_e = styles == null ? void 0 : styles.prefixAndContent) == null ? void 0 : _e.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAwcY","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: [
331
- prefix && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.prefix(hasIconPrefix)(theme), (_f = styles == null ? void 0 : styles.prefix) == null ? void 0 : _f.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA4cgB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: prefix }),
328
+ return /* @__PURE__ */ jsx(baseSelectContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.wrapper(theme), (_c = styles == null ? void 0 : styles.wrapper) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA0bQ","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], tabIndex: 1, onKeyDown: keyDownHandler, onFocus: focusHandle, onBlur: blurHandle, autoFocus, ref: controlRef, children: [
329
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.body(theme), (_d = styles == null ? void 0 : styles.body) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAmcU","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], onClick: clickHandle, ref: refs.setReference, children: [
330
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.prefixAndContent(theme), (_e = styles == null ? void 0 : styles.prefixAndContent) == null ? void 0 : _e.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAwcY","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: [
331
+ prefix && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.prefix(hasIconPrefix)(theme), (_f = styles == null ? void 0 : styles.prefix) == null ? void 0 : _f.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA4cgB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: prefix }),
332
332
  showSearch ? /* @__PURE__ */ jsxs("span", { ref: containerRef, css: selectDefaultStyle.content(theme), children: [
333
333
  mode === "multiple" && renderLabel(filteredActiveValues, currentLabel),
334
334
  /* @__PURE__ */ jsx("input", { css: selectDefaultStyle.searchInput(theme), value: inputValue ?? "", onChange: searchHandle, placeholder: searchInputPlaceholder == null ? void 0 : searchInputPlaceholder.toString(), ref: inputRef, disabled, style: getSelectSearchInputWidthStyle(mode === "multiple", isEmpty, lettersNumber), "data-element": "search-input" })
335
- ] }) : /* @__PURE__ */ jsx("span", { ref: containerRef, css: [selectDefaultStyle.content(theme), (_g = styles == null ? void 0 : styles.content) == null ? void 0 : _g.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAuegB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder() })
335
+ ] }) : /* @__PURE__ */ jsx("span", { ref: containerRef, css: [selectDefaultStyle.content(theme), (_g = styles == null ? void 0 : styles.content) == null ? void 0 : _g.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAuegB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder() })
336
336
  ] }),
337
- withClearButton && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.cleanIcon(theme), (_h = styles == null ? void 0 : styles.cleanIcon) == null ? void 0 : _h.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAgfc","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], onClick: clearSelect, children: /* @__PURE__ */ jsx(CloseCircleFilled, { onClick: clearSelect, "data-element": "clean-button" }) }),
338
- /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.suffixIcon(theme), (_i = styles == null ? void 0 : styles.suffixIcon) == null ? void 0 : _i.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAsfgB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderSuffix() })
337
+ withClearButton && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.cleanIcon(theme), (_h = styles == null ? void 0 : styles.cleanIcon) == null ? void 0 : _h.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAgfc","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], onClick: clearSelect, children: /* @__PURE__ */ jsx(CloseCircleFilled, { onClick: clearSelect, "data-element": "clean-button" }) }),
338
+ /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.suffixIcon(theme), (_i = styles == null ? void 0 : styles.suffixIcon) == null ? void 0 : _i.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAsfgB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n\n  const isInitialMount = useRef(true);\n  const controlRef = useRef<HTMLSpanElement | null>(null);\n  const inputRef = useRef<HTMLInputElement | null>(null);\n\n  const referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const withAutoClear = mode === \"single\" || autoClearSearchValue;\n\n  const clickHandle = () => {\n    if (disabled) {\n      return;\n    }\n\n    setIsSelectOpen((prev) => !prev);\n  };\n\n  const changeHandle = useCallback(\n    (value: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const focusHandle = (e: FocusEvent) => {\n    onFocus?.(e);\n\n    if (!showSearch) {\n      return;\n    }\n\n    returnFocusToInput();\n  };\n\n  const renderTagPlaceholder = (hiddenElementsCounter: number) => {\n    if (isUndefined(maxTagPlaceholder)) {\n      return <TagPlaceholder hiddenElementsCounter={hiddenElementsCounter} />;\n    }\n\n    if (!isFunction(maxTagPlaceholder)) {\n      return <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder}</span>;\n    }\n\n    const hiddenElements = currentValue.reduce((acc: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (showSearch && isSelectOpen) {\n      return <SearchOutlined />;\n    }\n\n    return suffixIcon;\n  };\n\n  const renderPlaceholder = () => (\n    <span css={[selectDefaultStyle.placeholder(theme), styles?.placeholder?.(theme)]}>\n      {placeholder}\n    </span>\n  );\n\n  const withClearButton = allowClear && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onFocus={focusHandle}\n        onBlur={blurHandle}\n        autoFocus={autoFocus}\n        ref={controlRef}\n      >\n        <span\n          css={[selectDefaultStyle.body(theme), styles?.body?.(theme)]}\n          onClick={clickHandle}\n          ref={refs.setReference}\n        >\n          <span\n            css={[selectDefaultStyle.prefixAndContent(theme), styles?.prefixAndContent?.(theme)]}\n          >\n            {prefix && (\n              <span\n                css={[selectDefaultStyle.prefix(hasIconPrefix)(theme), styles?.prefix?.(theme)]}\n              >\n                {prefix}\n              </span>\n            )}\n\n            {showSearch ? (\n              <span ref={containerRef} css={selectDefaultStyle.content(theme)}>\n                {mode === \"multiple\" && renderLabel(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <span\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              onClick={clearSelect}\n            >\n              <CloseCircleFilled onClick={clearSelect} data-element=\"clean-button\" />\n            </span>\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderSuffix() })
339
339
  ] }),
340
340
  /* @__PURE__ */ jsx(SelectOptionList, { options: filteredAndSortedOptions, renderDropdownItem, optionRender, virtualizerEstimateSize, styles: styles == null ? void 0 : styles.dropdownStyle })
341
341
  ] }) });