@infomaximum/ui-kit 0.12.12 → 0.13.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 (105) hide show
  1. package/dist/components/BaseSelect/BaseSelect.d.ts +5 -0
  2. package/dist/components/BaseSelect/BaseSelect.js +360 -0
  3. package/dist/components/{Select/Select.styles.d.ts → BaseSelect/BaseSelect.styles.d.ts} +20 -4
  4. package/dist/components/{Select/Select.styles.js → BaseSelect/BaseSelect.styles.js} +23 -10
  5. package/dist/components/BaseSelect/BaseSelect.types.d.ts +99 -0
  6. package/dist/components/BaseSelect/BaseSelect.utils.d.ts +8 -0
  7. package/dist/components/BaseSelect/BaseSelect.utils.js +39 -0
  8. package/dist/components/BaseSelect/components/BaseSelectOptionList/BaseSelectOptionList.types.d.ts +11 -0
  9. package/dist/components/BaseSelect/components/SelectOptionList/SelectOptionList.d.ts +4 -0
  10. package/dist/components/BaseSelect/components/SelectOptionList/SelectOptionList.js +120 -0
  11. package/dist/components/{Select → BaseSelect}/components/SelectOptionList/SelectOptionList.styles.d.ts +13 -4
  12. package/dist/components/{Select → BaseSelect}/components/SelectOptionList/SelectOptionList.styles.js +13 -7
  13. package/dist/components/BaseSelect/components/SelectOptionList/SelectOptionList.types.d.ts +20 -0
  14. package/dist/components/BaseSelect/components/SelectTag/SelectTag.d.ts +4 -0
  15. package/dist/components/{Select → BaseSelect}/components/SelectTag/SelectTag.js +9 -5
  16. package/dist/components/BaseSelect/components/SelectTag/SelectTag.styles.d.ts +16 -0
  17. package/dist/components/{Select → BaseSelect}/components/SelectTag/SelectTag.styles.js +13 -3
  18. package/dist/components/BaseSelect/components/SelectTag/SelectTag.types.d.ts +11 -0
  19. package/dist/components/BaseSelect/contexts/BaseSelectContext.d.ts +33 -0
  20. package/dist/components/BaseSelect/contexts/BaseSelectContext.js +8 -0
  21. package/dist/components/BaseSelect/hooks/useCurrentValue.d.ts +7 -0
  22. package/dist/components/{Select → BaseSelect}/hooks/useCurrentValue.js +15 -0
  23. package/dist/components/BaseSelect/hooks/useDefaultCurrentValue.d.ts +2 -0
  24. package/dist/components/{Select → BaseSelect}/hooks/useDefaultCurrentValue.js +1 -1
  25. package/dist/components/BaseSelect/hooks/useDefaultSelectIndex.d.ts +2 -0
  26. package/dist/components/BaseSelect/hooks/useHideElements.d.ts +6 -0
  27. package/dist/components/{Select → BaseSelect}/hooks/useHideElements.js +11 -3
  28. package/dist/components/BaseSelect/hooks/useSearch.d.ts +10 -0
  29. package/dist/components/{Select → BaseSelect}/hooks/useSearch.js +4 -16
  30. package/dist/components/Checkbox/Checkbox.js +12 -8
  31. package/dist/components/Checkbox/Checkbox.utils.d.ts +2 -0
  32. package/dist/components/Checkbox/Checkbox.utils.js +5 -0
  33. package/dist/components/Checkbox/index.d.ts +1 -0
  34. package/dist/components/Input/Input.d.ts +2 -2
  35. package/dist/components/Input/Input.js +35 -10
  36. package/dist/components/Input/Input.styles.d.ts +7 -0
  37. package/dist/components/Input/Input.styles.js +9 -5
  38. package/dist/components/Input/Input.types.d.ts +16 -6
  39. package/dist/components/Input/components/InputPassword/InputPassword.d.ts +2 -1
  40. package/dist/components/Input/components/InputTextArea/InputTextArea.d.ts +2 -2
  41. package/dist/components/Input/components/InputTextArea/InputTextArea.js +27 -5
  42. package/dist/components/Input/components/InputTextArea/InputTextArea.types.d.ts +10 -2
  43. package/dist/components/Input/index.d.ts +3 -1
  44. package/dist/components/Select/Select.d.ts +2 -2
  45. package/dist/components/Select/Select.js +39 -281
  46. package/dist/components/Select/Select.types.d.ts +6 -85
  47. package/dist/components/Select/Select.utils.d.ts +1 -9
  48. package/dist/components/Select/Select.utils.js +1 -46
  49. package/dist/components/Select/components/SelectOption/SelectOption.js +20 -23
  50. package/dist/components/Select/components/SelectOption/SelectOption.styles.js +1 -1
  51. package/dist/components/Select/components/SelectOption/SelectOption.types.d.ts +13 -15
  52. package/dist/components/Select/hooks/useKeyControl.d.ts +7 -3
  53. package/dist/components/Select/hooks/useKeyControl.js +48 -13
  54. package/dist/components/TreeSelect/TreeSelect.d.ts +3 -0
  55. package/dist/components/TreeSelect/TreeSelect.js +189 -0
  56. package/dist/components/TreeSelect/TreeSelect.tokens.d.ts +30 -0
  57. package/dist/components/TreeSelect/TreeSelect.tokens.js +31 -0
  58. package/dist/components/TreeSelect/TreeSelect.types.d.ts +69 -0
  59. package/dist/components/TreeSelect/TreeSelect.utils.d.ts +13 -0
  60. package/dist/components/TreeSelect/TreeSelect.utils.js +192 -0
  61. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.d.ts +3 -0
  62. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.js +117 -0
  63. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.styles.d.ts +83 -0
  64. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.styles.js +111 -0
  65. package/dist/components/TreeSelect/components/TreeSelectOption/TreeSelectOption.types.d.ts +27 -0
  66. package/dist/components/TreeSelect/contexts/treeSelectContext.d.ts +14 -0
  67. package/dist/components/TreeSelect/contexts/treeSelectContext.js +5 -0
  68. package/dist/components/TreeSelect/forStories/dataForExamples.d.ts +32 -0
  69. package/dist/components/TreeSelect/hooks/useAsyncLoading.d.ts +8 -0
  70. package/dist/components/TreeSelect/hooks/useAsyncLoading.js +39 -0
  71. package/dist/components/TreeSelect/hooks/useElementSizesController.d.ts +6 -0
  72. package/dist/components/TreeSelect/hooks/useElementSizesController.js +21 -0
  73. package/dist/components/TreeSelect/hooks/useExtendController.d.ts +19 -0
  74. package/dist/components/TreeSelect/hooks/useExtendController.js +65 -0
  75. package/dist/components/TreeSelect/hooks/useKeyControl.d.ts +11 -0
  76. package/dist/components/TreeSelect/hooks/useKeyControl.js +75 -0
  77. package/dist/components/TreeSelect/hooks/useTreeCheckable.d.ts +6 -0
  78. package/dist/components/TreeSelect/hooks/useTreeCheckable.js +56 -0
  79. package/dist/components/TreeSelect/hooks/useTreeData.d.ts +8 -0
  80. package/dist/components/TreeSelect/hooks/useTreeData.js +33 -0
  81. package/dist/components/TreeSelect/index.d.ts +2 -0
  82. package/dist/index.d.ts +5 -4
  83. package/dist/index.js +4 -0
  84. package/package.json +1 -1
  85. package/dist/components/Select/components/SelectOptionList/SelectOptionList.d.ts +0 -3
  86. package/dist/components/Select/components/SelectOptionList/SelectOptionList.js +0 -139
  87. package/dist/components/Select/components/SelectOptionList/SelectOptionList.types.d.ts +0 -42
  88. package/dist/components/Select/components/SelectOptionList/SelectOptionList.utils.d.ts +0 -1
  89. package/dist/components/Select/components/SelectOptionList/SelectOptionList.utils.js +0 -4
  90. package/dist/components/Select/components/SelectTag/SelectTag.d.ts +0 -3
  91. package/dist/components/Select/components/SelectTag/SelectTag.styles.d.ts +0 -8
  92. package/dist/components/Select/components/SelectTag/SelectTag.types.d.ts +0 -10
  93. package/dist/components/Select/hooks/useCurrentValue.d.ts +0 -8
  94. package/dist/components/Select/hooks/useDefaultCurrentValue.d.ts +0 -3
  95. package/dist/components/Select/hooks/useDefaultSelectIndex.d.ts +0 -2
  96. package/dist/components/Select/hooks/useDefaultSelectIndex.js +0 -17
  97. package/dist/components/Select/hooks/useHideElements.d.ts +0 -5
  98. package/dist/components/Select/hooks/useSearch.d.ts +0 -11
  99. /package/dist/components/{Select/Select.tokens.d.ts → BaseSelect/BaseSelect.tokens.d.ts} +0 -0
  100. /package/dist/components/{Select/Select.tokens.js → BaseSelect/BaseSelect.tokens.js} +0 -0
  101. /package/dist/components/{Select → BaseSelect}/components/TagPlaceholder/TagPlaceholder.d.ts +0 -0
  102. /package/dist/components/{Select → BaseSelect}/components/TagPlaceholder/TagPlaceholder.js +0 -0
  103. /package/dist/components/{Select → BaseSelect}/components/TagPlaceholder/TagPlaceholder.styles.d.ts +0 -0
  104. /package/dist/components/{Select → BaseSelect}/components/TagPlaceholder/TagPlaceholder.styles.js +0 -0
  105. /package/dist/components/{Select → BaseSelect}/components/TagPlaceholder/TagPlaceholder.types.d.ts +0 -0
@@ -0,0 +1,360 @@
1
+ import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
2
+ import { memo, useState, useRef, useCallback, useEffect, useMemo } from "react";
3
+ import { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from "./BaseSelect.styles.js";
4
+ import { CloseCircleFilled, DownOutlined, BarsOutlined, SearchOutlined } from "@infomaximum/icons";
5
+ import { isUndefined, isFunction, isNull, isNumber } from "lodash-es";
6
+ import { useFloating, autoUpdate, offset, flip } from "@floating-ui/react";
7
+ import { convertSelectPlacement, getLabel, getVisibleLabels } from "./BaseSelect.utils.js";
8
+ import { useSearch } from "./hooks/useSearch.js";
9
+ import { useCurrentValue } from "./hooks/useCurrentValue.js";
10
+ import { SelectTag } from "./components/SelectTag/SelectTag.js";
11
+ import { useHideElements } from "./hooks/useHideElements.js";
12
+ import { TagPlaceholder, tagPlaceholderDataElement } from "./components/TagPlaceholder/TagPlaceholder.js";
13
+ import { SelectOptionList } from "./components/SelectOptionList/SelectOptionList.js";
14
+ import { createBaseSelectContext } from "./contexts/BaseSelectContext.js";
15
+ import { useTheme } from "../../hooks/useTheme/useTheme.js";
16
+ const BaseSelectComponent = ({
17
+ options = [],
18
+ mode = "single",
19
+ variant = "outlined",
20
+ defaultValue,
21
+ defaultOpen = false,
22
+ defaultActiveFirstOption,
23
+ value,
24
+ open,
25
+ placeholder,
26
+ dropdownMinWidth = 120,
27
+ dropdownMaxHeight = 414,
28
+ allowClear = false,
29
+ autoFocus,
30
+ prefix,
31
+ suffixIcon = /* @__PURE__ */ jsx(DownOutlined, {}),
32
+ status = "default",
33
+ disabled = false,
34
+ dropdownPrompt,
35
+ loading = false,
36
+ dropdownClassName,
37
+ styles,
38
+ dropdownMatchSelectWidth = true,
39
+ placement = "bottomLeft",
40
+ virtual = true,
41
+ emptyContent = "",
42
+ showSearch = mode === "single" ? false : true,
43
+ searchValue,
44
+ notFoundContent = "Not found",
45
+ optionLabelProp = "title",
46
+ drawer = false,
47
+ autoClearSearchValue = true,
48
+ maxTagCount,
49
+ maxTagTextLength,
50
+ maxTagPlaceholder,
51
+ currentSelectingIndex,
52
+ getCurrentSelectingValue,
53
+ onKeyControl,
54
+ getOptionByValue,
55
+ virtualizerEstimateSize,
56
+ filterOptions,
57
+ filterSort,
58
+ valuesFilter,
59
+ dropdownRender,
60
+ optionRender,
61
+ labelRender,
62
+ onBlur,
63
+ onChange,
64
+ onClear,
65
+ onDropdownVisibleChange,
66
+ onFocus,
67
+ onInputKeyDown,
68
+ onSelect,
69
+ getPopupContainer = () => document.body,
70
+ onSearch,
71
+ tagRender,
72
+ onDeselect,
73
+ renderDropdownItem,
74
+ onTagClose
75
+ }) => {
76
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i;
77
+ const theme = useTheme();
78
+ const baseSelectContext = createBaseSelectContext();
79
+ const {
80
+ filteredAndSortedOptions,
81
+ searchInputValue,
82
+ searchHandle,
83
+ clearSearchValue
84
+ } = useSearch({
85
+ options,
86
+ searchValue,
87
+ onSearch,
88
+ filterSort,
89
+ filterOptions
90
+ });
91
+ const {
92
+ currentValue,
93
+ changeCurrentValue,
94
+ removeValue,
95
+ clearCurrentValue
96
+ } = useCurrentValue(mode, defaultValue, defaultActiveFirstOption, options, onDeselect);
97
+ const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);
98
+ const [isHover, setIsHover] = useState(false);
99
+ const isInitialMount = useRef(true);
100
+ const controlRef = useRef(null);
101
+ const inputRef = useRef(null);
102
+ const referenceOffsetWidth = (_a = controlRef.current) == null ? void 0 : _a.offsetWidth;
103
+ const {
104
+ refs,
105
+ floatingStyles
106
+ } = useFloating({
107
+ whileElementsMounted: autoUpdate,
108
+ placement: convertSelectPlacement(placement),
109
+ middleware: [offset(4), flip()]
110
+ });
111
+ const returnFocusToWrapper = useCallback(() => {
112
+ setTimeout(() => {
113
+ var _a2;
114
+ (_a2 = controlRef.current) == null ? void 0 : _a2.focus();
115
+ });
116
+ }, []);
117
+ const returnFocusToInput = useCallback(() => {
118
+ setTimeout(() => {
119
+ var _a2;
120
+ (_a2 = inputRef.current) == null ? void 0 : _a2.focus();
121
+ });
122
+ }, []);
123
+ useEffect(() => {
124
+ if (!isInitialMount.current) {
125
+ const options2 = currentValue.reduce((acc, value2) => {
126
+ const option = getOptionByValue(value2);
127
+ if (isUndefined(option)) {
128
+ return acc;
129
+ }
130
+ return [...acc, option];
131
+ }, []);
132
+ onChange == null ? void 0 : onChange(currentValue, options2);
133
+ }
134
+ }, [currentValue, getOptionByValue, onChange]);
135
+ useEffect(() => {
136
+ if (isInitialMount.current) {
137
+ isInitialMount.current = false;
138
+ } else {
139
+ onDropdownVisibleChange == null ? void 0 : onDropdownVisibleChange();
140
+ }
141
+ }, [isSelectOpen, onDropdownVisibleChange]);
142
+ const activeValues = useMemo(() => {
143
+ return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];
144
+ }, [currentValue, value]);
145
+ const selectDefaultStyle = getSelectDefaultStyle({
146
+ status,
147
+ disabled,
148
+ variant,
149
+ multiple: mode === "multiple",
150
+ isHover,
151
+ maxTagCount,
152
+ withPrefix: !!prefix,
153
+ isEmpty: activeValues.length === 0
154
+ });
155
+ const filteredActiveValues = useMemo(() => {
156
+ return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;
157
+ }, [activeValues, valuesFilter]);
158
+ const {
159
+ containerRef,
160
+ isItemHidden
161
+ } = useHideElements(filteredActiveValues, theme.spaceXS, inputRef, maxTagCount);
162
+ const currentLabel = getLabel(filteredActiveValues, getOptionByValue, optionLabelProp);
163
+ const withDrawer = mode === "multiple" && drawer;
164
+ const withAutoClear = mode === "single" || autoClearSearchValue;
165
+ const clickHandle = () => {
166
+ if (disabled) {
167
+ return;
168
+ }
169
+ setIsSelectOpen((prev) => !prev);
170
+ };
171
+ const changeHandle = useCallback((value2) => {
172
+ changeCurrentValue(value2);
173
+ if (Array.isArray(value2)) {
174
+ return;
175
+ }
176
+ const option = getOptionByValue(value2);
177
+ if (withAutoClear) {
178
+ clearSearchValue();
179
+ }
180
+ if (option) {
181
+ onSelect == null ? void 0 : onSelect(value2, option);
182
+ }
183
+ }, [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]);
184
+ const closeOptionList = useCallback(() => {
185
+ setIsSelectOpen(false);
186
+ }, []);
187
+ const blurHandle = (e) => {
188
+ var _a2;
189
+ const isFocusOnOptionList = (_a2 = refs.floating.current) == null ? void 0 : _a2.contains(e.relatedTarget);
190
+ const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;
191
+ const isFocusOnControl = e.relatedTarget === controlRef.current;
192
+ if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {
193
+ if (showSearch) {
194
+ returnFocusToInput();
195
+ } else {
196
+ returnFocusToWrapper();
197
+ }
198
+ return;
199
+ }
200
+ onBlur == null ? void 0 : onBlur(e);
201
+ clearSearchValue();
202
+ closeOptionList();
203
+ };
204
+ const clearSelect = useCallback((e) => {
205
+ e.preventDefault();
206
+ e.stopPropagation();
207
+ clearCurrentValue();
208
+ onClear == null ? void 0 : onClear();
209
+ }, [clearCurrentValue, onClear]);
210
+ const keyDownHandler = (e) => {
211
+ if (e.key === "Enter") {
212
+ if (isSelectOpen) {
213
+ const value2 = getCurrentSelectingValue();
214
+ if (!value2) {
215
+ return;
216
+ }
217
+ if (currentValue.includes(value2)) {
218
+ removeValue(value2);
219
+ } else {
220
+ changeCurrentValue(value2);
221
+ }
222
+ if (withAutoClear) {
223
+ clearSearchValue();
224
+ }
225
+ }
226
+ clickHandle();
227
+ }
228
+ setIsSelectOpen(true);
229
+ onKeyControl(e);
230
+ onInputKeyDown == null ? void 0 : onInputKeyDown(e);
231
+ };
232
+ const mouseOverHandle = () => {
233
+ setIsHover(true);
234
+ };
235
+ const mouseOutHandle = () => {
236
+ setIsHover(false);
237
+ };
238
+ const focusHandle = (e) => {
239
+ onFocus == null ? void 0 : onFocus(e);
240
+ if (!showSearch) {
241
+ return;
242
+ }
243
+ returnFocusToInput();
244
+ };
245
+ const renderTagPlaceholder = (hiddenElementsCounter) => {
246
+ if (isUndefined(maxTagPlaceholder)) {
247
+ return /* @__PURE__ */ jsx(TagPlaceholder, { hiddenElementsCounter });
248
+ }
249
+ if (!isFunction(maxTagPlaceholder)) {
250
+ return /* @__PURE__ */ jsx("span", { "data-element": tagPlaceholderDataElement, children: maxTagPlaceholder });
251
+ }
252
+ const hiddenElements = currentValue.reduce((acc, value2) => {
253
+ const isHidden = isItemHidden.get(value2);
254
+ const option = getOptionByValue(value2);
255
+ if (!isHidden || isUndefined(option)) {
256
+ return acc;
257
+ }
258
+ acc.push(option);
259
+ return acc;
260
+ }, []);
261
+ return /* @__PURE__ */ jsx("span", { "data-element": tagPlaceholderDataElement, children: maxTagPlaceholder(hiddenElements) });
262
+ };
263
+ const renderLabel = (values, currentLabel2) => {
264
+ const visibleLabels = getVisibleLabels(currentLabel2, maxTagCount);
265
+ const label = visibleLabels.map((label2, index) => {
266
+ const value2 = values[index];
267
+ if (isFunction(labelRender)) {
268
+ return labelRender({
269
+ label: label2,
270
+ value: value2
271
+ });
272
+ }
273
+ if (mode === "single") {
274
+ return label2;
275
+ }
276
+ if (isFunction(tagRender)) {
277
+ return tagRender(label2);
278
+ }
279
+ const isHidden = !!isItemHidden.get(value2);
280
+ return /* @__PURE__ */ jsx(SelectTag, { value: value2, label: label2, removeValue, maxTagTextLength, isBorderless: variant === "borderless", isError: status === "error", disabled, isHidden, onTagClose }, value2 == null ? void 0 : value2.toString());
281
+ });
282
+ const hiddenElementsCounter = isNumber(maxTagCount) ? isItemHidden.size - maxTagCount : Array.from(isItemHidden.values()).reduce((acc, isHidden) => isHidden ? acc + 1 : acc, 0);
283
+ const withTagPlaceholder = !isUndefined(maxTagCount) && mode === "multiple" && hiddenElementsCounter > 0;
284
+ if (label.length === 0) {
285
+ return null;
286
+ }
287
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
288
+ label,
289
+ withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)
290
+ ] });
291
+ };
292
+ const renderSuffix = () => {
293
+ var _a2;
294
+ if (withDrawer) {
295
+ 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/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA4YU","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"] });
296
+ }
297
+ if (showSearch && isSelectOpen) {
298
+ return /* @__PURE__ */ jsx(SearchOutlined, {});
299
+ }
300
+ return suffixIcon;
301
+ };
302
+ const renderPlaceholder = () => {
303
+ var _a2;
304
+ return /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.placeholder(theme), (_a2 = styles == null ? void 0 : styles.placeholder) == null ? void 0 : _a2.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:renderPlaceholder;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAyZU","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: placeholder });
305
+ };
306
+ const withClearButton = allowClear && !!filteredActiveValues.length;
307
+ const inputValue = mode === "multiple" || isSelectOpen ? searchValue ?? searchInputValue : (_b = currentLabel[0]) == null ? void 0 : _b.toString();
308
+ const isEmpty = filteredActiveValues.length === 0;
309
+ const singleModPlaceholder = currentLabel[0] ?? placeholder ?? "";
310
+ const multipleModPlaceholder = isEmpty ? placeholder : void 0;
311
+ const searchInputPlaceholder = mode === "single" ? singleModPlaceholder : multipleModPlaceholder;
312
+ const lettersNumber = ((inputValue == null ? void 0 : inputValue.length) ?? 0) + 1;
313
+ const hasIconPrefix = typeof prefix === "object";
314
+ const contextValue = {
315
+ currentValue: activeValues,
316
+ showOptionList: open ?? isSelectOpen,
317
+ setValue: changeHandle,
318
+ closeOptionList,
319
+ dropdownMinWidth,
320
+ dropdownMaxHeight,
321
+ dropdownPrompt,
322
+ loading,
323
+ dropdownClassName,
324
+ dropdownRender,
325
+ dropdownMatchSelectWidth,
326
+ referenceOffsetWidth,
327
+ floatingStyles,
328
+ setFloating: refs.setFloating,
329
+ floatingRef: refs.floating,
330
+ getPopupContainer,
331
+ virtual,
332
+ currentSelectingIndex,
333
+ emptyContent,
334
+ notFoundContent,
335
+ searchValue: searchValue ?? searchInputValue,
336
+ showSearch,
337
+ mode,
338
+ removeValue,
339
+ isItemHidden,
340
+ getCurrentSelectingValue
341
+ };
342
+ return /* @__PURE__ */ jsx(baseSelectContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.wrapper(theme), (_c = styles == null ? void 0 : styles.wrapper) == null ? void 0 : _c.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA+cQ","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], tabIndex: 1, onKeyDown: keyDownHandler, onMouseOver: mouseOverHandle, onMouseOut: mouseOutHandle, onFocus: focusHandle, onBlur: blurHandle, autoFocus, ref: controlRef, children: [
343
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.body(theme), (_d = styles == null ? void 0 : styles.body) == null ? void 0 : _d.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA0dU","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], onClick: !withDrawer ? clickHandle : void 0, ref: refs.setReference, children: [
344
+ /* @__PURE__ */ jsxs("span", { css: [selectDefaultStyle.prefixAndContent(theme), (_e = styles == null ? void 0 : styles.prefixAndContent) == null ? void 0 : _e.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA+dY","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: [
345
+ prefix && /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.prefix(hasIconPrefix)(theme), (_f = styles == null ? void 0 : styles.prefix) == null ? void 0 : _f.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAmegB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: prefix }),
346
+ showSearch ? /* @__PURE__ */ jsxs("span", { ref: containerRef, css: selectDefaultStyle.content(theme), children: [
347
+ mode === "multiple" && renderLabel(filteredActiveValues, currentLabel),
348
+ /* @__PURE__ */ jsx("input", { css: selectDefaultStyle.searchInput(theme), value: inputValue ?? "", onChange: searchHandle, placeholder: searchInputPlaceholder == null ? void 0 : searchInputPlaceholder.toString(), ref: inputRef, disabled, style: getSelectSearchInputWidthStyle(mode === "multiple", isEmpty, lettersNumber), "data-element": "search-input" })
349
+ ] }) : /* @__PURE__ */ jsx("span", { ref: containerRef, css: [selectDefaultStyle.content(theme), (_g = styles == null ? void 0 : styles.content) == null ? void 0 : _g.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA8fgB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder() })
350
+ ] }),
351
+ withClearButton && /* @__PURE__ */ jsx(CloseCircleFilled, { className: "clean-button", onClick: clearSelect, css: [selectDefaultStyle.cleanIcon(theme), (_h = styles == null ? void 0 : styles.cleanIcon) == null ? void 0 : _h.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AAygBc","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], "data-element": "clean-button" }),
352
+ /* @__PURE__ */ jsx("span", { css: [selectDefaultStyle.suffixIcon(theme), (_i = styles == null ? void 0 : styles.suffixIcon) == null ? void 0 : _i.call(styles, theme), process.env.NODE_ENV === "production" ? "" : ";label:BaseSelectComponent;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx"],"names":[],"mappings":"AA6gBgB","file":"/builds/frontend/libs/ui-kit/src/components/BaseSelect/BaseSelect.tsx","sourcesContent":["import {\n  type FocusEvent,\n  type KeyboardEvent,\n  memo,\n  type MouseEvent,\n  type PropsWithChildren,\n  useCallback,\n  useEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport { getSelectDefaultStyle, getSelectSearchInputWidthStyle } from \"./BaseSelect.styles\";\nimport { useTheme } from \"hooks/useTheme\";\nimport { BarsOutlined, CloseCircleFilled, DownOutlined, SearchOutlined } from \"@infomaximum/icons\";\nimport { isFunction, isNull, isNumber, isUndefined } from \"lodash-es\";\nimport { autoUpdate, flip, offset, useFloating } from \"@floating-ui/react\";\nimport { convertSelectPlacement, getLabel, getVisibleLabels } from \"./BaseSelect.utils\";\nimport { useSearch } from \"./hooks/useSearch\";\nimport { useCurrentValue } from \"./hooks/useCurrentValue\";\nimport { SelectTag } from \"./components/SelectTag/SelectTag\";\nimport { useHideElements } from \"./hooks/useHideElements\";\nimport {\n  TagPlaceholder,\n  tagPlaceholderDataElement,\n} from \"./components/TagPlaceholder/TagPlaceholder\";\nimport type { BaseSelectOptionInterface, BaseSelectProps } from \"./BaseSelect.types\";\nimport { SelectOptionList } from \"./components/SelectOptionList/SelectOptionList\";\nimport { createBaseSelectContext, type BaseSelectContextShape } from \"./contexts/BaseSelectContext\";\n\nconst BaseSelectComponent = <Option extends BaseSelectOptionInterface<OptionValue>, OptionValue>({\n  options = [],\n  mode = \"single\",\n  variant = \"outlined\",\n  defaultValue,\n  defaultOpen = false,\n  defaultActiveFirstOption,\n  value,\n  open,\n  placeholder,\n  dropdownMinWidth = 120,\n  dropdownMaxHeight = 414,\n  allowClear = false,\n  autoFocus,\n  prefix,\n  suffixIcon = <DownOutlined />,\n  status = \"default\",\n  disabled = false,\n  dropdownPrompt,\n  loading = false,\n  dropdownClassName,\n  styles,\n  dropdownMatchSelectWidth = true,\n  placement = \"bottomLeft\",\n  virtual = true,\n  emptyContent = \"\",\n  showSearch = mode === \"single\" ? false : true,\n  searchValue,\n  notFoundContent = \"Not found\",\n  optionLabelProp = \"title\",\n  drawer = false,\n  autoClearSearchValue = true,\n  maxTagCount,\n  maxTagTextLength,\n  maxTagPlaceholder,\n  currentSelectingIndex,\n  getCurrentSelectingValue,\n  onKeyControl,\n  getOptionByValue,\n  virtualizerEstimateSize,\n  filterOptions,\n  filterSort,\n  valuesFilter,\n  dropdownRender,\n  optionRender,\n  labelRender,\n  onBlur,\n  onChange,\n  onClear,\n  onDropdownVisibleChange,\n  onFocus,\n  onInputKeyDown,\n  onSelect,\n  getPopupContainer = () => document.body,\n  onSearch,\n  tagRender,\n  onDeselect,\n  renderDropdownItem,\n  onTagClose,\n}: PropsWithChildren<BaseSelectProps<Option, OptionValue>>) => {\n  const theme = useTheme();\n  const baseSelectContext = createBaseSelectContext<OptionValue>();\n\n  const { filteredAndSortedOptions, searchInputValue, searchHandle, clearSearchValue } = useSearch<\n    Option,\n    OptionValue\n  >({\n    options,\n    searchValue,\n    onSearch,\n    filterSort,\n    filterOptions,\n  });\n\n  const { currentValue, changeCurrentValue, removeValue, clearCurrentValue } = useCurrentValue(\n    mode,\n    defaultValue,\n    defaultActiveFirstOption,\n    options,\n    onDeselect\n  );\n\n  const [isSelectOpen, setIsSelectOpen] = useState(defaultOpen);\n  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 referenceOffsetWidth = controlRef.current?.offsetWidth;\n\n  const { refs, floatingStyles } = useFloating<HTMLSpanElement>({\n    whileElementsMounted: autoUpdate,\n    placement: convertSelectPlacement(placement),\n    middleware: [offset(4), flip()],\n  });\n\n  const returnFocusToWrapper = useCallback(() => {\n    setTimeout(() => {\n      controlRef.current?.focus();\n    });\n  }, []);\n\n  const returnFocusToInput = useCallback(() => {\n    setTimeout(() => {\n      inputRef.current?.focus();\n    });\n  }, []);\n\n  useEffect(() => {\n    if (!isInitialMount.current) {\n      const options = currentValue.reduce((acc: Option[], value) => {\n        const option = getOptionByValue(value);\n\n        if (isUndefined(option)) {\n          return acc;\n        }\n\n        return [...acc, option];\n      }, []);\n\n      onChange?.(currentValue, options);\n    }\n  }, [currentValue, getOptionByValue, onChange]);\n\n  useEffect(() => {\n    if (isInitialMount.current) {\n      isInitialMount.current = false;\n    } else {\n      onDropdownVisibleChange?.();\n    }\n  }, [isSelectOpen, onDropdownVisibleChange]);\n\n  const activeValues = useMemo(() => {\n    return Array.isArray(value) ? value : isUndefined(value) ? currentValue : [value];\n  }, [currentValue, value]);\n\n  const selectDefaultStyle = getSelectDefaultStyle({\n    status,\n    disabled,\n    variant,\n    multiple: mode === \"multiple\",\n    isHover,\n    maxTagCount,\n    withPrefix: !!prefix,\n    isEmpty: activeValues.length === 0,\n  });\n\n  const filteredActiveValues = useMemo(() => {\n    return isFunction(valuesFilter) ? valuesFilter(activeValues) : activeValues;\n  }, [activeValues, valuesFilter]);\n\n  const { containerRef, isItemHidden } = useHideElements(\n    filteredActiveValues,\n    theme.spaceXS,\n    inputRef,\n    maxTagCount\n  );\n\n  const currentLabel = getLabel<Option, OptionValue>(\n    filteredActiveValues,\n    getOptionByValue,\n    optionLabelProp\n  );\n\n  const 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: OptionValue | OptionValue[]) => {\n      changeCurrentValue(value);\n\n      if (Array.isArray(value)) {\n        return;\n      }\n\n      const option = getOptionByValue(value);\n\n      if (withAutoClear) {\n        clearSearchValue();\n      }\n\n      if (option) {\n        onSelect?.(value, option);\n      }\n    },\n    [changeCurrentValue, clearSearchValue, getOptionByValue, onSelect, withAutoClear]\n  );\n\n  const closeOptionList = useCallback(() => {\n    setIsSelectOpen(false);\n  }, []);\n\n  const blurHandle = (e: FocusEvent) => {\n    const isFocusOnOptionList = refs.floating.current?.contains(e.relatedTarget);\n    const isFocusOnSearchInput = !isNull(inputRef.current) && e.relatedTarget === inputRef.current;\n    const isFocusOnControl = e.relatedTarget === controlRef.current;\n\n    if (isFocusOnOptionList || isFocusOnSearchInput || isFocusOnControl) {\n      if (showSearch) {\n        returnFocusToInput();\n      } else {\n        returnFocusToWrapper();\n      }\n\n      return;\n    }\n\n    onBlur?.(e);\n    clearSearchValue();\n    closeOptionList();\n  };\n\n  const clearSelect = useCallback(\n    (e: MouseEvent) => {\n      e.preventDefault();\n      e.stopPropagation();\n\n      clearCurrentValue();\n      onClear?.();\n    },\n    [clearCurrentValue, onClear]\n  );\n\n  const keyDownHandler = (e: KeyboardEvent) => {\n    if (e.key === \"Enter\") {\n      if (isSelectOpen) {\n        const value = getCurrentSelectingValue();\n\n        if (!value) {\n          return;\n        }\n\n        if (currentValue.includes(value)) {\n          removeValue(value);\n        } else {\n          changeCurrentValue(value);\n        }\n\n        if (withAutoClear) {\n          clearSearchValue();\n        }\n      }\n\n      clickHandle();\n    }\n\n    setIsSelectOpen(true);\n\n    onKeyControl(e);\n    onInputKeyDown?.(e);\n  };\n\n  const 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: Option[], value) => {\n      const isHidden = isItemHidden.get(value);\n      const option = getOptionByValue(value);\n\n      if (!isHidden || isUndefined(option)) {\n        return acc;\n      }\n\n      acc.push(option);\n\n      return acc;\n    }, []);\n\n    return (\n      <span data-element={tagPlaceholderDataElement}>{maxTagPlaceholder(hiddenElements)}</span>\n    );\n  };\n\n  const renderLabel = (values: OptionValue[], currentLabel: string[]) => {\n    const visibleLabels = getVisibleLabels(currentLabel, maxTagCount);\n\n    const label = visibleLabels.map((label, index) => {\n      const value = values[index] as OptionValue;\n\n      if (isFunction(labelRender)) {\n        return labelRender({ label, value });\n      }\n\n      if (mode === \"single\") {\n        return label;\n      }\n\n      if (isFunction(tagRender)) {\n        return tagRender(label);\n      }\n\n      const isHidden = !!isItemHidden.get(value);\n\n      return (\n        <SelectTag<OptionValue>\n          value={value}\n          label={label}\n          removeValue={removeValue}\n          maxTagTextLength={maxTagTextLength}\n          isBorderless={variant === \"borderless\"}\n          isError={status === \"error\"}\n          disabled={disabled}\n          isHidden={isHidden}\n          onTagClose={onTagClose}\n          key={value?.toString()}\n        />\n      );\n    });\n\n    const hiddenElementsCounter = isNumber(maxTagCount)\n      ? isItemHidden.size - maxTagCount\n      : Array.from(isItemHidden.values()).reduce((acc, isHidden) => (isHidden ? acc + 1 : acc), 0);\n\n    const withTagPlaceholder =\n      !isUndefined(maxTagCount) && mode === \"multiple\" && hiddenElementsCounter > 0;\n\n    if (label.length === 0) {\n      return null;\n    }\n\n    return (\n      <>\n        {label}\n        {withTagPlaceholder && renderTagPlaceholder(hiddenElementsCounter)}\n      </>\n    );\n  };\n\n  const renderSuffix = () => {\n    if (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 && !!filteredActiveValues.length;\n\n  const inputValue =\n    mode === \"multiple\" || isSelectOpen\n      ? (searchValue ?? searchInputValue)\n      : currentLabel[0]?.toString();\n\n  const isEmpty = filteredActiveValues.length === 0;\n  const singleModPlaceholder = currentLabel[0] ?? placeholder ?? \"\";\n  const multipleModPlaceholder = isEmpty ? placeholder : undefined;\n\n  const searchInputPlaceholder = mode === \"single\" ? singleModPlaceholder : multipleModPlaceholder;\n\n  const lettersNumber = (inputValue?.length ?? 0) + 1;\n\n  const hasIconPrefix = typeof prefix === \"object\";\n\n  const contextValue: BaseSelectContextShape<OptionValue> = {\n    currentValue: activeValues,\n    showOptionList: open ?? isSelectOpen,\n    setValue: changeHandle,\n    closeOptionList,\n    dropdownMinWidth,\n    dropdownMaxHeight,\n    dropdownPrompt,\n    loading,\n    dropdownClassName,\n    dropdownRender,\n    dropdownMatchSelectWidth,\n    referenceOffsetWidth,\n    floatingStyles,\n    setFloating: refs.setFloating,\n    floatingRef: refs.floating,\n    getPopupContainer,\n    virtual,\n    currentSelectingIndex,\n    emptyContent,\n    notFoundContent,\n    searchValue: searchValue ?? searchInputValue,\n    showSearch,\n    mode,\n    removeValue,\n    isItemHidden,\n    getCurrentSelectingValue,\n  };\n\n  return (\n    <baseSelectContext.Provider value={contextValue}>\n      <span\n        css={[selectDefaultStyle.wrapper(theme), styles?.wrapper?.(theme)]}\n        tabIndex={1}\n        onKeyDown={keyDownHandler}\n        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(filteredActiveValues, currentLabel)}\n                <input\n                  css={selectDefaultStyle.searchInput(theme)}\n                  value={inputValue ?? \"\"}\n                  onChange={searchHandle}\n                  placeholder={searchInputPlaceholder?.toString()}\n                  ref={inputRef}\n                  disabled={disabled}\n                  style={getSelectSearchInputWidthStyle(\n                    mode === \"multiple\",\n                    isEmpty,\n                    lettersNumber\n                  )}\n                  data-element=\"search-input\"\n                />\n              </span>\n            ) : (\n              <span\n                ref={containerRef}\n                css={[selectDefaultStyle.content(theme), styles?.content?.(theme)]}\n              >\n                {renderLabel(filteredActiveValues, currentLabel) ?? renderPlaceholder()}\n              </span>\n            )}\n          </span>\n\n          {withClearButton && (\n            <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<Option, OptionValue>\n          options={filteredAndSortedOptions}\n          renderDropdownItem={renderDropdownItem}\n          optionRender={optionRender}\n          virtualizerEstimateSize={virtualizerEstimateSize}\n          styles={styles?.dropdownStyle}\n        />\n      </span>\n    </baseSelectContext.Provider>\n  );\n};\n\nexport const BaseSelect = memo(BaseSelectComponent) as typeof BaseSelectComponent;\n"]} */"], children: renderSuffix() })
353
+ ] }),
354
+ /* @__PURE__ */ jsx(SelectOptionList, { options: filteredAndSortedOptions, renderDropdownItem, optionRender, virtualizerEstimateSize, styles: styles == null ? void 0 : styles.dropdownStyle })
355
+ ] }) });
356
+ };
357
+ const BaseSelect = memo(BaseSelectComponent);
358
+ export {
359
+ BaseSelect
360
+ };