@ultraviolet/ui 3.0.0-beta.2 → 3.0.0-beta.21

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 (554) hide show
  1. package/README.md +23 -11
  2. package/dist/components/ActionBar/index.cjs +5 -30
  3. package/dist/components/ActionBar/index.js +5 -28
  4. package/dist/components/ActionBar/styles.css.cjs +11 -0
  5. package/dist/components/ActionBar/styles.css.d.ts +3 -0
  6. package/dist/components/ActionBar/styles.css.js +11 -0
  7. package/dist/components/Alert/index.cjs +8 -76
  8. package/dist/components/Alert/index.d.ts +1 -2
  9. package/dist/components/Alert/index.js +8 -74
  10. package/dist/components/Alert/styles.css.cjs +14 -0
  11. package/dist/components/Alert/styles.css.d.ts +35 -0
  12. package/dist/components/Alert/styles.css.js +14 -0
  13. package/dist/components/Alert/type.d.ts +2 -0
  14. package/dist/components/Avatar/constants.cjs +0 -9
  15. package/dist/components/Avatar/constants.js +0 -9
  16. package/dist/components/Avatar/index.cjs +42 -117
  17. package/dist/components/Avatar/index.js +43 -116
  18. package/dist/components/Avatar/styles.css.cjs +16 -0
  19. package/dist/components/Avatar/styles.css.d.ts +128 -0
  20. package/dist/components/Avatar/styles.css.js +16 -0
  21. package/dist/components/Avatar/variables.css.cjs +9 -0
  22. package/dist/components/Avatar/variables.css.d.ts +3 -0
  23. package/dist/components/Avatar/variables.css.js +9 -0
  24. package/dist/components/Badge/constant.cjs +8 -0
  25. package/dist/components/Badge/constant.d.ts +14 -0
  26. package/dist/components/Badge/constant.js +8 -0
  27. package/dist/components/Badge/index.cjs +10 -88
  28. package/dist/components/Badge/index.d.ts +2 -20
  29. package/dist/components/Badge/index.js +8 -84
  30. package/dist/components/Badge/styles.css.cjs +6 -0
  31. package/dist/components/Badge/styles.css.d.ts +43 -0
  32. package/dist/components/Badge/styles.css.js +6 -0
  33. package/dist/components/Banner/index.cjs +12 -69
  34. package/dist/components/Banner/index.d.ts +3 -5
  35. package/dist/components/Banner/index.js +8 -63
  36. package/dist/components/Banner/styles.css.cjs +10 -0
  37. package/dist/components/Banner/styles.css.d.ts +18 -0
  38. package/dist/components/Banner/styles.css.js +10 -0
  39. package/dist/components/BarChart/Tooltip.cjs +6 -37
  40. package/dist/components/BarChart/Tooltip.js +6 -35
  41. package/dist/components/BarChart/index.cjs +4 -4
  42. package/dist/components/BarChart/index.js +1 -1
  43. package/dist/components/BarChart/styles.css.cjs +9 -0
  44. package/dist/components/BarChart/styles.css.d.ts +3 -0
  45. package/dist/components/BarChart/styles.css.js +9 -0
  46. package/dist/components/BarStack/index.cjs +7 -96
  47. package/dist/components/BarStack/index.d.ts +2 -1
  48. package/dist/components/BarStack/index.js +7 -94
  49. package/dist/components/BarStack/styles.css.cjs +11 -0
  50. package/dist/components/BarStack/styles.css.d.ts +4 -0
  51. package/dist/components/BarStack/styles.css.js +11 -0
  52. package/dist/components/Breadcrumbs/components/Item.cjs +25 -42
  53. package/dist/components/Breadcrumbs/components/Item.d.ts +3 -2
  54. package/dist/components/Breadcrumbs/components/Item.js +25 -40
  55. package/dist/components/Breadcrumbs/components/styles.css.cjs +16 -0
  56. package/dist/components/Breadcrumbs/components/styles.css.d.ts +12 -0
  57. package/dist/components/Breadcrumbs/components/styles.css.js +16 -0
  58. package/dist/components/Breadcrumbs/index.cjs +2 -19
  59. package/dist/components/Breadcrumbs/index.js +2 -17
  60. package/dist/components/Breadcrumbs/styles.css.cjs +5 -0
  61. package/dist/components/Breadcrumbs/styles.css.d.ts +1 -0
  62. package/dist/components/Breadcrumbs/styles.css.js +5 -0
  63. package/dist/components/Bullet/constants.d.ts +10 -0
  64. package/dist/components/Bullet/index.cjs +9 -75
  65. package/dist/components/Bullet/index.d.ts +5 -14
  66. package/dist/components/Bullet/index.js +10 -74
  67. package/dist/components/Bullet/styles.css.cjs +6 -0
  68. package/dist/components/Bullet/styles.css.d.ts +23 -0
  69. package/dist/components/Bullet/styles.css.js +6 -0
  70. package/dist/components/Button/constants.cjs +0 -1
  71. package/dist/components/Button/constants.js +0 -1
  72. package/dist/components/Button/index.cjs +7 -6
  73. package/dist/components/Button/index.d.ts +4 -3
  74. package/dist/components/Button/index.js +6 -5
  75. package/dist/components/Button/styles.css.cjs +0 -2
  76. package/dist/components/Button/styles.css.d.ts +4 -4
  77. package/dist/components/Button/styles.css.js +0 -2
  78. package/dist/components/Card/index.cjs +9 -43
  79. package/dist/components/Card/index.js +4 -36
  80. package/dist/components/Card/styles.css.cjs +7 -0
  81. package/dist/components/Card/styles.css.d.ts +2 -0
  82. package/dist/components/Card/styles.css.js +7 -0
  83. package/dist/components/Carousel/index.cjs +9 -64
  84. package/dist/components/Carousel/index.js +9 -62
  85. package/dist/components/Carousel/styles.css.cjs +15 -0
  86. package/dist/components/Carousel/styles.css.d.ts +6 -0
  87. package/dist/components/Carousel/styles.css.js +15 -0
  88. package/dist/components/Checkbox/index.cjs +9 -207
  89. package/dist/components/Checkbox/index.d.ts +0 -20
  90. package/dist/components/Checkbox/index.js +9 -205
  91. package/dist/components/Checkbox/styles.css.cjs +17 -0
  92. package/dist/components/Checkbox/styles.css.d.ts +7 -0
  93. package/dist/components/Checkbox/styles.css.js +17 -0
  94. package/dist/components/CheckboxGroup/index.cjs +3 -34
  95. package/dist/components/CheckboxGroup/index.js +3 -32
  96. package/dist/components/CheckboxGroup/styles.css.cjs +7 -0
  97. package/dist/components/CheckboxGroup/styles.css.d.ts +2 -0
  98. package/dist/components/CheckboxGroup/styles.css.js +7 -0
  99. package/dist/components/Chip/ChipContext.d.ts +1 -1
  100. package/dist/components/Chip/ChipIcon.cjs +10 -21
  101. package/dist/components/Chip/ChipIcon.js +10 -19
  102. package/dist/components/Chip/index.cjs +2 -56
  103. package/dist/components/Chip/index.d.ts +1 -1
  104. package/dist/components/Chip/index.js +2 -54
  105. package/dist/components/Chip/styles.css.cjs +7 -0
  106. package/dist/components/Chip/styles.css.d.ts +2 -0
  107. package/dist/components/Chip/styles.css.js +7 -0
  108. package/dist/components/DateInput/components/CalendarContent.cjs +2 -20
  109. package/dist/components/DateInput/components/CalendarContent.js +2 -18
  110. package/dist/components/DateInput/components/CalendarDaily.cjs +3 -43
  111. package/dist/components/DateInput/components/CalendarDaily.js +3 -41
  112. package/dist/components/DateInput/components/CalendarMonthly.cjs +2 -24
  113. package/dist/components/DateInput/components/CalendarMonthly.js +2 -22
  114. package/dist/components/DateInput/components/Popup.cjs +2 -15
  115. package/dist/components/DateInput/components/Popup.js +2 -13
  116. package/dist/components/DateInput/components/styles.css.cjs +12 -0
  117. package/dist/components/DateInput/components/styles.css.d.ts +4 -0
  118. package/dist/components/DateInput/components/styles.css.js +12 -0
  119. package/dist/components/DateInput/helpers.cjs +0 -8
  120. package/dist/components/DateInput/helpers.d.ts +0 -2
  121. package/dist/components/DateInput/helpers.js +1 -9
  122. package/dist/components/DateInput/index.cjs +10 -30
  123. package/dist/components/DateInput/index.js +11 -29
  124. package/dist/components/DateInput/styles.css.cjs +8 -0
  125. package/dist/components/DateInput/styles.css.d.ts +8 -0
  126. package/dist/components/DateInput/styles.css.js +8 -0
  127. package/dist/components/Dialog/constants.d.ts +1 -1
  128. package/dist/components/Dialog/index.cjs +2 -2
  129. package/dist/components/Dialog/index.d.ts +4 -3
  130. package/dist/components/Dialog/index.js +2 -2
  131. package/dist/components/Drawer/index.cjs +14 -100
  132. package/dist/components/Drawer/index.d.ts +9 -16
  133. package/dist/components/Drawer/index.js +11 -95
  134. package/dist/components/Drawer/styles.css.cjs +17 -0
  135. package/dist/components/Drawer/styles.css.d.ts +12 -0
  136. package/dist/components/Drawer/styles.css.js +17 -0
  137. package/dist/components/EmptyState/index.cjs +11 -74
  138. package/dist/components/EmptyState/index.d.ts +1 -6
  139. package/dist/components/EmptyState/index.js +8 -69
  140. package/dist/components/EmptyState/styles.css.cjs +10 -0
  141. package/dist/components/EmptyState/styles.css.d.ts +29 -0
  142. package/dist/components/EmptyState/styles.css.js +10 -0
  143. package/dist/components/Expandable/index.cjs +5 -17
  144. package/dist/components/Expandable/index.d.ts +0 -6
  145. package/dist/components/Expandable/index.js +6 -16
  146. package/dist/components/Expandable/styles.css.cjs +7 -0
  147. package/dist/components/Expandable/styles.css.d.ts +2 -0
  148. package/dist/components/Expandable/styles.css.js +7 -0
  149. package/dist/components/ExpandableCard/index.cjs +17 -100
  150. package/dist/components/ExpandableCard/index.d.ts +3 -1
  151. package/dist/components/ExpandableCard/index.js +12 -93
  152. package/dist/components/ExpandableCard/styles.css.cjs +17 -0
  153. package/dist/components/ExpandableCard/styles.css.d.ts +7 -0
  154. package/dist/components/ExpandableCard/styles.css.js +17 -0
  155. package/dist/components/GlobalAlert/GlobalAlertLink.cjs +2 -2
  156. package/dist/components/GlobalAlert/GlobalAlertLink.js +1 -1
  157. package/dist/components/GlobalAlert/index.cjs +3 -30
  158. package/dist/components/GlobalAlert/index.js +3 -28
  159. package/dist/components/GlobalAlert/styles.css.cjs +7 -0
  160. package/dist/components/GlobalAlert/styles.css.d.ts +2 -0
  161. package/dist/components/GlobalAlert/styles.css.js +7 -0
  162. package/dist/components/Key/index.cjs +85 -0
  163. package/dist/components/Key/index.d.ts +23 -0
  164. package/dist/components/Key/index.js +83 -0
  165. package/dist/components/Label/index.cjs +20 -24
  166. package/dist/components/Label/index.js +20 -22
  167. package/dist/components/Label/styles.css.cjs +5 -0
  168. package/dist/components/Label/styles.css.d.ts +1 -0
  169. package/dist/components/Label/styles.css.js +5 -0
  170. package/dist/components/LineChart/CustomLegend.cjs +9 -61
  171. package/dist/components/LineChart/CustomLegend.js +9 -59
  172. package/dist/components/LineChart/Tooltip.cjs +6 -35
  173. package/dist/components/LineChart/Tooltip.js +6 -33
  174. package/dist/components/LineChart/index.cjs +5 -5
  175. package/dist/components/LineChart/index.js +1 -1
  176. package/dist/components/LineChart/styles.css.cjs +17 -0
  177. package/dist/components/LineChart/styles.css.d.ts +7 -0
  178. package/dist/components/LineChart/styles.css.js +17 -0
  179. package/dist/components/Link/constants.d.ts +6 -0
  180. package/dist/components/Link/index.cjs +11 -114
  181. package/dist/components/Link/index.d.ts +1 -6
  182. package/dist/components/Link/index.js +12 -113
  183. package/dist/components/Link/styles.css.cjs +14 -0
  184. package/dist/components/Link/styles.css.d.ts +78 -0
  185. package/dist/components/Link/styles.css.js +14 -0
  186. package/dist/components/List/index.cjs +2 -2
  187. package/dist/components/List/index.d.ts +1 -1
  188. package/dist/components/List/index.js +2 -2
  189. package/dist/components/Loader/index.cjs +4 -36
  190. package/dist/components/Loader/index.d.ts +0 -4
  191. package/dist/components/Loader/index.js +5 -35
  192. package/dist/components/Loader/styles.css.cjs +7 -0
  193. package/dist/components/Loader/styles.css.d.ts +2 -0
  194. package/dist/components/Loader/styles.css.js +7 -0
  195. package/dist/components/Menu/index.d.ts +1 -1
  196. package/dist/components/Meter/index.cjs +6 -37
  197. package/dist/components/Meter/index.js +6 -35
  198. package/dist/components/Meter/styles.css.cjs +11 -0
  199. package/dist/components/Meter/styles.css.d.ts +4 -0
  200. package/dist/components/Meter/styles.css.js +11 -0
  201. package/dist/components/Modal/ModalContent.cjs +2 -14
  202. package/dist/components/Modal/ModalContent.js +2 -12
  203. package/dist/components/Modal/components/Dialog.cjs +18 -82
  204. package/dist/components/Modal/components/Dialog.d.ts +1 -13
  205. package/dist/components/Modal/components/Dialog.js +19 -81
  206. package/dist/components/Modal/constants.d.ts +42 -2
  207. package/dist/components/Modal/styles.css.cjs +21 -0
  208. package/dist/components/Modal/styles.css.d.ts +78 -0
  209. package/dist/components/Modal/styles.css.js +21 -0
  210. package/dist/components/Notice/index.cjs +2 -12
  211. package/dist/components/Notice/index.js +2 -10
  212. package/dist/components/Notice/styles.css.cjs +5 -0
  213. package/dist/components/Notice/styles.css.d.ts +1 -0
  214. package/dist/components/Notice/styles.css.js +5 -0
  215. package/dist/components/Notification/index.cjs +2 -19
  216. package/dist/components/Notification/index.js +3 -20
  217. package/dist/components/Notification/styles.css.cjs +5 -0
  218. package/dist/components/Notification/styles.css.d.ts +1 -0
  219. package/dist/components/Notification/styles.css.js +5 -0
  220. package/dist/components/NumberInput/constant.d.ts +5 -0
  221. package/dist/components/NumberInput/index.cjs +43 -157
  222. package/dist/components/NumberInput/index.d.ts +2 -6
  223. package/dist/components/NumberInput/index.js +42 -154
  224. package/dist/components/NumberInput/styles.css.cjs +14 -0
  225. package/dist/components/NumberInput/styles.css.d.ts +109 -0
  226. package/dist/components/NumberInput/styles.css.js +14 -0
  227. package/dist/components/Pagination/PaginationButtons.cjs +4 -41
  228. package/dist/components/Pagination/PaginationButtons.js +4 -39
  229. package/dist/components/Pagination/PerPage.cjs +3 -20
  230. package/dist/components/Pagination/PerPage.js +3 -18
  231. package/dist/components/Pagination/styles.css.cjs +9 -0
  232. package/dist/components/Pagination/styles.css.d.ts +3 -0
  233. package/dist/components/Pagination/styles.css.js +9 -0
  234. package/dist/components/PasswordCheck/index.cjs +2 -12
  235. package/dist/components/PasswordCheck/index.js +2 -10
  236. package/dist/components/PasswordCheck/styles.css.cjs +5 -0
  237. package/dist/components/PasswordCheck/styles.css.d.ts +1 -0
  238. package/dist/components/PasswordCheck/styles.css.js +5 -0
  239. package/dist/components/PieChart/Legends.cjs +20 -124
  240. package/dist/components/PieChart/Legends.js +20 -122
  241. package/dist/components/PieChart/Tooltip.cjs +4 -35
  242. package/dist/components/PieChart/Tooltip.js +4 -33
  243. package/dist/components/PieChart/index.cjs +13 -36
  244. package/dist/components/PieChart/index.js +8 -29
  245. package/dist/components/PieChart/styles.css.cjs +36 -0
  246. package/dist/components/PieChart/styles.css.d.ts +49 -0
  247. package/dist/components/PieChart/styles.css.js +36 -0
  248. package/dist/components/Popover/constant.d.ts +5 -0
  249. package/dist/components/Popover/index.cjs +6 -41
  250. package/dist/components/Popover/index.d.ts +1 -5
  251. package/dist/components/Popover/index.js +6 -39
  252. package/dist/components/Popover/styles.css.cjs +8 -0
  253. package/dist/components/Popover/styles.css.d.ts +35 -0
  254. package/dist/components/Popover/styles.css.js +8 -0
  255. package/dist/components/Popup/helpers.cjs +8 -4
  256. package/dist/components/Popup/helpers.js +8 -4
  257. package/dist/components/Popup/index.cjs +25 -62
  258. package/dist/components/Popup/index.d.ts +9 -4
  259. package/dist/components/Popup/index.js +27 -62
  260. package/dist/components/Popup/styles.css.cjs +13 -0
  261. package/dist/components/Popup/styles.css.d.ts +45 -0
  262. package/dist/components/Popup/styles.css.js +13 -0
  263. package/dist/components/Popup/variables.css.cjs +18 -0
  264. package/dist/components/Popup/variables.css.d.ts +9 -0
  265. package/dist/components/Popup/variables.css.js +18 -0
  266. package/dist/components/ProgressBar/constants.d.ts +1 -0
  267. package/dist/components/ProgressBar/index.cjs +7 -77
  268. package/dist/components/ProgressBar/index.d.ts +2 -2
  269. package/dist/components/ProgressBar/index.js +7 -75
  270. package/dist/components/ProgressBar/styles.css.cjs +12 -0
  271. package/dist/components/ProgressBar/styles.css.d.ts +4 -0
  272. package/dist/components/ProgressBar/styles.css.js +12 -0
  273. package/dist/components/{Breadcrumbs/constants.cjs → ProgressBar/variables.css.cjs} +2 -2
  274. package/dist/components/ProgressBar/variables.css.d.ts +1 -0
  275. package/dist/components/ProgressBar/variables.css.js +4 -0
  276. package/dist/components/Radio/index.cjs +30 -136
  277. package/dist/components/Radio/index.d.ts +0 -32
  278. package/dist/components/Radio/index.js +31 -135
  279. package/dist/components/Radio/styles.css.cjs +21 -0
  280. package/dist/components/Radio/styles.css.d.ts +9 -0
  281. package/dist/components/Radio/styles.css.js +21 -0
  282. package/dist/components/RadioGroup/index.cjs +2 -20
  283. package/dist/components/RadioGroup/index.js +2 -18
  284. package/dist/components/RadioGroup/styles.css.cjs +5 -0
  285. package/dist/components/RadioGroup/styles.css.d.ts +1 -0
  286. package/dist/components/RadioGroup/styles.css.js +5 -0
  287. package/dist/components/Row/index.cjs +28 -38
  288. package/dist/components/Row/index.d.ts +8 -10
  289. package/dist/components/Row/index.js +29 -37
  290. package/dist/components/Row/styles.css.cjs +17 -0
  291. package/dist/components/Row/styles.css.d.ts +460 -0
  292. package/dist/components/Row/styles.css.js +17 -0
  293. package/dist/components/Row/variables.css.cjs +7 -0
  294. package/dist/components/Row/variables.css.d.ts +4 -0
  295. package/dist/components/Row/variables.css.js +7 -0
  296. package/dist/components/SearchInput/KeyGroup.cjs +3 -21
  297. package/dist/components/SearchInput/KeyGroup.d.ts +1 -1
  298. package/dist/components/SearchInput/KeyGroup.js +3 -19
  299. package/dist/components/SearchInput/index.cjs +2 -38
  300. package/dist/components/SearchInput/index.js +3 -37
  301. package/dist/components/SearchInput/styles.css.cjs +10 -0
  302. package/dist/components/SearchInput/styles.css.d.ts +3 -0
  303. package/dist/components/SearchInput/styles.css.js +10 -0
  304. package/dist/components/SelectInput/components/Dropdown.cjs +341 -0
  305. package/dist/components/SelectInput/{Dropdown.d.ts → components/Dropdown.d.ts} +1 -1
  306. package/dist/components/SelectInput/components/Dropdown.js +341 -0
  307. package/dist/components/SelectInput/components/DropdownOption.cjs +47 -0
  308. package/dist/components/SelectInput/{DropdownOption.d.ts → components/DropdownOption.d.ts} +1 -1
  309. package/dist/components/SelectInput/components/DropdownOption.js +47 -0
  310. package/dist/components/SelectInput/components/SearchBarDropdown.cjs +117 -0
  311. package/dist/components/SelectInput/{SearchBarDropdown.d.ts → components/SearchBarDropdown.d.ts} +1 -1
  312. package/dist/components/SelectInput/components/SearchBarDropdown.js +117 -0
  313. package/dist/components/SelectInput/components/SelectBar.cjs +237 -0
  314. package/dist/components/SelectInput/{SelectBar.d.ts → components/SelectBar.d.ts} +1 -12
  315. package/dist/components/SelectInput/components/SelectBar.js +237 -0
  316. package/dist/components/SelectInput/components/dropdown.css.cjs +34 -0
  317. package/dist/components/SelectInput/components/dropdown.css.d.ts +35 -0
  318. package/dist/components/SelectInput/components/dropdown.css.js +34 -0
  319. package/dist/components/SelectInput/components/selectBar.css.cjs +24 -0
  320. package/dist/components/SelectInput/components/selectBar.css.d.ts +108 -0
  321. package/dist/components/SelectInput/components/selectBar.css.js +24 -0
  322. package/dist/components/SelectInput/index.cjs +8 -33
  323. package/dist/components/SelectInput/index.d.ts +2 -2
  324. package/dist/components/SelectInput/index.js +8 -31
  325. package/dist/components/SelectInput/styles.css.cjs +7 -0
  326. package/dist/components/SelectInput/styles.css.d.ts +2 -0
  327. package/dist/components/SelectInput/styles.css.js +7 -0
  328. package/dist/components/SelectableCard/index.cjs +21 -182
  329. package/dist/components/SelectableCard/index.js +22 -181
  330. package/dist/components/SelectableCard/styles.css.cjs +21 -0
  331. package/dist/components/SelectableCard/styles.css.d.ts +26 -0
  332. package/dist/components/SelectableCard/styles.css.js +21 -0
  333. package/dist/components/SelectableCard/variables.css.cjs +8 -0
  334. package/dist/components/SelectableCard/variables.css.d.ts +3 -0
  335. package/dist/components/SelectableCard/variables.css.js +8 -0
  336. package/dist/components/SelectableCardOptionGroup/components/Option.cjs +11 -11
  337. package/dist/components/SelectableCardOptionGroup/components/Option.js +9 -9
  338. package/dist/components/Separator/index.cjs +26 -39
  339. package/dist/components/Separator/index.d.ts +2 -5
  340. package/dist/components/Separator/index.js +26 -37
  341. package/dist/components/Separator/styles.css.cjs +10 -0
  342. package/dist/components/Separator/styles.css.d.ts +125 -0
  343. package/dist/components/Separator/styles.css.js +10 -0
  344. package/dist/components/Skeleton/Block.cjs +3 -27
  345. package/dist/components/Skeleton/Block.js +3 -25
  346. package/dist/components/Skeleton/Blocks.cjs +6 -27
  347. package/dist/components/Skeleton/Blocks.js +6 -25
  348. package/dist/components/Skeleton/BoxWithIcon.cjs +6 -25
  349. package/dist/components/Skeleton/BoxWithIcon.js +6 -23
  350. package/dist/components/Skeleton/Donut.cjs +4 -45
  351. package/dist/components/Skeleton/Donut.js +4 -43
  352. package/dist/components/Skeleton/IconSkeleton.cjs +3 -21
  353. package/dist/components/Skeleton/IconSkeleton.d.ts +1 -4
  354. package/dist/components/Skeleton/IconSkeleton.js +3 -19
  355. package/dist/components/Skeleton/Line.cjs +6 -15
  356. package/dist/components/Skeleton/Line.d.ts +1 -4
  357. package/dist/components/Skeleton/Line.js +6 -13
  358. package/dist/components/Skeleton/List.cjs +4 -42
  359. package/dist/components/Skeleton/List.js +4 -40
  360. package/dist/components/Skeleton/Slider.cjs +6 -35
  361. package/dist/components/Skeleton/Slider.js +6 -33
  362. package/dist/components/Skeleton/Square.cjs +3 -11
  363. package/dist/components/Skeleton/Square.d.ts +1 -4
  364. package/dist/components/Skeleton/Square.js +3 -9
  365. package/dist/components/Skeleton/index.cjs +5 -47
  366. package/dist/components/Skeleton/index.d.ts +5 -9
  367. package/dist/components/Skeleton/index.js +5 -45
  368. package/dist/components/Skeleton/styles.css.cjs +7 -0
  369. package/dist/components/Skeleton/styles.css.d.ts +2 -0
  370. package/dist/components/Skeleton/styles.css.js +7 -0
  371. package/dist/components/Skeleton/stylesVariants.css.cjs +47 -0
  372. package/dist/components/Skeleton/stylesVariants.css.d.ts +22 -0
  373. package/dist/components/Skeleton/stylesVariants.css.js +47 -0
  374. package/dist/components/Slider/components/DoubleSlider.cjs +20 -20
  375. package/dist/components/Slider/components/DoubleSlider.js +6 -6
  376. package/dist/components/Slider/components/SingleSlider.cjs +5 -5
  377. package/dist/components/Slider/components/SingleSlider.js +4 -4
  378. package/dist/components/Slider/styles.d.ts +30 -13
  379. package/dist/components/Snippet/index.cjs +22 -155
  380. package/dist/components/Snippet/index.js +18 -149
  381. package/dist/components/Snippet/styles.css.cjs +26 -0
  382. package/dist/components/Snippet/styles.css.d.ts +48 -0
  383. package/dist/components/Snippet/styles.css.js +26 -0
  384. package/dist/components/Stack/index.cjs +69 -44
  385. package/dist/components/Stack/index.d.ts +17 -19
  386. package/dist/components/Stack/index.js +69 -42
  387. package/dist/components/Stack/styles.css.cjs +19 -0
  388. package/dist/components/Stack/styles.css.d.ts +470 -0
  389. package/dist/components/Stack/styles.css.js +19 -0
  390. package/dist/components/Stack/types.d.ts +8 -0
  391. package/dist/components/Stack/variables.css.cjs +11 -0
  392. package/dist/components/Stack/variables.css.d.ts +4 -0
  393. package/dist/components/Stack/variables.css.js +11 -0
  394. package/dist/components/Status/constant.d.ts +1 -0
  395. package/dist/components/Status/index.cjs +10 -66
  396. package/dist/components/Status/index.d.ts +2 -20
  397. package/dist/components/Status/index.js +10 -64
  398. package/dist/components/Status/styles.css.cjs +11 -0
  399. package/dist/components/Status/styles.css.d.ts +23 -0
  400. package/dist/components/Status/styles.css.js +11 -0
  401. package/dist/components/StepList/index.cjs +10 -42
  402. package/dist/components/StepList/index.d.ts +2 -1
  403. package/dist/components/StepList/index.js +10 -40
  404. package/dist/components/StepList/styles.css.cjs +10 -0
  405. package/dist/components/StepList/styles.css.d.ts +23 -0
  406. package/dist/components/StepList/styles.css.js +10 -0
  407. package/dist/components/Stepper/Step.cjs +43 -113
  408. package/dist/components/Stepper/Step.js +41 -109
  409. package/dist/components/Stepper/index.cjs +10 -65
  410. package/dist/components/Stepper/index.js +10 -63
  411. package/dist/components/Stepper/styles.css.cjs +20 -0
  412. package/dist/components/Stepper/styles.css.d.ts +122 -0
  413. package/dist/components/Stepper/styles.css.js +20 -0
  414. package/dist/components/SwitchButton/FocusOverlay.cjs +2 -18
  415. package/dist/components/SwitchButton/FocusOverlay.js +2 -16
  416. package/dist/components/SwitchButton/Option.cjs +2 -45
  417. package/dist/components/SwitchButton/Option.js +2 -43
  418. package/dist/components/SwitchButton/index.cjs +2 -27
  419. package/dist/components/SwitchButton/index.js +2 -25
  420. package/dist/components/SwitchButton/styles.css.cjs +9 -0
  421. package/dist/components/SwitchButton/styles.css.d.ts +7 -0
  422. package/dist/components/SwitchButton/styles.css.js +9 -0
  423. package/dist/components/Table/HeaderRow.cjs +2 -2
  424. package/dist/components/Table/HeaderRow.js +1 -1
  425. package/dist/components/Table/Row.cjs +6 -6
  426. package/dist/components/Table/Row.js +6 -6
  427. package/dist/components/Table/index.cjs +4 -4
  428. package/dist/components/Table/index.d.ts +1 -1
  429. package/dist/components/Table/index.js +3 -3
  430. package/dist/components/Tabs/TabMenuItem.d.ts +1 -1
  431. package/dist/components/Tabs/index.d.ts +2 -2
  432. package/dist/components/Tag/index.cjs +17 -104
  433. package/dist/components/Tag/index.d.ts +5 -4
  434. package/dist/components/Tag/index.js +13 -99
  435. package/dist/components/Tag/styles.css.cjs +10 -0
  436. package/dist/components/Tag/styles.css.d.ts +34 -0
  437. package/dist/components/Tag/styles.css.js +10 -0
  438. package/dist/components/TagInput/index.cjs +11 -88
  439. package/dist/components/TagInput/index.d.ts +1 -5
  440. package/dist/components/TagInput/index.js +11 -86
  441. package/dist/components/TagInput/styles.css.cjs +12 -0
  442. package/dist/components/TagInput/styles.css.d.ts +21 -0
  443. package/dist/components/TagInput/styles.css.js +12 -0
  444. package/dist/components/TagList/constant.cjs +5 -0
  445. package/dist/components/TagList/constant.d.ts +1 -0
  446. package/dist/components/TagList/constant.js +5 -0
  447. package/dist/components/TagList/index.cjs +21 -66
  448. package/dist/components/TagList/index.js +19 -62
  449. package/dist/components/TagList/styles.css.cjs +14 -0
  450. package/dist/components/TagList/styles.css.d.ts +11 -0
  451. package/dist/components/TagList/styles.css.js +14 -0
  452. package/dist/components/Text/constant.d.ts +6 -0
  453. package/dist/components/Text/index.cjs +22 -60
  454. package/dist/components/Text/index.d.ts +3 -7
  455. package/dist/components/Text/index.js +22 -58
  456. package/dist/components/Text/style.css.cjs +6 -0
  457. package/dist/components/Text/style.css.d.ts +52 -0
  458. package/dist/components/Text/style.css.js +6 -0
  459. package/dist/components/Text/variables.css.cjs +7 -0
  460. package/dist/components/Text/variables.css.d.ts +2 -0
  461. package/dist/components/Text/variables.css.js +7 -0
  462. package/dist/components/TextArea/index.cjs +34 -99
  463. package/dist/components/TextArea/index.js +34 -97
  464. package/dist/components/TextArea/styles.css.cjs +12 -0
  465. package/dist/components/TextArea/styles.css.d.ts +15 -0
  466. package/dist/components/TextArea/styles.css.js +12 -0
  467. package/dist/components/TextInput/constants.d.ts +5 -0
  468. package/dist/components/TextInput/index.cjs +8 -113
  469. package/dist/components/TextInput/index.d.ts +3 -55
  470. package/dist/components/TextInput/index.js +8 -111
  471. package/dist/components/TextInput/styles.css.cjs +17 -0
  472. package/dist/components/TextInput/styles.css.d.ts +8 -0
  473. package/dist/components/TextInput/styles.css.js +17 -0
  474. package/dist/components/TimeInput/constants.cjs +0 -6
  475. package/dist/components/TimeInput/constants.js +0 -6
  476. package/dist/components/TimeInput/index.cjs +16 -96
  477. package/dist/components/TimeInput/index.d.ts +0 -7
  478. package/dist/components/TimeInput/index.js +13 -91
  479. package/dist/components/TimeInput/styles.css.cjs +10 -0
  480. package/dist/components/TimeInput/styles.css.d.ts +82 -0
  481. package/dist/components/TimeInput/styles.css.js +10 -0
  482. package/dist/components/Toaster/index.cjs +3 -23
  483. package/dist/components/Toaster/index.js +3 -21
  484. package/dist/components/Toaster/styles.css.cjs +7 -0
  485. package/dist/components/Toaster/styles.css.d.ts +2 -0
  486. package/dist/components/Toaster/styles.css.js +7 -0
  487. package/dist/components/Toggle/index.cjs +10 -108
  488. package/dist/components/Toggle/index.d.ts +0 -18
  489. package/dist/components/Toggle/index.js +13 -109
  490. package/dist/components/Toggle/styles.css.cjs +10 -0
  491. package/dist/components/Toggle/styles.css.d.ts +108 -0
  492. package/dist/components/Toggle/styles.css.js +10 -0
  493. package/dist/components/ToggleGroup/index.cjs +2 -20
  494. package/dist/components/ToggleGroup/index.js +2 -18
  495. package/dist/components/ToggleGroup/styles.css.cjs +5 -0
  496. package/dist/components/ToggleGroup/styles.css.d.ts +1 -0
  497. package/dist/components/ToggleGroup/styles.css.js +5 -0
  498. package/dist/components/Tooltip/index.cjs +2 -20
  499. package/dist/components/Tooltip/index.d.ts +1 -1
  500. package/dist/components/Tooltip/index.js +2 -18
  501. package/dist/components/Tooltip/styles.css.cjs +5 -0
  502. package/dist/components/Tooltip/styles.css.d.ts +1 -0
  503. package/dist/components/Tooltip/styles.css.js +5 -0
  504. package/dist/components/UnitInput/index.cjs +30 -123
  505. package/dist/components/UnitInput/index.d.ts +2 -1
  506. package/dist/components/UnitInput/index.js +26 -117
  507. package/dist/components/UnitInput/styles.css.cjs +17 -0
  508. package/dist/components/UnitInput/styles.css.d.ts +7 -0
  509. package/dist/components/UnitInput/styles.css.js +17 -0
  510. package/dist/components/VerificationCode/constants.d.ts +12 -0
  511. package/dist/components/VerificationCode/index.cjs +5 -88
  512. package/dist/components/VerificationCode/index.d.ts +1 -1
  513. package/dist/components/VerificationCode/index.js +5 -86
  514. package/dist/components/VerificationCode/styles.css.cjs +9 -0
  515. package/dist/components/VerificationCode/styles.css.d.ts +3 -0
  516. package/dist/components/VerificationCode/styles.css.js +9 -0
  517. package/dist/components/index.d.ts +1 -0
  518. package/dist/index.cjs +110 -103
  519. package/dist/index.js +3 -2
  520. package/dist/theme/ThemeProvider.cjs +2 -29
  521. package/dist/theme/ThemeProvider.js +4 -31
  522. package/dist/theme/index.cjs +8 -4
  523. package/dist/theme/index.d.ts +2 -3
  524. package/dist/theme/index.js +4 -6
  525. package/dist/ui.css +1 -1
  526. package/dist/utils/animationVanillaExtract.css.d.ts +3 -0
  527. package/dist/utils/index.d.ts +1 -0
  528. package/package.json +9 -6
  529. package/dist/components/Breadcrumbs/constants.js +0 -4
  530. package/dist/components/Modal/constants.cjs +0 -53
  531. package/dist/components/Modal/constants.js +0 -53
  532. package/dist/components/Popup/animations.cjs +0 -25
  533. package/dist/components/Popup/animations.d.ts +0 -21
  534. package/dist/components/Popup/animations.js +0 -25
  535. package/dist/components/SearchInput/Key.cjs +0 -55
  536. package/dist/components/SearchInput/Key.d.ts +0 -21
  537. package/dist/components/SearchInput/Key.js +0 -53
  538. package/dist/components/SelectInput/Dropdown.cjs +0 -488
  539. package/dist/components/SelectInput/Dropdown.js +0 -486
  540. package/dist/components/SelectInput/DropdownOption.cjs +0 -91
  541. package/dist/components/SelectInput/DropdownOption.js +0 -89
  542. package/dist/components/SelectInput/SearchBarDropdown.cjs +0 -133
  543. package/dist/components/SelectInput/SearchBarDropdown.js +0 -131
  544. package/dist/components/SelectInput/SelectBar.cjs +0 -373
  545. package/dist/components/SelectInput/SelectBar.js +0 -371
  546. package/dist/themes/dist/vanilla/themes.css.js.vanilla.css.cjs +0 -1
  547. package/dist/themes/dist/vanilla/themes.css.js.vanilla.css.js +0 -1
  548. package/dist/themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.cjs +0 -1
  549. package/dist/themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.js +0 -1
  550. package/dist/utils/capitalize.cjs +0 -3
  551. package/dist/utils/capitalize.js +0 -4
  552. package/dist/utils/searchAlgorithm.cjs +0 -40
  553. package/dist/utils/searchAlgorithm.d.ts +0 -12
  554. package/dist/utils/searchAlgorithm.js +0 -40
@@ -0,0 +1,341 @@
1
+ "use client";
2
+ import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
3
+ import { useTheme } from "@ultraviolet/themes";
4
+ import { useState, useRef, useContext, useEffect, useCallback, useMemo } from "react";
5
+ import { Checkbox } from "../../Checkbox/index.js";
6
+ import { ModalContext } from "../../Modal/ModalProvider.js";
7
+ import { Popup } from "../../Popup/index.js";
8
+ import { Skeleton } from "../../Skeleton/index.js";
9
+ import { Stack } from "../../Stack/index.js";
10
+ import { Text } from "../../Text/index.js";
11
+ import { useSelectInput } from "../SelectInputProvider.js";
12
+ import { INPUT_SIZE_HEIGHT } from "../types.js";
13
+ import { DisplayOption } from "./DropdownOption.js";
14
+ import { footer, dropdown, dropdownEmptyState, dropdownContainer, dropdownItem, dropdownCheckbox, dropdownGroupWrapper, dropdownGroupSelectable, dropdownGroup, dropdownLoadMore, dropdownContainerUnGrouped } from "./dropdown.css.js";
15
+ import { SearchBarDropdown } from "./SearchBarDropdown.js";
16
+ const DROPDOWN_MAX_HEIGHT = 256;
17
+ const NON_SEARCHABLE_KEYS = ["Tab", " ", "Enter", "CapsLock", "Shift", "ArrowDown", "ArrowUp", "ArrowLeft", "ArrowRight", "Escape"];
18
+ const moveFocusDown = () => {
19
+ const options = document.querySelectorAll('#items > div[role="option"]:not([disabled])');
20
+ const activeItem = document.activeElement;
21
+ if (options) {
22
+ for (let i = 0; i < options?.length; i += 1) {
23
+ const listLength = options.length;
24
+ if (activeItem === options[i] && activeItem !== options[listLength - 1]) {
25
+ options[i + 1].focus();
26
+ }
27
+ }
28
+ }
29
+ };
30
+ const moveFocusUp = () => {
31
+ const options = document.querySelectorAll('#items > div[role="option"]:not([disabled])');
32
+ const activeItem = document.activeElement;
33
+ if (options) {
34
+ for (let i = 0; i < options.length; i += 1) {
35
+ if (activeItem === options[i] && activeItem !== options[0]) {
36
+ options[i - 1].focus();
37
+ }
38
+ }
39
+ }
40
+ };
41
+ const handleKeyDownSelect = (event) => {
42
+ if (event.key === "ArrowDown") {
43
+ event.preventDefault();
44
+ moveFocusDown();
45
+ }
46
+ if (event.key === "ArrowUp") {
47
+ event.preventDefault();
48
+ moveFocusUp();
49
+ }
50
+ if (event.key === " ") {
51
+ event.preventDefault();
52
+ }
53
+ };
54
+ const handleKeyDown = (event, ref, options, searchBarActive, setSearch, setDefaultSearch, search) => {
55
+ if (ref.current && !searchBarActive && !NON_SEARCHABLE_KEYS.includes(event.key) && document.activeElement?.ariaLabel !== "search-bar") {
56
+ const currentSearch = search + event.key;
57
+ setSearch(currentSearch);
58
+ ref.current.focus();
59
+ if (!Array.isArray(options)) {
60
+ const closestOptions = {
61
+ ...options
62
+ };
63
+ Object.keys(closestOptions).map((group) => {
64
+ closestOptions[group] = closestOptions[group].filter((option) => option.searchText ? option.searchText.toLocaleLowerCase().startsWith(currentSearch) : option.value.toLocaleLowerCase().startsWith(currentSearch));
65
+ return null;
66
+ });
67
+ const closestOption = closestOptions[Object.keys(closestOptions)[0]][0];
68
+ if (closestOption) {
69
+ setDefaultSearch(closestOption.searchText ?? closestOption.value);
70
+ } else {
71
+ setDefaultSearch(null);
72
+ }
73
+ } else {
74
+ const closestOption = [...options].find((option) => option.searchText ? option.searchText.toLocaleLowerCase().startsWith(currentSearch) : option.value.toLocaleLowerCase().startsWith(currentSearch));
75
+ if (closestOption) {
76
+ setDefaultSearch(closestOption.searchText ?? closestOption.value);
77
+ } else {
78
+ setDefaultSearch(null);
79
+ }
80
+ }
81
+ }
82
+ };
83
+ const CreateDropdown = ({
84
+ isEmpty,
85
+ emptyState,
86
+ descriptionDirection,
87
+ loadMore,
88
+ optionalInfoPlacement,
89
+ defaultSearchValue,
90
+ isLoading
91
+ }) => {
92
+ const {
93
+ setIsDropdownVisible,
94
+ onChange,
95
+ options,
96
+ multiselect,
97
+ selectAll,
98
+ selectAllGroup,
99
+ displayedOptions,
100
+ setSelectedData,
101
+ selectedData
102
+ } = useSelectInput();
103
+ const focusedItemRef = useRef(null);
104
+ useEffect(() => {
105
+ if (defaultSearchValue && focusedItemRef?.current) {
106
+ focusedItemRef.current.focus();
107
+ }
108
+ }, [defaultSearchValue]);
109
+ if (isEmpty) {
110
+ return /* @__PURE__ */ jsx(Stack, { alignItems: "center", className: dropdownEmptyState, gap: 2, children: emptyState ?? /* @__PURE__ */ jsx(Text, { as: "p", variant: "bodyStrong", children: "No options" }) });
111
+ }
112
+ const handleClick = (clickedOption, group) => {
113
+ setSelectedData({
114
+ clickedOption,
115
+ group,
116
+ type: "selectOption"
117
+ });
118
+ if (multiselect) {
119
+ if (selectedData.selectedValues.includes(clickedOption.value)) {
120
+ onChange?.(selectedData.selectedValues.filter((val) => val !== clickedOption.value));
121
+ } else {
122
+ onChange?.([...selectedData.selectedValues, clickedOption.value]);
123
+ }
124
+ } else {
125
+ onChange?.(clickedOption.value);
126
+ }
127
+ setIsDropdownVisible(multiselect);
128
+ };
129
+ const selectAllOptions = () => {
130
+ if (multiselect) {
131
+ setSelectedData({
132
+ type: "selectAll"
133
+ });
134
+ if (selectedData.allSelected && onChange) {
135
+ onChange([]);
136
+ } else {
137
+ const allValues = [];
138
+ if (!Array.isArray(options)) {
139
+ Object.keys(options).map((group) => options[group].map((option) => {
140
+ if (!option.disabled) {
141
+ allValues.push(option);
142
+ }
143
+ return null;
144
+ }));
145
+ } else {
146
+ options.map((option) => allValues.push(option));
147
+ }
148
+ onChange?.(allValues.map((value) => value.value));
149
+ }
150
+ }
151
+ };
152
+ const handleSelectGroup = (group) => {
153
+ if (multiselect) {
154
+ setSelectedData({
155
+ selectedGroup: group,
156
+ type: "selectGroup"
157
+ });
158
+ if (!Array.isArray(options)) {
159
+ if (selectedData.selectedGroups.includes(group)) {
160
+ const newSelectedValues = [...selectedData.selectedValues].filter((selectedValue) => !options[group].find((option) => option.value === selectedValue));
161
+ onChange?.(newSelectedValues);
162
+ } else {
163
+ const newSelectedValues = [...selectedData.selectedValues];
164
+ options[group].map((option) => newSelectedValues.includes(option.value) || option.disabled ? null : newSelectedValues.push(option.value));
165
+ onChange?.(newSelectedValues);
166
+ }
167
+ }
168
+ }
169
+ };
170
+ return !Array.isArray(displayedOptions) ? /* @__PURE__ */ jsxs(Stack, { className: dropdownContainer, "data-grouped": true, id: "select-dropdown", onKeyDown: handleKeyDownSelect, role: "listbox", children: [
171
+ isLoading ? /* @__PURE__ */ jsx(Skeleton, { variant: "block" }) : /* @__PURE__ */ jsxs(Fragment, { children: [
172
+ selectAll && multiselect ? /* @__PURE__ */ jsx(Stack, { id: "items", children: /* @__PURE__ */ jsx("div", { "aria-disabled": false, "aria-label": "select-all", "aria-selected": selectedData.allSelected, className: dropdownItem({
173
+ selected: selectedData.allSelected
174
+ }), "data-testid": "select-all", id: "select-all", onClick: selectAllOptions, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? selectAllOptions() : null, role: "option", tabIndex: 0, children: /* @__PURE__ */ jsx(Checkbox, { checked: selectedData.allSelected, className: dropdownCheckbox, "data-testid": "select-all-checkbox", disabled: false, onChange: selectAllOptions, tabIndex: -1, value: "select-all", children: /* @__PURE__ */ jsxs(Stack, { direction: "column", children: [
175
+ /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", variant: "body", children: selectAll.label }),
176
+ /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: selectAll.description })
177
+ ] }) }) }) }) : null,
178
+ Object.keys(displayedOptions).map((group, index) => /* @__PURE__ */ jsxs(Stack, { gap: 0.25, children: [
179
+ displayedOptions[group].length > 0 ? /* @__PURE__ */ jsx("div", { className: dropdownGroupWrapper, id: selectAllGroup ? "items" : void 0, children: group ? /* @__PURE__ */ jsx("button", { className: `${selectAllGroup ? dropdownGroupSelectable : ""} ${dropdownGroup}`, "data-selectgroup": selectAllGroup, "data-testid": `group-${index}`, onClick: () => selectAllGroup ? handleSelectGroup(group) : null, onKeyDown: (event) => {
180
+ if ([" ", "Enter"].includes(event.key)) {
181
+ event.preventDefault();
182
+ handleSelectGroup(group);
183
+ }
184
+ }, role: "group", tabIndex: selectAllGroup ? 0 : -1, type: "button", children: selectAllGroup ? /* @__PURE__ */ jsx(Checkbox, { checked: selectedData.selectedGroups.includes(group), className: dropdownCheckbox, "data-testid": "select-group", disabled: false, onChange: () => selectAllGroup ? handleSelectGroup(group) : null, tabIndex: -1, value: group, children: /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", sentiment: "neutral", variant: "caption", children: group.toUpperCase() }) }) : /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", sentiment: "neutral", variant: "caption", children: group.toUpperCase() }) }, group) : null }) : null,
185
+ /* @__PURE__ */ jsx(Stack, { gap: "0.25", id: "items", children: displayedOptions[group].map((option, indexOption) => /* @__PURE__ */ jsx("div", { "aria-disabled": !!option.disabled, "aria-label": option.value, "aria-selected": selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdownItem({
186
+ disabled: !!option.disabled,
187
+ selected: selectedData.selectedValues.includes(option.value) && !option.disabled
188
+ }), "data-testid": `option-${option.value}`, id: `option-${indexOption}`, onClick: () => {
189
+ if (!option.disabled) {
190
+ handleClick(option, group);
191
+ }
192
+ }, 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__ */ jsx(Checkbox, { checked: selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdownCheckbox, disabled: option.disabled, onChange: () => {
193
+ if (!option.disabled) {
194
+ handleClick(option, group);
195
+ }
196
+ }, tabIndex: -1, value: option.value, children: /* @__PURE__ */ jsx(DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }) : /* @__PURE__ */ jsx(DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }, option.value)) })
197
+ ] }, group))
198
+ ] }),
199
+ loadMore ? /* @__PURE__ */ jsx(Stack, { className: dropdownLoadMore, children: loadMore }) : null
200
+ ] }) : /* @__PURE__ */ jsxs(Stack, { className: `${dropdownContainer} ${dropdownContainerUnGrouped}`, gap: 0.25, id: "select-dropdown", onKeyDown: handleKeyDownSelect, role: "listbox", children: [
201
+ selectAll && multiselect ? /* @__PURE__ */ jsx(Stack, { gap: 0.25, id: "items", tabIndex: -1, children: /* @__PURE__ */ jsx("div", { "aria-disabled": false, "aria-label": "select-all", "aria-selected": selectedData.allSelected, className: dropdownItem({
202
+ selected: selectedData.allSelected
203
+ }), "data-testid": "select-all", onClick: selectAllOptions, onKeyDown: (event) => [" ", "Enter"].includes(event.key) ? selectAllOptions() : null, role: "option", tabIndex: 0, children: /* @__PURE__ */ jsx(Checkbox, { checked: selectedData.allSelected, className: dropdownCheckbox, "data-testid": "select-all-checkbox", disabled: false, onChange: selectAllOptions, tabIndex: -1, value: "select-all", children: /* @__PURE__ */ jsxs(Stack, { direction: "column", children: [
204
+ /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", variant: "body", children: selectAll.label }),
205
+ /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: selectAll.description })
206
+ ] }) }) }) }) : null,
207
+ /* @__PURE__ */ jsxs(Stack, { gap: 0.25, id: "items", children: [
208
+ isLoading ? /* @__PURE__ */ jsx(Skeleton, { variant: "block" }) : displayedOptions.map((option, index) => /* @__PURE__ */ jsx("div", { "aria-disabled": !!option.disabled, "aria-label": option.value, "aria-selected": selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdownItem({
209
+ disabled: !!option.disabled,
210
+ selected: selectedData.selectedValues.includes(option.value) && !option.disabled
211
+ }), "data-testid": `option-${option.value}`, id: `option-${index}`, onClick: () => {
212
+ if (!option.disabled) {
213
+ handleClick(option);
214
+ }
215
+ }, 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__ */ jsx(Checkbox, { checked: selectedData.selectedValues.includes(option.value) && !option.disabled, className: dropdownCheckbox, disabled: option.disabled, onChange: () => {
216
+ if (!option.disabled) {
217
+ handleClick(option);
218
+ }
219
+ }, tabIndex: -1, value: option.value, children: /* @__PURE__ */ jsx(DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }) : /* @__PURE__ */ jsx(DisplayOption, { descriptionDirection, option, optionalInfoPlacement }) }, option.value)),
220
+ loadMore ? /* @__PURE__ */ jsx(Stack, { className: dropdownLoadMore, children: loadMore }) : null
221
+ ] })
222
+ ] });
223
+ };
224
+ const Dropdown = ({
225
+ children,
226
+ emptyState,
227
+ descriptionDirection,
228
+ searchable,
229
+ placeholder,
230
+ footer: footer$1,
231
+ refSelect,
232
+ loadMore,
233
+ optionalInfoPlacement,
234
+ isLoading,
235
+ size,
236
+ dropdownAlign,
237
+ portalTarget,
238
+ id
239
+ }) => {
240
+ const {
241
+ setIsDropdownVisible,
242
+ isDropdownVisible,
243
+ onSearch,
244
+ searchInput,
245
+ options,
246
+ displayedOptions,
247
+ numberOfOptions
248
+ } = useSelectInput();
249
+ const theme = useTheme();
250
+ const [searchBarActive, setSearchBarActive] = useState(false);
251
+ const [defaultSearchValue, setDefaultSearch] = useState(null);
252
+ const ref = useRef(null);
253
+ const [search, setSearch] = useState("");
254
+ const [maxWidth, setWidth] = useState(refSelect.current?.offsetWidth ?? "100%");
255
+ const modalContext = useContext(ModalContext);
256
+ useEffect(() => {
257
+ if (refSelect.current && isDropdownVisible) {
258
+ const position = refSelect.current.getBoundingClientRect().bottom + DROPDOWN_MAX_HEIGHT + Number(theme.sizing[INPUT_SIZE_HEIGHT[size]].replace("rem", "")) * 16 + Number.parseInt(theme.space["5"], 10);
259
+ const overflow = position - window.innerHeight + 32;
260
+ if (overflow > 0 && modalContext) {
261
+ const currentModal = modalContext.openedModals[0];
262
+ const modalElement = currentModal?.ref.current;
263
+ if (modalElement) {
264
+ const parentElement = modalElement.parentNode;
265
+ if (parentElement) {
266
+ parentElement.scrollBy({
267
+ behavior: "smooth",
268
+ top: overflow
269
+ });
270
+ }
271
+ } else {
272
+ window.scrollBy({
273
+ behavior: "smooth",
274
+ top: overflow
275
+ });
276
+ }
277
+ }
278
+ }
279
+ }, [isDropdownVisible, refSelect, size, ref.current]);
280
+ const resizeDropdown = useCallback(() => {
281
+ if (refSelect.current && refSelect.current.getBoundingClientRect().width > 0) {
282
+ setWidth(refSelect.current.getBoundingClientRect().width);
283
+ }
284
+ }, [refSelect]);
285
+ useEffect(() => {
286
+ resizeDropdown();
287
+ window.addEventListener("resize", resizeDropdown);
288
+ return () => window.removeEventListener("resize", resizeDropdown);
289
+ }, [resizeDropdown]);
290
+ useEffect(() => {
291
+ if (!searchInput) {
292
+ onSearch(options);
293
+ }
294
+ }, [onSearch, options, searchInput]);
295
+ useEffect(() => {
296
+ if (!isDropdownVisible) {
297
+ setDefaultSearch(null);
298
+ setSearch("");
299
+ }
300
+ if (!searchable) {
301
+ document.addEventListener("keydown", (event) => handleKeyDown(event, ref, options, searchBarActive, setSearch, setDefaultSearch, search));
302
+ }
303
+ return () => {
304
+ if (!searchable) {
305
+ document.removeEventListener("keydown", (event) => handleKeyDown(event, ref, options, searchBarActive, setSearch, setDefaultSearch, search));
306
+ }
307
+ };
308
+ }, [isDropdownVisible, searchBarActive, options, onSearch, search, refSelect, setDefaultSearch, setIsDropdownVisible, searchable]);
309
+ const isEmpty = useMemo(() => {
310
+ if (numberOfOptions === 0) {
311
+ return true;
312
+ }
313
+ if (Array.isArray(displayedOptions)) {
314
+ return displayedOptions.length === 0;
315
+ }
316
+ const groups = Object.keys(displayedOptions);
317
+ for (const group of groups) {
318
+ if (displayedOptions[group].length > 0) {
319
+ return false;
320
+ }
321
+ }
322
+ return true;
323
+ }, [displayedOptions, numberOfOptions]);
324
+ const computedFooter = useMemo(() => {
325
+ if (footer$1 && !isEmpty) {
326
+ if (typeof footer$1 === "function") {
327
+ return /* @__PURE__ */ jsx("div", { className: footer, children: footer$1(() => setIsDropdownVisible(false)) });
328
+ }
329
+ return /* @__PURE__ */ jsx("div", { className: footer, children: footer$1 });
330
+ }
331
+ return null;
332
+ }, [isEmpty, footer$1, setIsDropdownVisible]);
333
+ return /* @__PURE__ */ jsx(Popup, { align: dropdownAlign ?? "start", className: 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__ */ jsxs(Stack, { children: [
334
+ searchable && !isLoading && numberOfOptions >= 6 ? /* @__PURE__ */ jsx(SearchBarDropdown, { displayedOptions, placeholder, setSearchBarActive }) : null,
335
+ /* @__PURE__ */ jsx(CreateDropdown, { defaultSearchValue, descriptionDirection, emptyState, isEmpty, isLoading, loadMore, optionalInfoPlacement }),
336
+ computedFooter
337
+ ] }), visible: isDropdownVisible, children });
338
+ };
339
+ export {
340
+ Dropdown
341
+ };
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
5
+ const index$1 = require("../../Stack/index.cjs");
6
+ const index$2 = require("../../Text/index.cjs");
7
+ const index = require("../../Tooltip/index.cjs");
8
+ const dropdown_css = require("./dropdown.css.cjs");
9
+ const DisplayOption = ({
10
+ option,
11
+ optionalInfoPlacement,
12
+ descriptionDirection
13
+ }) => {
14
+ if (descriptionDirection === "row" && optionalInfoPlacement === "left") {
15
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxRuntime.jsx(index$1.Stack, { "data-testid": `option-stack-${option.value}`, direction: "row", gap: 0.5, justifyContent: "left", children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "center", className: dropdown_css.dropdownInfoContainer, direction: "row", gap: 0.5, children: [
16
+ option.optionalInfo ?? null,
17
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", className: dropdown_css.dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
18
+ option.description ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
19
+ ] }) }) });
20
+ }
21
+ if (descriptionDirection === "row" && optionalInfoPlacement === "right") {
22
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "baseline", "data-testid": `option-stack-${option.value}`, direction: "row", gap: 0.5, justifyContent: "space-between", children: [
23
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "baseline", className: dropdown_css.dropdownInfoContainer, direction: "row", gap: 0.5, children: [
24
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", className: dropdown_css.dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
25
+ option.description ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
26
+ ] }),
27
+ option.optionalInfo ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: dropdown_css.dropdownInfo, children: option.optionalInfo }) : null
28
+ ] }) });
29
+ }
30
+ if (descriptionDirection === "column" && optionalInfoPlacement === "left") {
31
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "normal", direction: "row", gap: 0.5, justifyContent: option.optionalInfo ? "left" : "space-between", children: [
32
+ option.optionalInfo ?? null,
33
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { className: dropdown_css.dropdownInfoContainer, "data-testid": `option-stack-${option.value}`, direction: "column", gap: 0.5, children: [
34
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", className: dropdown_css.dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
35
+ option.description ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
36
+ ] })
37
+ ] }) });
38
+ }
39
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "normal", "data-testid": `option-stack-${option.value}`, direction: "column", gap: 0.5, children: [
40
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { className: dropdown_css.dropdownInfoContainer, direction: "row", gap: 0.5, justifyContent: "space-between", children: [
41
+ /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", className: dropdown_css.dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
42
+ option.optionalInfo ? /* @__PURE__ */ jsxRuntime.jsx("div", { className: dropdown_css.dropdownInfo, children: option.optionalInfo }) : null
43
+ ] }),
44
+ option.description ? /* @__PURE__ */ jsxRuntime.jsx(index$2.Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
45
+ ] }) });
46
+ };
47
+ exports.DisplayOption = DisplayOption;
@@ -1,4 +1,4 @@
1
- import type { OptionType } from './types';
1
+ import type { OptionType } from '../types';
2
2
  type DisplayOptionProps = {
3
3
  option: OptionType;
4
4
  descriptionDirection: 'row' | 'column';
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
+ import { Stack } from "../../Stack/index.js";
4
+ import { Text } from "../../Text/index.js";
5
+ import { Tooltip } from "../../Tooltip/index.js";
6
+ import { dropdownInfoContainer, dropdownInfoTextItem, dropdownInfo } from "./dropdown.css.js";
7
+ const DisplayOption = ({
8
+ option,
9
+ optionalInfoPlacement,
10
+ descriptionDirection
11
+ }) => {
12
+ if (descriptionDirection === "row" && optionalInfoPlacement === "left") {
13
+ return /* @__PURE__ */ jsx(Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsx(Stack, { "data-testid": `option-stack-${option.value}`, direction: "row", gap: 0.5, justifyContent: "left", children: /* @__PURE__ */ jsxs(Stack, { alignItems: "center", className: dropdownInfoContainer, direction: "row", gap: 0.5, children: [
14
+ option.optionalInfo ?? null,
15
+ /* @__PURE__ */ jsx(Text, { as: "span", className: dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
16
+ option.description ? /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
17
+ ] }) }) });
18
+ }
19
+ if (descriptionDirection === "row" && optionalInfoPlacement === "right") {
20
+ return /* @__PURE__ */ jsx(Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxs(Stack, { alignItems: "baseline", "data-testid": `option-stack-${option.value}`, direction: "row", gap: 0.5, justifyContent: "space-between", children: [
21
+ /* @__PURE__ */ jsxs(Stack, { alignItems: "baseline", className: dropdownInfoContainer, direction: "row", gap: 0.5, children: [
22
+ /* @__PURE__ */ jsx(Text, { as: "span", className: dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
23
+ option.description ? /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
24
+ ] }),
25
+ option.optionalInfo ? /* @__PURE__ */ jsx("div", { className: dropdownInfo, children: option.optionalInfo }) : null
26
+ ] }) });
27
+ }
28
+ if (descriptionDirection === "column" && optionalInfoPlacement === "left") {
29
+ return /* @__PURE__ */ jsx(Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxs(Stack, { alignItems: "normal", direction: "row", gap: 0.5, justifyContent: option.optionalInfo ? "left" : "space-between", children: [
30
+ option.optionalInfo ?? null,
31
+ /* @__PURE__ */ jsxs(Stack, { className: dropdownInfoContainer, "data-testid": `option-stack-${option.value}`, direction: "column", gap: 0.5, children: [
32
+ /* @__PURE__ */ jsx(Text, { as: "span", className: dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
33
+ option.description ? /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
34
+ ] })
35
+ ] }) });
36
+ }
37
+ return /* @__PURE__ */ jsx(Tooltip, { text: option.tooltip, children: /* @__PURE__ */ jsxs(Stack, { alignItems: "normal", "data-testid": `option-stack-${option.value}`, direction: "column", gap: 0.5, children: [
38
+ /* @__PURE__ */ jsxs(Stack, { className: dropdownInfoContainer, direction: "row", gap: 0.5, justifyContent: "space-between", children: [
39
+ /* @__PURE__ */ jsx(Text, { as: "span", className: dropdownInfoTextItem, placement: "left", variant: "body", children: option.label }),
40
+ option.optionalInfo ? /* @__PURE__ */ jsx("div", { className: dropdownInfo, children: option.optionalInfo }) : null
41
+ ] }),
42
+ option.description ? /* @__PURE__ */ jsx(Text, { as: "span", placement: "left", prominence: "weak", sentiment: "neutral", variant: "bodySmall", children: option.description }) : null
43
+ ] }) });
44
+ };
45
+ export {
46
+ DisplayOption
47
+ };
@@ -0,0 +1,117 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
5
+ const fuzzySearch = require("@scaleway/fuzzy-search");
6
+ const Icon = require("@ultraviolet/icons");
7
+ const react = require("react");
8
+ const index = require("../../TextInput/index.cjs");
9
+ const SelectInputProvider = require("../SelectInputProvider.cjs");
10
+ const dropdown_css = require("./dropdown.css.cjs");
11
+ const getReferenceText = (option) => {
12
+ if (option.searchText) {
13
+ return fuzzySearch.normalizeString(option.searchText);
14
+ }
15
+ if (typeof option.label === "string") {
16
+ return fuzzySearch.normalizeString(option.label);
17
+ }
18
+ return "";
19
+ };
20
+ const searchRegex = (data, query) => data.filter((option) => {
21
+ const referenceText = getReferenceText(option);
22
+ const regex = new RegExp(query, "i");
23
+ return (query.length > 2 ? fuzzySearch.isFuzzyMatch(query, referenceText) : referenceText.match(regex)) || typeof option.description === "string" && option.description.match(regex) || option.value.match(regex);
24
+ });
25
+ const findClosestOption = (options, searchInput) => {
26
+ if (searchInput) {
27
+ if (!Array.isArray(options)) {
28
+ const possibleOptions = {
29
+ ...options
30
+ };
31
+ Object.keys(possibleOptions).map((group) => {
32
+ possibleOptions[group] = possibleOptions[group].filter((option) => !option.disabled);
33
+ return null;
34
+ });
35
+ if (Object.keys(possibleOptions).some((group) => possibleOptions[group].length > 0)) {
36
+ const firstFit = Object.keys(possibleOptions).map((group) => possibleOptions[group][0]).find((value) => !!value);
37
+ return firstFit;
38
+ }
39
+ } else {
40
+ const possibleOption = [...options].find((option) => !option.disabled);
41
+ if (possibleOption) {
42
+ return possibleOption;
43
+ }
44
+ }
45
+ }
46
+ return null;
47
+ };
48
+ const escapeRegExp = (string) => string.replace(/[.*+?^{}()|[\]\\]/g, String.raw`\$&`);
49
+ const SearchBarDropdown = ({
50
+ placeholder,
51
+ displayedOptions,
52
+ setSearchBarActive
53
+ }) => {
54
+ const searchInputRef = react.useRef(null);
55
+ const {
56
+ onChange,
57
+ onSearch,
58
+ setSearchInput,
59
+ searchInput,
60
+ options,
61
+ multiselect,
62
+ setSelectedData,
63
+ selectedData
64
+ } = SelectInputProvider.useSelectInput();
65
+ const handleChange = (search) => {
66
+ if (search.length > 0) {
67
+ if (!Array.isArray(options)) {
68
+ const filteredOptions = {
69
+ ...options
70
+ };
71
+ Object.keys(filteredOptions).map((group) => {
72
+ filteredOptions[group] = searchRegex(filteredOptions[group], escapeRegExp(search.toString()));
73
+ return null;
74
+ });
75
+ onSearch(filteredOptions);
76
+ } else {
77
+ const filteredOptions = searchRegex([...options], escapeRegExp(search.toString()));
78
+ onSearch(filteredOptions);
79
+ }
80
+ } else {
81
+ onSearch(options);
82
+ }
83
+ setSearchInput(search);
84
+ };
85
+ const handleKeyDown = (key, search) => {
86
+ if (key === "Enter") {
87
+ const closestOption = findClosestOption(displayedOptions, search);
88
+ if (closestOption) {
89
+ if (multiselect) {
90
+ setSelectedData({
91
+ clickedOption: closestOption,
92
+ group: !Array.isArray(options) ? Object.keys(options).find((group) => options[group].includes(closestOption)) : void 0,
93
+ type: "selectOption"
94
+ });
95
+ onChange?.(selectedData.selectedValues.includes(closestOption.value) ? selectedData.selectedValues : [...selectedData.selectedValues, closestOption.value]);
96
+ } else {
97
+ setSelectedData({
98
+ clickedOption: closestOption,
99
+ type: "selectOption"
100
+ });
101
+ onChange?.(selectedData.selectedValues[0] ?? "");
102
+ }
103
+ }
104
+ } else if (key === "Tab") {
105
+ searchInputRef.current?.blur();
106
+ }
107
+ };
108
+ react.useEffect(() => {
109
+ setTimeout(() => {
110
+ searchInputRef.current?.focus();
111
+ }, 50);
112
+ }, []);
113
+ return /* @__PURE__ */ jsxRuntime.jsx(index.TextInput, { "aria-label": "search-bar", className: dropdown_css.searchBar, "data-testid": "search-bar", onBlur: () => setSearchBarActive(false), onChange: (event) => handleChange(event.target.value), onFocus: () => setSearchBarActive(true), onKeyDown: (event) => handleKeyDown(event.key, searchInput), placeholder, prefix: /* @__PURE__ */ jsxRuntime.jsx(Icon.SearchIcon, { sentiment: "neutral", size: "small" }), ref: searchInputRef, size: "medium", value: searchInput });
114
+ };
115
+ exports.SearchBarDropdown = SearchBarDropdown;
116
+ exports.getReferenceText = getReferenceText;
117
+ exports.searchRegex = searchRegex;
@@ -1,5 +1,5 @@
1
1
  import type { Dispatch, SetStateAction } from 'react';
2
- import type { DataType, OptionType } from './types';
2
+ import type { DataType, OptionType } from '../types';
3
3
  type SearchBarProps = {
4
4
  placeholder: string;
5
5
  displayedOptions: DataType;