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