@ultraviolet/ui 3.0.0-beta.17 → 3.0.0-beta.19

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 (149) hide show
  1. package/README.md +23 -11
  2. package/dist/components/ActionBar/styles.css.cjs +0 -1
  3. package/dist/components/ActionBar/styles.css.js +0 -1
  4. package/dist/components/Alert/styles.css.cjs +1 -0
  5. package/dist/components/Alert/styles.css.js +1 -0
  6. package/dist/components/Avatar/styles.css.cjs +0 -1
  7. package/dist/components/Avatar/styles.css.js +0 -1
  8. package/dist/components/Avatar/variables.css.cjs +1 -0
  9. package/dist/components/Avatar/variables.css.js +1 -0
  10. package/dist/components/Checkbox/index.cjs +1 -1
  11. package/dist/components/Checkbox/index.js +1 -1
  12. package/dist/components/Chip/index.d.ts +1 -1
  13. package/dist/components/DateInput/components/CalendarContent.cjs +2 -20
  14. package/dist/components/DateInput/components/CalendarContent.js +2 -18
  15. package/dist/components/DateInput/components/CalendarDaily.cjs +3 -43
  16. package/dist/components/DateInput/components/CalendarDaily.js +3 -41
  17. package/dist/components/DateInput/components/CalendarMonthly.cjs +2 -24
  18. package/dist/components/DateInput/components/CalendarMonthly.js +2 -22
  19. package/dist/components/DateInput/components/Popup.cjs +2 -15
  20. package/dist/components/DateInput/components/Popup.js +2 -13
  21. package/dist/components/DateInput/components/styles.css.cjs +12 -0
  22. package/dist/components/DateInput/components/styles.css.d.ts +4 -0
  23. package/dist/components/DateInput/components/styles.css.js +12 -0
  24. package/dist/components/DateInput/helpers.cjs +0 -8
  25. package/dist/components/DateInput/helpers.d.ts +0 -2
  26. package/dist/components/DateInput/helpers.js +1 -9
  27. package/dist/components/DateInput/index.cjs +10 -30
  28. package/dist/components/DateInput/index.js +11 -29
  29. package/dist/components/DateInput/styles.css.cjs +8 -0
  30. package/dist/components/DateInput/styles.css.d.ts +8 -0
  31. package/dist/components/DateInput/styles.css.js +8 -0
  32. package/dist/components/EmptyState/index.cjs +11 -74
  33. package/dist/components/EmptyState/index.d.ts +1 -6
  34. package/dist/components/EmptyState/index.js +8 -69
  35. package/dist/components/EmptyState/styles.css.cjs +10 -0
  36. package/dist/components/EmptyState/styles.css.d.ts +29 -0
  37. package/dist/components/EmptyState/styles.css.js +10 -0
  38. package/dist/components/Popup/helpers.cjs +8 -4
  39. package/dist/components/Popup/helpers.js +8 -4
  40. package/dist/components/Popup/styles.css.cjs +1 -0
  41. package/dist/components/Popup/styles.css.js +1 -0
  42. package/dist/components/Popup/variables.css.cjs +0 -1
  43. package/dist/components/Popup/variables.css.js +0 -1
  44. package/dist/components/ProgressBar/styles.css.cjs +1 -0
  45. package/dist/components/ProgressBar/styles.css.js +1 -0
  46. package/dist/components/ProgressBar/variables.css.cjs +0 -1
  47. package/dist/components/ProgressBar/variables.css.js +0 -1
  48. package/dist/components/SearchInput/KeyGroup.cjs +4 -22
  49. package/dist/components/SearchInput/KeyGroup.js +2 -18
  50. package/dist/components/SearchInput/index.cjs +2 -38
  51. package/dist/components/SearchInput/index.js +3 -37
  52. package/dist/components/SearchInput/styles.css.cjs +10 -0
  53. package/dist/components/SearchInput/styles.css.d.ts +3 -0
  54. package/dist/components/SearchInput/styles.css.js +10 -0
  55. package/dist/components/SelectInput/components/Dropdown.cjs +342 -0
  56. package/dist/components/SelectInput/{Dropdown.d.ts → components/Dropdown.d.ts} +1 -1
  57. package/dist/components/SelectInput/components/Dropdown.js +342 -0
  58. package/dist/components/SelectInput/components/DropdownOption.cjs +47 -0
  59. package/dist/components/SelectInput/{DropdownOption.d.ts → components/DropdownOption.d.ts} +1 -1
  60. package/dist/components/SelectInput/components/DropdownOption.js +47 -0
  61. package/dist/components/SelectInput/components/SearchBarDropdown.cjs +117 -0
  62. package/dist/components/SelectInput/{SearchBarDropdown.d.ts → components/SearchBarDropdown.d.ts} +1 -1
  63. package/dist/components/SelectInput/components/SearchBarDropdown.js +117 -0
  64. package/dist/components/SelectInput/components/SelectBar.cjs +237 -0
  65. package/dist/components/SelectInput/{SelectBar.d.ts → components/SelectBar.d.ts} +1 -12
  66. package/dist/components/SelectInput/components/SelectBar.js +237 -0
  67. package/dist/components/SelectInput/components/dropdown.css.cjs +34 -0
  68. package/dist/components/SelectInput/components/dropdown.css.d.ts +35 -0
  69. package/dist/components/SelectInput/components/dropdown.css.js +34 -0
  70. package/dist/components/SelectInput/components/selectBar.css.cjs +24 -0
  71. package/dist/components/SelectInput/components/selectBar.css.d.ts +108 -0
  72. package/dist/components/SelectInput/components/selectBar.css.js +24 -0
  73. package/dist/components/SelectInput/index.cjs +8 -33
  74. package/dist/components/SelectInput/index.d.ts +2 -2
  75. package/dist/components/SelectInput/index.js +8 -31
  76. package/dist/components/SelectInput/styles.css.cjs +7 -0
  77. package/dist/components/SelectInput/styles.css.d.ts +2 -0
  78. package/dist/components/SelectInput/styles.css.js +7 -0
  79. package/dist/components/SelectableCard/styles.css.cjs +1 -0
  80. package/dist/components/SelectableCard/styles.css.js +1 -0
  81. package/dist/components/SelectableCard/variables.css.cjs +0 -1
  82. package/dist/components/SelectableCard/variables.css.js +0 -1
  83. package/dist/components/SelectableCardOptionGroup/components/Option.cjs +7 -7
  84. package/dist/components/SelectableCardOptionGroup/components/Option.js +7 -7
  85. package/dist/components/Skeleton/index.cjs +3 -2
  86. package/dist/components/Skeleton/index.d.ts +3 -1
  87. package/dist/components/Skeleton/index.js +3 -2
  88. package/dist/components/SwitchButton/FocusOverlay.cjs +2 -18
  89. package/dist/components/SwitchButton/FocusOverlay.js +2 -16
  90. package/dist/components/SwitchButton/Option.cjs +2 -45
  91. package/dist/components/SwitchButton/Option.js +2 -43
  92. package/dist/components/SwitchButton/index.cjs +2 -27
  93. package/dist/components/SwitchButton/index.js +2 -25
  94. package/dist/components/SwitchButton/styles.css.cjs +9 -0
  95. package/dist/components/SwitchButton/styles.css.d.ts +7 -0
  96. package/dist/components/SwitchButton/styles.css.js +9 -0
  97. package/dist/components/Tag/index.cjs +2 -1
  98. package/dist/components/Tag/index.d.ts +3 -2
  99. package/dist/components/Tag/index.js +2 -1
  100. package/dist/components/TagInput/index.cjs +11 -88
  101. package/dist/components/TagInput/index.d.ts +1 -5
  102. package/dist/components/TagInput/index.js +11 -86
  103. package/dist/components/TagInput/styles.css.cjs +12 -0
  104. package/dist/components/TagInput/styles.css.d.ts +21 -0
  105. package/dist/components/TagInput/styles.css.js +12 -0
  106. package/dist/components/TagList/constant.cjs +5 -0
  107. package/dist/components/TagList/constant.d.ts +1 -0
  108. package/dist/components/TagList/constant.js +5 -0
  109. package/dist/components/TagList/index.cjs +21 -66
  110. package/dist/components/TagList/index.js +19 -62
  111. package/dist/components/TagList/styles.css.cjs +14 -0
  112. package/dist/components/TagList/styles.css.d.ts +11 -0
  113. package/dist/components/TagList/styles.css.js +14 -0
  114. package/dist/components/TextInput/constants.d.ts +5 -0
  115. package/dist/components/TextInput/index.cjs +8 -113
  116. package/dist/components/TextInput/index.d.ts +2 -88
  117. package/dist/components/TextInput/index.js +8 -111
  118. package/dist/components/TextInput/styles.css.cjs +17 -0
  119. package/dist/components/TextInput/styles.css.d.ts +8 -0
  120. package/dist/components/TextInput/styles.css.js +17 -0
  121. package/dist/components/TimeInput/constants.cjs +0 -6
  122. package/dist/components/TimeInput/constants.js +0 -6
  123. package/dist/components/TimeInput/index.cjs +16 -96
  124. package/dist/components/TimeInput/index.d.ts +0 -7
  125. package/dist/components/TimeInput/index.js +13 -91
  126. package/dist/components/TimeInput/styles.css.cjs +10 -0
  127. package/dist/components/TimeInput/styles.css.d.ts +82 -0
  128. package/dist/components/TimeInput/styles.css.js +10 -0
  129. package/dist/components/Toggle/index.cjs +10 -108
  130. package/dist/components/Toggle/index.d.ts +0 -18
  131. package/dist/components/Toggle/index.js +13 -109
  132. package/dist/components/Toggle/styles.css.cjs +10 -0
  133. package/dist/components/Toggle/styles.css.d.ts +108 -0
  134. package/dist/components/Toggle/styles.css.js +10 -0
  135. package/dist/components/UnitInput/index.cjs +28 -122
  136. package/dist/components/UnitInput/index.js +24 -116
  137. package/dist/components/UnitInput/styles.css.cjs +17 -0
  138. package/dist/components/UnitInput/styles.css.d.ts +7 -0
  139. package/dist/components/UnitInput/styles.css.js +17 -0
  140. package/dist/ui.css +1 -1
  141. package/package.json +2 -2
  142. package/dist/components/SelectInput/Dropdown.cjs +0 -488
  143. package/dist/components/SelectInput/Dropdown.js +0 -486
  144. package/dist/components/SelectInput/DropdownOption.cjs +0 -91
  145. package/dist/components/SelectInput/DropdownOption.js +0 -89
  146. package/dist/components/SelectInput/SearchBarDropdown.cjs +0 -133
  147. package/dist/components/SelectInput/SearchBarDropdown.js +0 -131
  148. package/dist/components/SelectInput/SelectBar.cjs +0 -366
  149. package/dist/components/SelectInput/SelectBar.js +0 -364
@@ -0,0 +1,342 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
5
+ const react = require("react");
6
+ require("../../../theme/index.cjs");
7
+ const index$4 = require("../../Checkbox/index.cjs");
8
+ const ModalProvider = require("../../Modal/ModalProvider.cjs");
9
+ const index = require("../../Popup/index.cjs");
10
+ const index$3 = require("../../Skeleton/index.cjs");
11
+ const index$1 = require("../../Stack/index.cjs");
12
+ const index$2 = require("../../Text/index.cjs");
13
+ const SelectInputProvider = require("../SelectInputProvider.cjs");
14
+ const types = require("../types.cjs");
15
+ const DropdownOption = require("./DropdownOption.cjs");
16
+ const dropdown_css = require("./dropdown.css.cjs");
17
+ const SearchBarDropdown = require("./SearchBarDropdown.cjs");
18
+ const ThemeProvider = require("../../../theme/ThemeProvider.cjs");
19
+ const DROPDOWN_MAX_HEIGHT = 256;
20
+ const NON_SEARCHABLE_KEYS = ["Tab", " ", "Enter", "CapsLock", "Shift", "ArrowDown", "ArrowUp", "ArrowLeft", "ArrowRight", "Escape"];
21
+ const moveFocusDown = () => {
22
+ const options = document.querySelectorAll('#items > div[role="option"]:not([disabled])');
23
+ const activeItem = document.activeElement;
24
+ if (options) {
25
+ for (let i = 0; i < options?.length; i += 1) {
26
+ const listLength = options.length;
27
+ if (activeItem === options[i] && activeItem !== options[listLength - 1]) {
28
+ options[i + 1].focus();
29
+ }
30
+ }
31
+ }
32
+ };
33
+ const moveFocusUp = () => {
34
+ const options = document.querySelectorAll('#items > div[role="option"]:not([disabled])');
35
+ const activeItem = document.activeElement;
36
+ if (options) {
37
+ for (let i = 0; i < options.length; i += 1) {
38
+ if (activeItem === options[i] && activeItem !== options[0]) {
39
+ options[i - 1].focus();
40
+ }
41
+ }
42
+ }
43
+ };
44
+ const handleKeyDownSelect = (event) => {
45
+ if (event.key === "ArrowDown") {
46
+ event.preventDefault();
47
+ moveFocusDown();
48
+ }
49
+ if (event.key === "ArrowUp") {
50
+ event.preventDefault();
51
+ moveFocusUp();
52
+ }
53
+ if (event.key === " ") {
54
+ event.preventDefault();
55
+ }
56
+ };
57
+ const handleKeyDown = (event, ref, options, searchBarActive, setSearch, setDefaultSearch, search) => {
58
+ if (ref.current && !searchBarActive && !NON_SEARCHABLE_KEYS.includes(event.key) && document.activeElement?.ariaLabel !== "search-bar") {
59
+ const currentSearch = search + event.key;
60
+ setSearch(currentSearch);
61
+ ref.current.focus();
62
+ if (!Array.isArray(options)) {
63
+ const closestOptions = {
64
+ ...options
65
+ };
66
+ Object.keys(closestOptions).map((group) => {
67
+ closestOptions[group] = closestOptions[group].filter((option) => option.searchText ? option.searchText.toLocaleLowerCase().startsWith(currentSearch) : option.value.toLocaleLowerCase().startsWith(currentSearch));
68
+ return null;
69
+ });
70
+ const closestOption = closestOptions[Object.keys(closestOptions)[0]][0];
71
+ if (closestOption) {
72
+ setDefaultSearch(closestOption.searchText ?? closestOption.value);
73
+ } else {
74
+ setDefaultSearch(null);
75
+ }
76
+ } else {
77
+ const closestOption = [...options].find((option) => option.searchText ? option.searchText.toLocaleLowerCase().startsWith(currentSearch) : option.value.toLocaleLowerCase().startsWith(currentSearch));
78
+ if (closestOption) {
79
+ setDefaultSearch(closestOption.searchText ?? closestOption.value);
80
+ } else {
81
+ setDefaultSearch(null);
82
+ }
83
+ }
84
+ }
85
+ };
86
+ const CreateDropdown = ({
87
+ isEmpty,
88
+ emptyState,
89
+ descriptionDirection,
90
+ loadMore,
91
+ optionalInfoPlacement,
92
+ defaultSearchValue,
93
+ isLoading
94
+ }) => {
95
+ const {
96
+ setIsDropdownVisible,
97
+ onChange,
98
+ options,
99
+ multiselect,
100
+ selectAll,
101
+ selectAllGroup,
102
+ displayedOptions,
103
+ setSelectedData,
104
+ selectedData
105
+ } = SelectInputProvider.useSelectInput();
106
+ const focusedItemRef = react.useRef(null);
107
+ react.useEffect(() => {
108
+ if (defaultSearchValue && focusedItemRef?.current) {
109
+ focusedItemRef.current.focus();
110
+ }
111
+ }, [defaultSearchValue]);
112
+ if (isEmpty) {
113
+ return /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { alignItems: "center", className: dropdown_css.dropdownEmptyState, gap: 2, children: emptyState ?? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "p", variant: "bodyStrong", children: "No options" }) });
114
+ }
115
+ const handleClick = (clickedOption, group) => {
116
+ setSelectedData({
117
+ clickedOption,
118
+ group,
119
+ type: "selectOption"
120
+ });
121
+ if (multiselect) {
122
+ if (selectedData.selectedValues.includes(clickedOption.value)) {
123
+ onChange?.(selectedData.selectedValues.filter((val) => val !== clickedOption.value));
124
+ } else {
125
+ onChange?.([...selectedData.selectedValues, clickedOption.value]);
126
+ }
127
+ } else {
128
+ onChange?.(clickedOption.value);
129
+ }
130
+ setIsDropdownVisible(multiselect);
131
+ };
132
+ const selectAllOptions = () => {
133
+ if (multiselect) {
134
+ setSelectedData({
135
+ type: "selectAll"
136
+ });
137
+ if (selectedData.allSelected && onChange) {
138
+ onChange([]);
139
+ } else {
140
+ const allValues = [];
141
+ if (!Array.isArray(options)) {
142
+ Object.keys(options).map((group) => options[group].map((option) => {
143
+ if (!option.disabled) {
144
+ allValues.push(option);
145
+ }
146
+ return null;
147
+ }));
148
+ } else {
149
+ options.map((option) => allValues.push(option));
150
+ }
151
+ onChange?.(allValues.map((value) => value.value));
152
+ }
153
+ }
154
+ };
155
+ const handleSelectGroup = (group) => {
156
+ if (multiselect) {
157
+ setSelectedData({
158
+ selectedGroup: group,
159
+ type: "selectGroup"
160
+ });
161
+ if (!Array.isArray(options)) {
162
+ if (selectedData.selectedGroups.includes(group)) {
163
+ const newSelectedValues = [...selectedData.selectedValues].filter((selectedValue) => !options[group].find((option) => option.value === selectedValue));
164
+ onChange?.(newSelectedValues);
165
+ } else {
166
+ const newSelectedValues = [...selectedData.selectedValues];
167
+ options[group].map((option) => newSelectedValues.includes(option.value) || option.disabled ? null : newSelectedValues.push(option.value));
168
+ onChange?.(newSelectedValues);
169
+ }
170
+ }
171
+ }
172
+ };
173
+ return !Array.isArray(displayedOptions) ? /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { className: dropdown_css.dropdownContainer, "data-grouped": true, id: "select-dropdown", onKeyDown: handleKeyDownSelect, role: "listbox", children: [
174
+ isLoading ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Skeleton, { variant: "block" }) : /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
175
+ selectAll && multiselect ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { id: "items", children: /* @__PURE__ */ jsxRuntime.jsx("div", { "aria-disabled": false, "aria-label": "select-all", "aria-selected": selectedData.allSelected, className: dropdown_css.dropdownItem({
176
+ selected: selectedData.allSelected
177
+ }), "data-testid": "select-all", id: "select-all", onClick: selectAllOptions, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? selectAllOptions() : null, role: "option", tabIndex: 0, children: /* @__PURE__ */ jsxRuntime.jsx(index$4.Checkbox, { checked: selectedData.allSelected, className: dropdown_css.dropdownCheckbox, "data-testid": "select-all-checkbox", disabled: false, onChange: selectAllOptions, tabIndex: -1, value: "select-all", children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "column", children: [
178
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", variant: "body", children: selectAll.label }),
179
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: selectAll.description })
180
+ ] }) }) }) }) : null,
181
+ Object.keys(displayedOptions).map((group, index2) => /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 0.25, children: [
182
+ displayedOptions[group].length > 0 ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: dropdown_css.dropdownGroupWrapper, id: selectAllGroup ? "items" : void 0, children: group ? /* @__PURE__ */ jsxRuntime.jsx("button", { className: `${selectAllGroup ? dropdown_css.dropdownGroupSelectable : ""} ${dropdown_css.dropdownGroup}`, "data-selectgroup": selectAllGroup, "data-testid": `group-${index2}`, onClick: () => selectAllGroup ? handleSelectGroup(group) : null, onKeyDown: (event) => {
183
+ if ([" ", "Enter"].includes(event.key)) {
184
+ event.preventDefault();
185
+ handleSelectGroup(group);
186
+ }
187
+ }, role: "group", tabIndex: selectAllGroup ? 0 : -1, type: "button", children: selectAllGroup ? /* @__PURE__ */ jsxRuntime.jsx(index$4.Checkbox, { checked: selectedData.selectedGroups.includes(group), className: dropdown_css.dropdownCheckbox, "data-testid": "select-group", disabled: false, onChange: () => selectAllGroup ? handleSelectGroup(group) : null, tabIndex: -1, value: group, children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", sentiment: "neutral", variant: "caption", children: group.toUpperCase() }) }) : /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", sentiment: "neutral", variant: "caption", children: group.toUpperCase() }) }, group) : null }) : null,
188
+ /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { gap: "0.25", id: "items", children: displayedOptions[group].map((option, indexOption) => /* @__PURE__ */ jsxRuntime.jsx("div", { "aria-disabled": !!option.disabled, "aria-label": option.value, "aria-selected": selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdown_css.dropdownItem({
189
+ disabled: !!option.disabled,
190
+ selected: selectedData.selectedValues.includes(option.value) && !option.disabled
191
+ }), "data-testid": `option-${option.value}`, id: `option-${indexOption}`, onClick: () => {
192
+ if (!option.disabled) {
193
+ handleClick(option, group);
194
+ }
195
+ }, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? handleClick(option, group) : null, ref: option.value === defaultSearchValue || option.searchText === defaultSearchValue ? focusedItemRef : null, role: "option", tabIndex: !option.disabled ? 0 : -1, children: multiselect ? /* @__PURE__ */ jsxRuntime.jsx(index$4.Checkbox, { checked: selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdown_css.dropdownCheckbox, disabled: option.disabled, onChange: () => {
196
+ if (!option.disabled) {
197
+ handleClick(option, group);
198
+ }
199
+ }, tabIndex: -1, value: option.value, children: /* @__PURE__ */ jsxRuntime.jsx(DropdownOption.DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }) : /* @__PURE__ */ jsxRuntime.jsx(DropdownOption.DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }, option.value)) })
200
+ ] }, group))
201
+ ] }),
202
+ loadMore ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { className: dropdown_css.dropdownLoadMore, children: loadMore }) : null
203
+ ] }) : /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { className: `${dropdown_css.dropdownContainer} ${dropdown_css.dropdownContainerUnGrouped}`, gap: 0.25, id: "select-dropdown", onKeyDown: handleKeyDownSelect, role: "listbox", children: [
204
+ selectAll && multiselect ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { gap: 0.25, id: "items", tabIndex: -1, children: /* @__PURE__ */ jsxRuntime.jsx("div", { "aria-disabled": false, "aria-label": "select-all", "aria-selected": selectedData.allSelected, className: dropdown_css.dropdownItem({
205
+ selected: selectedData.allSelected
206
+ }), "data-testid": "select-all", onClick: selectAllOptions, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? selectAllOptions() : null, role: "option", tabIndex: 0, children: /* @__PURE__ */ jsxRuntime.jsx(index$4.Checkbox, { checked: selectedData.allSelected, className: dropdown_css.dropdownCheckbox, "data-testid": "select-all-checkbox", disabled: false, onChange: selectAllOptions, tabIndex: -1, value: "select-all", children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { direction: "column", children: [
207
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", variant: "body", children: selectAll.label }),
208
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: selectAll.description })
209
+ ] }) }) }) }) : null,
210
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 0.25, id: "items", children: [
211
+ isLoading ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Skeleton, { variant: "block" }) : displayedOptions.map((option, index2) => /* @__PURE__ */ jsxRuntime.jsx("div", { "aria-disabled": !!option.disabled, "aria-label": option.value, "aria-selected": selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdown_css.dropdownItem({
212
+ disabled: !!option.disabled,
213
+ selected: selectedData.selectedValues.includes(option.value) && !option.disabled
214
+ }), "data-testid": `option-${option.value}`, id: `option-${index2}`, onClick: () => {
215
+ if (!option.disabled) {
216
+ handleClick(option);
217
+ }
218
+ }, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? handleClick(option) : null, ref: option.value === defaultSearchValue || option.searchText === defaultSearchValue ? focusedItemRef : null, role: "option", tabIndex: !option.disabled ? 0 : -1, children: multiselect ? /* @__PURE__ */ jsxRuntime.jsx(index$4.Checkbox, { checked: selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdown_css.dropdownCheckbox, disabled: option.disabled, onChange: () => {
219
+ if (!option.disabled) {
220
+ handleClick(option);
221
+ }
222
+ }, tabIndex: -1, value: option.value, children: /* @__PURE__ */ jsxRuntime.jsx(DropdownOption.DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }) : /* @__PURE__ */ jsxRuntime.jsx(DropdownOption.DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }, option.value)),
223
+ loadMore ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { className: dropdown_css.dropdownLoadMore, children: loadMore }) : null
224
+ ] })
225
+ ] });
226
+ };
227
+ const Dropdown = ({
228
+ children,
229
+ emptyState,
230
+ descriptionDirection,
231
+ searchable,
232
+ placeholder,
233
+ footer,
234
+ refSelect,
235
+ loadMore,
236
+ optionalInfoPlacement,
237
+ isLoading,
238
+ size,
239
+ dropdownAlign,
240
+ portalTarget,
241
+ id
242
+ }) => {
243
+ const {
244
+ setIsDropdownVisible,
245
+ isDropdownVisible,
246
+ onSearch,
247
+ searchInput,
248
+ options,
249
+ displayedOptions,
250
+ numberOfOptions
251
+ } = SelectInputProvider.useSelectInput();
252
+ const theme = ThemeProvider.useTheme();
253
+ const [searchBarActive, setSearchBarActive] = react.useState(false);
254
+ const [defaultSearchValue, setDefaultSearch] = react.useState(null);
255
+ const ref = react.useRef(null);
256
+ const [search, setSearch] = react.useState("");
257
+ const [maxWidth, setWidth] = react.useState(refSelect.current?.offsetWidth ?? "100%");
258
+ const modalContext = react.useContext(ModalProvider.ModalContext);
259
+ react.useEffect(() => {
260
+ if (refSelect.current && isDropdownVisible) {
261
+ const position = refSelect.current.getBoundingClientRect().bottom + DROPDOWN_MAX_HEIGHT + Number(theme.sizing[types.INPUT_SIZE_HEIGHT[size]].replace("rem", "")) * 16 + Number.parseInt(theme.space["5"], 10);
262
+ const overflow = position - window.innerHeight + 32;
263
+ if (overflow > 0 && modalContext) {
264
+ const currentModal = modalContext.openedModals[0];
265
+ const modalElement = currentModal?.ref.current;
266
+ if (modalElement) {
267
+ const parentElement = modalElement.parentNode;
268
+ if (parentElement) {
269
+ parentElement.scrollBy({
270
+ behavior: "smooth",
271
+ top: overflow
272
+ });
273
+ }
274
+ } else {
275
+ window.scrollBy({
276
+ behavior: "smooth",
277
+ top: overflow
278
+ });
279
+ }
280
+ }
281
+ }
282
+ }, [isDropdownVisible, refSelect, size, ref.current]);
283
+ const resizeDropdown = react.useCallback(() => {
284
+ if (refSelect.current && refSelect.current.getBoundingClientRect().width > 0) {
285
+ setWidth(refSelect.current.getBoundingClientRect().width);
286
+ }
287
+ }, [refSelect]);
288
+ react.useEffect(() => {
289
+ resizeDropdown();
290
+ window.addEventListener("resize", resizeDropdown);
291
+ return () => window.removeEventListener("resize", resizeDropdown);
292
+ }, [resizeDropdown]);
293
+ react.useEffect(() => {
294
+ if (!searchInput) {
295
+ onSearch(options);
296
+ }
297
+ }, [onSearch, options, searchInput]);
298
+ react.useEffect(() => {
299
+ if (!isDropdownVisible) {
300
+ setDefaultSearch(null);
301
+ setSearch("");
302
+ }
303
+ if (!searchable) {
304
+ document.addEventListener("keydown", (event) => handleKeyDown(event, ref, options, searchBarActive, setSearch, setDefaultSearch, search));
305
+ }
306
+ return () => {
307
+ if (!searchable) {
308
+ document.removeEventListener("keydown", (event) => handleKeyDown(event, ref, options, searchBarActive, setSearch, setDefaultSearch, search));
309
+ }
310
+ };
311
+ }, [isDropdownVisible, searchBarActive, options, onSearch, search, refSelect, setDefaultSearch, setIsDropdownVisible, searchable]);
312
+ const isEmpty = react.useMemo(() => {
313
+ if (numberOfOptions === 0) {
314
+ return true;
315
+ }
316
+ if (Array.isArray(displayedOptions)) {
317
+ return displayedOptions.length === 0;
318
+ }
319
+ const groups = Object.keys(displayedOptions);
320
+ for (const group of groups) {
321
+ if (displayedOptions[group].length > 0) {
322
+ return false;
323
+ }
324
+ }
325
+ return true;
326
+ }, [displayedOptions, numberOfOptions]);
327
+ const computedFooter = react.useMemo(() => {
328
+ if (footer && !isEmpty) {
329
+ if (typeof footer === "function") {
330
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: dropdown_css.footer, children: footer(() => setIsDropdownVisible(false)) });
331
+ }
332
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: dropdown_css.footer, children: footer });
333
+ }
334
+ return null;
335
+ }, [isEmpty, footer, setIsDropdownVisible]);
336
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Popup, { align: dropdownAlign ?? "start", className: dropdown_css.dropdown, containerFullWidth: true, debounceDelay: 0, disableAnimation: true, hasArrow: false, hideOnClickOutside: true, id, maxWidth: maxWidth ?? refSelect.current?.offsetWidth, onClose: () => setIsDropdownVisible(false), placement: "bottom", portalTarget, ref, role: "dialog", tabIndex: -1, text: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { children: [
337
+ searchable && !isLoading && numberOfOptions >= 6 ? /* @__PURE__ */ jsxRuntime.jsx(SearchBarDropdown.SearchBarDropdown, { displayedOptions, placeholder, setSearchBarActive }) : null,
338
+ /* @__PURE__ */ jsxRuntime.jsx(CreateDropdown, { defaultSearchValue, descriptionDirection, emptyState, isEmpty, isLoading, loadMore, optionalInfoPlacement }),
339
+ computedFooter
340
+ ] }), visible: isDropdownVisible, children });
341
+ };
342
+ exports.Dropdown = Dropdown;
@@ -1,5 +1,5 @@
1
1
  import type { ComponentProps, ReactNode, RefObject } from 'react';
2
- import { Popup } from '../Popup';
2
+ import { Popup } from '../../Popup';
3
3
  export type DropdownProps = {
4
4
  id?: string;
5
5
  children: ReactNode;