@infomaximum/ui-kit 0.12.9 → 0.12.11-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 (41) hide show
  1. package/dist/components/Alert/Alert.js +4 -4
  2. package/dist/components/Avatar/Avatar.js +1 -1
  3. package/dist/components/Button/Button.js +3 -3
  4. package/dist/components/Checkbox/Checkbox.js +21 -8
  5. package/dist/components/Checkbox/Checkbox.types.d.ts +12 -3
  6. package/dist/components/Checkbox/components/Group/Group.d.ts +2 -2
  7. package/dist/components/Checkbox/components/Group/Group.js +22 -8
  8. package/dist/components/Checkbox/components/Group/Group.utils.d.ts +2 -0
  9. package/dist/components/Checkbox/components/Group/Group.utils.js +6 -1
  10. package/dist/components/Checkbox/index.d.ts +1 -1
  11. package/dist/components/Dropdown/components/Divider/Divider.js +1 -1
  12. package/dist/components/Dropdown/components/Group/Group.js +5 -5
  13. package/dist/components/Dropdown/components/Item/Item.js +6 -6
  14. package/dist/components/Dropdown/components/Menu/Menu.js +4 -4
  15. package/dist/components/Input/Input.js +5 -5
  16. package/dist/components/InputNumber/InputNumber.js +4 -4
  17. package/dist/components/InputNumber/InputNumber.styles.d.ts +3 -0
  18. package/dist/components/InputNumber/InputNumber.styles.js +3 -0
  19. package/dist/components/InputNumber/hooks/useChangeValue/useChangeValue.js +2 -2
  20. package/dist/components/InternalPicker/pickers/RangePicker/RangePicker.js +3 -2
  21. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.js +3 -2
  22. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.d.ts +3 -4
  23. package/dist/components/InternalPicker/pickers/SinglePicker/SinglePicker.utils.js +15 -4
  24. package/dist/components/Message/components/Message/Message.js +4 -4
  25. package/dist/components/Popconfirm/components/PopconfirmFloatingElement/PopconfirmFloatingElement.js +7 -7
  26. package/dist/components/Popover/component/PopoverFloatingElement/PopoverFloatingElement.js +3 -3
  27. package/dist/components/Radio/Radio.js +2 -2
  28. package/dist/components/Radio/components/RadioInternal/RadioInternal.js +1 -1
  29. package/dist/components/Select/Select.js +9 -9
  30. package/dist/components/Select/components/SelectOptionList/SelectOptionList.js +2 -2
  31. package/dist/components/Switch/Switch.js +1 -1
  32. package/dist/components/Tabs/Tabs.js +1 -1
  33. package/dist/components/Tabs/components/TabBar/TabBar.js +2 -2
  34. package/dist/components/Tabs/components/TabItem/TabItem.js +4 -4
  35. package/dist/components/Tag/Tag.js +2 -2
  36. package/dist/components/Tag/components/Checkable/Checkable.js +1 -1
  37. package/dist/components/Tooltip/components/TooltipFloatingElement/TooltipFloatingElement.js +1 -1
  38. package/dist/components/Upload/components/InternalUpload/InternalUpload.js +1 -1
  39. package/dist/components/Upload/components/UploadListItem/UploadListItem.js +1 -1
  40. package/dist/index.d.ts +1 -1
  41. package/package.json +1 -1
@@ -265,7 +265,7 @@ const SelectComponent = memo(({
265
265
  const renderSuffix = () => {
266
266
  var _a2;
267
267
  if (withDrawer) {
268
- return /* @__PURE__ */ jsx(BarsOutlined, { onClick: clickHandle, css: [selectDefaultStyle.drawerIcon(theme), (_a2 = styles == null ? void 0 : styles.drawerIcon) == null ? void 0 : _a2.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:renderSuffix;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAgYY","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"] });
268
+ return /* @__PURE__ */ jsx(BarsOutlined, { onClick: clickHandle, css: [selectDefaultStyle.drawerIcon(theme), (_a2 = styles == null ? void 0 : styles.drawerIcon) == null ? void 0 : _a2.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:renderSuffix;", 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/Select/Select.tsx"],"names":[],"mappings":"AAgYY","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"] });
269
269
  }
270
270
  if (showSearch && isSelectOpen) {
271
271
  return /* @__PURE__ */ jsx(SearchOutlined, {});
@@ -274,7 +274,7 @@ const SelectComponent = memo(({
274
274
  };
275
275
  const renderPlaceholder = () => {
276
276
  var _a2;
277
- 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/Select/Select.tsx"],"names":[],"mappings":"AA6YY","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: placeholder });
277
+ 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/Select/Select.tsx"],"names":[],"mappings":"AA6YY","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: placeholder });
278
278
  };
279
279
  const withClearButton = allowClear && !!activeValues.length;
280
280
  const inputValue = mode === "multiple" || isSelectOpen ? searchValue ?? searchInputValue : currentLabel[0];
@@ -284,17 +284,17 @@ const SelectComponent = memo(({
284
284
  const searchInputPlaceholder = mode === "single" ? singleModPlaceholder : multipleModPlaceholder;
285
285
  const lettersNumber = ((inputValue == null ? void 0 : inputValue.length) ?? 0) + 1;
286
286
  const hasIconPrefix = typeof prefix === "object";
287
- return /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.wrapper(theme), (_b = styles == null ? void 0 : styles.wrapper) == null ? void 0 : _b.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAoaQ","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], tabIndex: 1, onKeyDown: keyDownHandler, onMouseOver: mouseOverHandle, onMouseOut: mouseOutHandle, onFocus: focusHandle, onBlur: blurHandle, autoFocus, ref: controlRef, children: [
288
- /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.body(theme), (_c = styles == null ? void 0 : styles.body) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AA+aU","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], onClick: !withDrawer ? clickHandle : void 0, ref: refs.setReference, children: [
289
- /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.prefixAndContent(theme), (_d = styles == null ? void 0 : styles.prefixAndContent) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAobY","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: [
290
- prefix && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.prefix(hasIconPrefix)(theme), (_e = styles == null ? void 0 : styles.prefix) == null ? void 0 : _e.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAwbgB","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: prefix }),
287
+ return /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.wrapper(theme), (_b = styles == null ? void 0 : styles.wrapper) == null ? void 0 : _b.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AAoaQ","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], tabIndex: 1, onKeyDown: keyDownHandler, onMouseOver: mouseOverHandle, onMouseOut: mouseOutHandle, onFocus: focusHandle, onBlur: blurHandle, autoFocus, ref: controlRef, children: [
288
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.body(theme), (_c = styles == null ? void 0 : styles.body) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AA+aU","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], onClick: !withDrawer ? clickHandle : void 0, ref: refs.setReference, children: [
289
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.prefixAndContent(theme), (_d = styles == null ? void 0 : styles.prefixAndContent) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AAobY","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: [
290
+ prefix && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.prefix(hasIconPrefix)(theme), (_e = styles == null ? void 0 : styles.prefix) == null ? void 0 : _e.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AAwbgB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: prefix }),
291
291
  showSearch ? /* @__PURE__ */ jsxs("span", { ref: containerRef, css: selectDefaultStyle.content(theme), children: [
292
292
  mode === "multiple" && renderLabel(activeValues, currentLabel),
293
293
  /* @__PURE__ */ jsx("input", { css: selectDefaultStyle.searchInput(theme), value: inputValue ?? "", onChange: searchHandle, placeholder: searchInputPlaceholder, ref: inputRef, disabled, style: getSelectSearchInputWidthStyle(mode === "multiple", isEmpty, lettersNumber), "data-element": "search-input" })
294
- ] }) : /* @__PURE__ */ jsx("span", { ref: containerRef, css: [selectDefaultStyle.content(theme), (_f = styles == null ? void 0 : styles.content) == null ? void 0 : _f.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAmdgB","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: renderLabel(currentValue, currentLabel) ?? renderPlaceholder() })
294
+ ] }) : /* @__PURE__ */ jsx("span", { ref: containerRef, css: [selectDefaultStyle.content(theme), (_f = styles == null ? void 0 : styles.content) == null ? void 0 : _f.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AAmdgB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: renderLabel(currentValue, currentLabel) ?? renderPlaceholder() })
295
295
  ] }),
296
- withClearButton && /* @__PURE__ */ jsx(CloseCircleFilled, { className: "clean-button", onClick: clearSelect, css: [selectDefaultStyle.cleanIcon(theme), (_g = styles == null ? void 0 : styles.cleanIcon) == null ? void 0 : _g.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AA8dc","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], "data-element": "clean-button" }),
297
- /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.suffixIcon(theme), (_h = styles == null ? void 0 : styles.suffixIcon) == null ? void 0 : _h.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx"],"names":[],"mappings":"AAkegB","file":"/builds/frontend/libs/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: renderSuffix() })
296
+ withClearButton && /* @__PURE__ */ jsx(CloseCircleFilled, { className: "clean-button", onClick: clearSelect, css: [selectDefaultStyle.cleanIcon(theme), (_g = styles == null ? void 0 : styles.cleanIcon) == null ? void 0 : _g.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AA8dc","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], "data-element": "clean-button" }),
297
+ /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.suffixIcon(theme), (_h = styles == null ? void 0 : styles.suffixIcon) == null ? void 0 : _h.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:SelectComponent;", 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/Select/Select.tsx"],"names":[],"mappings":"AAkegB","file":"/Users/alex/projects/work/LIBS/ui-kit/src/components/Select/Select.tsx","sourcesContent":["import {\n  type FC,\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 type { SelectProps } from \"./Select.types\";\nimport { withThemeProvider } from \"hocs/withThemeProvider\";\nimport type {\n  SelectOptionInterface,\n  SelectOptionValue,\n} from \"./components/SelectOption/SelectOption.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./Select.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport {\n  additionalElements,\n  convertSelectPlacement,\n  getLabel,\n  getVisibleLabels,\n} from \"./Select.utils\";\nimport { useKeyControl } from \"./hooks/useKeyControl\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"components/Select/hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\n\nconst SelectComponent: FC<PropsWithChildren<SelectProps>> = memo(\n  ({\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    filterOption = true,\n    optionFilterProp = \"title\",\n    searchValue,\n    notFoundContent,\n    optionLabelProp = \"title\",\n    drawer = false,\n    autoClearSearchValue = true,\n    maxTagCount,\n    maxTagTextLength,\n    maxTagPlaceholder,\n    filterSort,\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  }) => {\n    const theme = useTheme();\n\n    const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } =\n      useSearch({\n        options,\n        filterOption,\n        optionFilterProp,\n        searchValue,\n        onSearch,\n        filterSort,\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    const [isHover, setIsHover] = useState(false);\n\n    const isInitialMount = useRef(true);\n    const controlRef = useRef<HTMLSpanElement | null>(null);\n    const inputRef = useRef<HTMLInputElement | null>(null);\n\n    const optionsMap = useMemo(() => {\n      const optionList: [SelectOptionValue, SelectOptionInterface][] = options.map((option) => [\n        option.value,\n        option,\n      ]);\n\n      return new Map(optionList);\n    }, [options]);\n\n    const { currentSelectingIndex, onKeyControl, setCurrentSelectingIndex } = useKeyControl(\n      currentValue,\n      filteredAndSortedOptions,\n      optionsMap\n    );\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: SelectOptionInterface[], value) => {\n          const option = optionsMap.get(value);\n\n          if (isUndefined(option)) {\n            return acc;\n          }\n\n          return [...acc, option];\n        }, []);\n\n        onChange?.(currentValue, options);\n      }\n    }, [currentValue]);\n\n    useEffect(() => {\n      if (isInitialMount.current) {\n        isInitialMount.current = false;\n      } else {\n        onDropdownVisibleChange?.();\n      }\n    }, [isSelectOpen]);\n\n    const selectDefaultStyle = getSelectDefaultStyle(\n      status,\n      disabled,\n      variant,\n      mode === \"multiple\",\n      isHover,\n      maxTagCount\n    );\n\n    const activeValues = Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n\n    const { containerRef, isItemHidden } = useHideElements(\n      activeValues,\n      theme.spaceXS,\n      additionalElements,\n      inputRef\n    );\n\n    const currentLabel = getLabel(activeValues, optionsMap, optionLabelProp);\n\n    const withDrawer = mode === \"multiple\" && drawer;\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: SelectOptionValue, index: number) => {\n        changeCurrentValue(value);\n        setCurrentSelectingIndex(index);\n        const option = optionsMap.get(value);\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n\n        if (option) {\n          onSelect?.(value, option);\n        }\n      },\n      [\n        changeCurrentValue,\n        clearSearchValue,\n        onSelect,\n        optionsMap,\n        setCurrentSelectingIndex,\n        withAutoClear,\n      ]\n    );\n\n    const closeOptionList = useCallback(() => {\n      setIsSelectOpen(false);\n    }, []);\n\n    const blurHandle = (e: FocusEvent) => {\n      const isFocusOnOptionList = refs.floating.current === e.relatedTarget;\n      const isFocusOnSearchInput =\n        !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n      const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n      if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\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          changeCurrentValue(filteredAndSortedOptions[currentSelectingIndex]?.value);\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 mouseOverHandle = () => {\n      setIsHover(true);\n    };\n\n    const mouseOutHandle = () => {\n      setIsHover(false);\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: SelectOptionInterface[], value) => {\n        const isHidden = isItemHidden.get(value);\n        const option = optionsMap.get(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: SelectOptionValue[], currentLabel: string[]) => {\n      const visibleLabels = getVisibleLabels(currentLabel, values, maxTagCount, isItemHidden);\n\n      const label = visibleLabels.map((label, index) => {\n        const value = values[index];\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        return (\n          <SelectTag\n            value={value}\n            label={label}\n            removeValue={removeValue}\n            maxTagTextLength={maxTagTextLength}\n            isBorderless={variant === \"borderless\"}\n            isError={status === \"error\"}\n            disabled={disabled}\n            key={value}\n          />\n        );\n      });\n\n      const hiddenElementsCounter = currentLabel.length - label.length;\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 (withDrawer) {\n        return (\n          <BarsOutlined\n            onClick={clickHandle}\n            css={[selectDefaultStyle.drawerIcon(theme), styles?.drawerIcon?.(theme)]}\n          />\n        );\n      }\n\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 && !!activeValues.length;\n\n    const inputValue =\n      mode === \"multiple\" || isSelectOpen ? (searchValue ?? searchInputValue) : currentLabel[0];\n\n    const isEmpty = activeValues.length === 0;\n    const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n    const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n    const searchInputPlaceholder =\n      mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n    const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n    const hasIconPrefix = typeof prefix === \"object\";\n\n    return (\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        onMouseOver={mouseOverHandle}\n        onMouseOut={mouseOutHandle}\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={!withDrawer ? clickHandle : undefined}\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(activeValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder}\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(currentValue, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <CloseCircleFilled\n              className=\"clean-button\"\n              onClick={clearSelect}\n              css={[selectDefaultStyle.cleanIcon(theme), styles?.cleanIcon?.(theme)]}\n              data-element=\"clean-button\"\n            />\n          )}\n          <span css={[selectDefaultStyle.suffixIcon(theme), styles?.suffixIcon?.(theme)]}>\n            {renderSuffix()}\n          </span>\n        </span>\n\n        <SelectOptionList\n          options={filteredAndSortedOptions}\n          currentValue={activeValues}\n          showOptionList={open ?? isSelectOpen}\n          setValue={changeHandle}\n          closeOptionList={closeOptionList}\n          dropdownMinWidth={dropdownMinWidth}\n          dropdownMaxHeight={dropdownMaxHeight}\n          returnFocusToWrapper={returnFocusToWrapper}\n          dropdownPrompt={dropdownPrompt}\n          loading={loading}\n          dropdownClassName={dropdownClassName}\n          styles={styles?.dropdownStyle}\n          dropdownRender={dropdownRender}\n          optionRender={optionRender}\n          dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n          referenceOffsetWidth={referenceOffsetWidth}\n          floatingStyles={floatingStyles}\n          setFloating={refs.setFloating}\n          floatingRef={refs.floating}\n          getPopupContainer={getPopupContainer}\n          virtual={virtual}\n          currentSelectingIndex={currentSelectingIndex}\n          emptyContent={emptyContent}\n          notFoundContent={notFoundContent}\n          searchValue={searchValue ?? searchInputValue}\n          showSearch={showSearch}\n          mode={mode}\n          removeValue={removeValue}\n        />\n      </span>\n    );\n  }\n);\n\nexport const Select = withThemeProvider<SelectProps>(SelectComponent);\n"]} */"], children: renderSuffix() })
298
298
  ] }),
299
299
  /* @__PURE__ */ jsx(SelectOptionList, { options: filteredAndSortedOptions, currentValue: activeValues, showOptionList: open ?? isSelectOpen, setValue: changeHandle, closeOptionList, dropdownMinWidth, dropdownMaxHeight, returnFocusToWrapper, dropdownPrompt, loading, dropdownClassName, styles: styles == null ? void 0 : styles.dropdownStyle, dropdownRender, optionRender, dropdownMatchSelectWidth, referenceOffsetWidth, floatingStyles, setFloating: refs.setFloating, floatingRef: refs.floating, getPopupContainer, virtual, currentSelectingIndex, emptyContent, notFoundContent, searchValue: searchValue ?? searchInputValue, showSearch, mode, removeValue })
300
300
  ] });