@ultraviolet/ui 1.51.0 → 1.51.2

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 (440) hide show
  1. package/dist/components/ActionBar/index.d.ts +20 -0
  2. package/dist/components/ActionBar/index.js +40 -0
  3. package/dist/components/Alert/index.d.ts +27 -0
  4. package/dist/components/Alert/index.js +126 -0
  5. package/dist/components/Avatar/index.d.ts +43 -0
  6. package/dist/components/Avatar/index.js +54 -0
  7. package/dist/components/Badge/index.d.ts +31 -0
  8. package/dist/components/Badge/index.js +115 -0
  9. package/dist/components/Banner/assets/default-image-small.svg.js +4 -0
  10. package/dist/components/Banner/assets/default-image.svg.js +4 -0
  11. package/dist/components/Banner/index.d.ts +24 -0
  12. package/dist/components/Banner/index.js +191 -0
  13. package/dist/components/BarChart/Tooltip.d.ts +9 -0
  14. package/dist/components/BarChart/Tooltip.js +36 -0
  15. package/dist/components/BarChart/index.d.ts +27 -0
  16. package/dist/components/BarChart/index.js +82 -0
  17. package/dist/components/BarStack/index.d.ts +36 -0
  18. package/dist/components/BarStack/index.js +188 -0
  19. package/dist/components/Breadcrumbs/index.d.ts +30 -0
  20. package/dist/components/Breadcrumbs/index.js +76 -0
  21. package/dist/components/Bullet/index.d.ts +39 -0
  22. package/dist/components/Bullet/index.js +88 -0
  23. package/dist/components/Button/index.d.ts +120 -0
  24. package/dist/components/Button/index.js +291 -0
  25. package/dist/components/Card/index.d.ts +20 -0
  26. package/dist/components/Card/index.js +59 -0
  27. package/dist/components/Carousel/index.d.ts +19 -0
  28. package/dist/components/Carousel/index.js +147 -0
  29. package/dist/components/Checkbox/index.d.ts +36 -0
  30. package/dist/components/Checkbox/index.js +359 -0
  31. package/dist/components/CheckboxGroup/index.d.ts +24 -0
  32. package/dist/components/CheckboxGroup/index.js +112 -0
  33. package/dist/components/CopyButton/index.d.ts +19 -0
  34. package/dist/components/CopyButton/index.js +37 -0
  35. package/dist/components/DateInput/datepicker.css.js +4 -0
  36. package/dist/components/DateInput/index.d.ts +38 -0
  37. package/dist/components/DateInput/index.js +301 -0
  38. package/dist/components/Dialog/Context.d.ts +7 -0
  39. package/dist/components/Dialog/Context.js +15 -0
  40. package/dist/components/Dialog/constants.d.ts +2 -0
  41. package/dist/components/Dialog/index.d.ts +87 -0
  42. package/dist/components/Dialog/index.js +87 -0
  43. package/dist/components/Dialog/subComponents/Button.d.ts +7 -0
  44. package/dist/components/Dialog/subComponents/Button.js +24 -0
  45. package/dist/components/Dialog/subComponents/Buttons.d.ts +7 -0
  46. package/dist/components/Dialog/subComponents/Buttons.js +12 -0
  47. package/dist/components/Dialog/subComponents/CancelButton.d.ts +8 -0
  48. package/dist/components/Dialog/subComponents/CancelButton.js +9 -0
  49. package/dist/components/Dialog/subComponents/Stack.d.ts +6 -0
  50. package/dist/components/Dialog/subComponents/Stack.js +6 -0
  51. package/dist/components/Dialog/subComponents/Text.d.ts +6 -0
  52. package/dist/components/Dialog/subComponents/Text.js +6 -0
  53. package/dist/components/EmptyState/index.d.ts +38 -0
  54. package/dist/components/EmptyState/index.js +82 -0
  55. package/dist/components/Expandable/index.d.ts +33 -0
  56. package/dist/components/Expandable/index.js +79 -0
  57. package/dist/components/GlobalAlert/GlobalAlertLink.d.ts +3 -0
  58. package/dist/components/GlobalAlert/GlobalAlertLink.js +39 -0
  59. package/dist/components/GlobalAlert/index.d.ts +40 -0
  60. package/dist/components/GlobalAlert/index.js +112 -0
  61. package/dist/components/LineChart/CustomLegend.d.ts +13 -0
  62. package/dist/components/LineChart/CustomLegend.js +109 -0
  63. package/dist/components/LineChart/Tooltip.d.ts +6 -0
  64. package/dist/components/LineChart/Tooltip.js +46 -0
  65. package/dist/components/LineChart/helpers.d.ts +8 -0
  66. package/dist/components/LineChart/helpers.js +50 -0
  67. package/dist/components/LineChart/index.d.ts +25 -0
  68. package/dist/components/LineChart/index.js +118 -0
  69. package/dist/components/Link/index.d.ts +33 -0
  70. package/dist/components/Link/index.js +167 -0
  71. package/dist/components/List/Body.d.ts +6 -0
  72. package/dist/components/List/Body.js +11 -0
  73. package/dist/components/List/Cell.d.ts +12 -0
  74. package/dist/components/List/Cell.js +38 -0
  75. package/dist/components/List/HeaderCell.d.ts +11 -0
  76. package/dist/components/List/HeaderCell.js +96 -0
  77. package/dist/components/List/HeaderRow.d.ts +7 -0
  78. package/dist/components/List/HeaderRow.js +38 -0
  79. package/dist/components/List/ListContext.d.ts +34 -0
  80. package/dist/components/List/ListContext.js +155 -0
  81. package/dist/components/List/Row.d.ts +23 -0
  82. package/dist/components/List/Row.js +194 -0
  83. package/dist/components/List/SelectBar.d.ts +15 -0
  84. package/dist/components/List/SelectBar.js +35 -0
  85. package/dist/components/List/SkeletonRows.d.ts +7 -0
  86. package/dist/components/List/SkeletonRows.js +36 -0
  87. package/dist/components/List/constants.d.ts +2 -0
  88. package/dist/{src/components → components}/List/constants.js +4 -2
  89. package/dist/components/List/index.d.ts +68 -0
  90. package/dist/components/List/index.js +80 -0
  91. package/dist/components/Loader/index.d.ts +22 -0
  92. package/dist/components/Loader/index.js +98 -0
  93. package/dist/components/Menu/Item.d.ts +15 -0
  94. package/dist/components/Menu/Item.js +101 -0
  95. package/dist/components/Menu/index.d.ts +49 -0
  96. package/dist/components/Menu/index.js +182 -0
  97. package/dist/components/MenuV2/Group.d.ts +7 -0
  98. package/dist/components/MenuV2/Group.js +23 -0
  99. package/dist/components/MenuV2/Item.d.ts +16 -0
  100. package/dist/components/MenuV2/Item.js +120 -0
  101. package/dist/components/MenuV2/index.d.ts +90 -0
  102. package/dist/components/MenuV2/index.js +124 -0
  103. package/dist/components/Meter/index.d.ts +26 -0
  104. package/dist/components/Meter/index.js +76 -0
  105. package/dist/components/Modal/Dialog.d.ts +3 -0
  106. package/dist/components/Modal/Dialog.js +197 -0
  107. package/dist/components/Modal/Disclosure.d.ts +3 -0
  108. package/dist/{src/components → components}/Modal/Disclosure.js +12 -12
  109. package/dist/components/Modal/constants.d.ts +3 -0
  110. package/dist/{src/components → components}/Modal/constants.js +8 -6
  111. package/dist/components/Modal/index.d.ts +42 -0
  112. package/dist/components/Modal/index.js +114 -0
  113. package/dist/components/Modal/types.d.ts +48 -0
  114. package/dist/components/Notice/index.d.ts +11 -0
  115. package/dist/components/Notice/index.js +39 -0
  116. package/dist/components/Notification/index.d.ts +36 -0
  117. package/dist/components/Notification/index.js +88 -0
  118. package/dist/components/Notification/react-toastify.css.js +4 -0
  119. package/dist/components/NumberInput/helpers.d.ts +4 -0
  120. package/dist/{src/components → components}/NumberInput/helpers.js +6 -2
  121. package/dist/components/NumberInput/index.d.ts +41 -0
  122. package/dist/components/NumberInput/index.js +349 -0
  123. package/dist/components/NumberInputV2/index.d.ts +27 -0
  124. package/dist/components/NumberInputV2/index.js +370 -0
  125. package/dist/components/Pagination/getPageNumbers.d.ts +8 -0
  126. package/dist/{src/components → components}/Pagination/getPageNumbers.js +4 -12
  127. package/dist/components/Pagination/index.d.ts +30 -0
  128. package/dist/components/Pagination/index.js +124 -0
  129. package/dist/components/PasswordCheck/index.d.ts +20 -0
  130. package/dist/components/PasswordCheck/index.js +29 -0
  131. package/dist/components/PasswordStrengthMeter/index.d.ts +39 -0
  132. package/dist/components/PasswordStrengthMeter/index.js +98 -0
  133. package/dist/components/PieChart/Legends.d.ts +9 -0
  134. package/dist/components/PieChart/Legends.js +120 -0
  135. package/dist/components/PieChart/Tooltip.d.ts +12 -0
  136. package/dist/components/PieChart/Tooltip.js +29 -0
  137. package/dist/components/PieChart/index.d.ts +20 -0
  138. package/dist/components/PieChart/index.js +120 -0
  139. package/dist/components/PieChart/types.d.ts +7 -0
  140. package/dist/components/Popover/index.d.ts +55 -0
  141. package/dist/components/Popover/index.js +149 -0
  142. package/dist/components/Popup/animations.d.ts +11 -0
  143. package/dist/{src/components → components}/Popup/animations.js +7 -6
  144. package/dist/components/Popup/helpers.d.ts +31 -0
  145. package/dist/components/Popup/helpers.js +204 -0
  146. package/dist/components/Popup/index.d.ts +72 -0
  147. package/dist/components/Popup/index.js +385 -0
  148. package/dist/components/ProgressBar/index.d.ts +14 -0
  149. package/dist/components/ProgressBar/index.js +71 -0
  150. package/dist/components/Radio/index.d.ts +21 -0
  151. package/dist/components/Radio/index.js +202 -0
  152. package/dist/components/RadioGroup/index.d.ts +25 -0
  153. package/dist/components/RadioGroup/index.js +104 -0
  154. package/dist/components/Row/index.d.ts +22 -0
  155. package/dist/components/Row/index.js +43 -0
  156. package/dist/components/SelectInput/index.d.ts +75 -0
  157. package/dist/components/SelectInput/index.js +563 -0
  158. package/dist/components/SelectInputV2/Dropdown.d.ts +23 -0
  159. package/dist/components/SelectInputV2/Dropdown.js +669 -0
  160. package/dist/components/SelectInputV2/DropdownOption.d.ts +8 -0
  161. package/dist/components/SelectInputV2/DropdownOption.js +133 -0
  162. package/dist/components/SelectInputV2/SearchBarDropdown.d.ts +9 -0
  163. package/dist/components/SelectInputV2/SearchBarDropdown.js +123 -0
  164. package/dist/components/SelectInputV2/SelectBar.d.ts +14 -0
  165. package/dist/components/SelectInputV2/SelectBar.js +327 -0
  166. package/dist/components/SelectInputV2/SelectInputProvider.d.ts +41 -0
  167. package/dist/components/SelectInputV2/SelectInputProvider.js +203 -0
  168. package/dist/components/SelectInputV2/findOptionInOptions.d.ts +2 -0
  169. package/dist/components/SelectInputV2/findOptionInOptions.js +12 -0
  170. package/dist/components/SelectInputV2/index.d.ts +115 -0
  171. package/dist/components/SelectInputV2/index.js +146 -0
  172. package/dist/components/SelectInputV2/types.d.ts +38 -0
  173. package/dist/{src/components → components}/SelectInputV2/types.js +4 -2
  174. package/dist/components/SelectableCard/index.d.ts +25 -0
  175. package/dist/components/SelectableCard/index.js +193 -0
  176. package/dist/components/SelectableCardGroup/index.d.ts +23 -0
  177. package/dist/components/SelectableCardGroup/index.js +112 -0
  178. package/dist/components/Separator/index.d.ts +17 -0
  179. package/dist/components/Separator/index.js +76 -0
  180. package/dist/components/Skeleton/Block.d.ts +3 -0
  181. package/dist/components/Skeleton/Block.js +30 -0
  182. package/dist/components/Skeleton/Blocks.d.ts +4 -0
  183. package/dist/components/Skeleton/Blocks.js +28 -0
  184. package/dist/components/Skeleton/BoxWithIcon.d.ts +4 -0
  185. package/dist/components/Skeleton/BoxWithIcon.js +29 -0
  186. package/dist/components/Skeleton/Donut.d.ts +1 -0
  187. package/dist/components/Skeleton/Donut.js +36 -0
  188. package/dist/components/Skeleton/IconSkeleton.d.ts +5 -0
  189. package/dist/components/Skeleton/IconSkeleton.js +12 -0
  190. package/dist/components/Skeleton/Line.d.ts +5 -0
  191. package/dist/components/Skeleton/Line.js +13 -0
  192. package/dist/components/Skeleton/List.d.ts +4 -0
  193. package/dist/components/Skeleton/List.js +29 -0
  194. package/dist/components/Skeleton/Slider.d.ts +3 -0
  195. package/dist/components/Skeleton/Slider.js +26 -0
  196. package/dist/components/Skeleton/Square.d.ts +5 -0
  197. package/dist/components/Skeleton/Square.js +10 -0
  198. package/dist/components/Skeleton/index.d.ts +47 -0
  199. package/dist/components/Skeleton/index.js +86 -0
  200. package/dist/components/Snippet/index.d.ts +23 -0
  201. package/dist/components/Snippet/index.js +171 -0
  202. package/dist/components/Stack/index.d.ts +23 -0
  203. package/dist/components/Stack/index.js +36 -0
  204. package/dist/components/Status/index.d.ts +32 -0
  205. package/dist/components/Status/index.js +57 -0
  206. package/dist/components/StepList/index.d.ts +33 -0
  207. package/dist/components/StepList/index.js +69 -0
  208. package/dist/components/Stepper/index.d.ts +15 -0
  209. package/dist/components/Stepper/index.js +153 -0
  210. package/dist/components/SwitchButton/FocusOverlay.d.ts +8 -0
  211. package/dist/components/SwitchButton/FocusOverlay.js +47 -0
  212. package/dist/components/SwitchButton/index.d.ts +26 -0
  213. package/dist/components/SwitchButton/index.js +140 -0
  214. package/dist/components/Table/Body.d.ts +6 -0
  215. package/dist/components/Table/Body.js +5 -0
  216. package/dist/components/Table/Cell.d.ts +9 -0
  217. package/dist/components/Table/Cell.js +10 -0
  218. package/dist/components/Table/Header.d.ts +6 -0
  219. package/dist/components/Table/Header.js +9 -0
  220. package/dist/components/Table/HeaderCell.d.ts +14 -0
  221. package/dist/components/Table/HeaderCell.js +123 -0
  222. package/dist/components/Table/HeaderRow.d.ts +7 -0
  223. package/dist/components/Table/HeaderRow.js +25 -0
  224. package/dist/components/Table/Row.d.ts +14 -0
  225. package/dist/components/Table/Row.js +85 -0
  226. package/dist/components/Table/SelectBar.d.ts +15 -0
  227. package/dist/components/Table/SelectBar.js +35 -0
  228. package/dist/components/Table/SkeletonRows.d.ts +7 -0
  229. package/dist/components/Table/SkeletonRows.js +22 -0
  230. package/dist/components/Table/TableContext.d.ts +27 -0
  231. package/dist/components/Table/TableContext.js +103 -0
  232. package/dist/components/Table/index.d.ts +60 -0
  233. package/dist/components/Table/index.js +81 -0
  234. package/dist/components/Tabs/Tab.d.ts +20 -0
  235. package/dist/components/Tabs/Tab.js +170 -0
  236. package/dist/components/Tabs/TabMenu.d.ts +8 -0
  237. package/dist/components/Tabs/TabMenu.js +63 -0
  238. package/dist/components/Tabs/TabMenuItem.d.ts +20 -0
  239. package/dist/components/Tabs/TabMenuItem.js +39 -0
  240. package/dist/components/Tabs/TabsContext.d.ts +8 -0
  241. package/dist/components/Tabs/TabsContext.js +9 -0
  242. package/dist/components/Tabs/index.d.ts +50 -0
  243. package/dist/components/Tabs/index.js +137 -0
  244. package/dist/components/Tag/index.d.ts +26 -0
  245. package/dist/components/Tag/index.js +153 -0
  246. package/dist/components/TagInput/index.d.ts +55 -0
  247. package/dist/components/TagInput/index.js +316 -0
  248. package/dist/components/TagList/index.d.ts +37 -0
  249. package/dist/components/TagList/index.js +103 -0
  250. package/dist/components/Text/index.d.ts +40 -0
  251. package/dist/components/Text/index.js +107 -0
  252. package/dist/components/TextArea/index.d.ts +50 -0
  253. package/dist/components/TextArea/index.js +226 -0
  254. package/dist/components/TextInput/index.d.ts +75 -0
  255. package/dist/components/TextInput/index.js +472 -0
  256. package/dist/components/TextInputV2/index.d.ts +30 -0
  257. package/dist/components/TextInputV2/index.js +314 -0
  258. package/dist/components/TimeInput/index.d.ts +25 -0
  259. package/dist/components/TimeInput/index.js +199 -0
  260. package/dist/components/Toaster/index.d.ts +46 -0
  261. package/dist/components/Toaster/index.js +131 -0
  262. package/dist/components/Toaster/react-toastify.css.js +4 -0
  263. package/dist/components/Toggle/index.d.ts +34 -0
  264. package/dist/components/Toggle/index.js +196 -0
  265. package/dist/components/ToggleGroup/index.d.ts +24 -0
  266. package/dist/components/ToggleGroup/index.js +87 -0
  267. package/dist/components/Tooltip/index.d.ts +9 -0
  268. package/dist/components/Tooltip/index.js +47 -0
  269. package/dist/components/VerificationCode/index.d.ts +36 -0
  270. package/dist/components/VerificationCode/index.js +222 -0
  271. package/dist/components/index.d.ts +75 -0
  272. package/dist/helpers/isJSON.d.ts +2 -0
  273. package/dist/{src/helpers → helpers}/isJSON.js +4 -3
  274. package/dist/helpers/jestMockMatchMedia.d.ts +6 -0
  275. package/dist/helpers/keycode.d.ts +3 -0
  276. package/dist/helpers/legend.d.ts +2 -0
  277. package/dist/helpers/legend.js +14 -0
  278. package/dist/helpers/numbers.d.ts +2 -0
  279. package/dist/helpers/recursivelyGetChildrenString.d.ts +3 -0
  280. package/dist/helpers/recursivelyGetChildrenString.js +15 -0
  281. package/dist/hooks/useIsOverflowing.d.ts +5 -0
  282. package/dist/hooks/useIsOverflowing.js +23 -0
  283. package/dist/index.d.ts +4 -3693
  284. package/dist/index.js +187 -0
  285. package/dist/mocks/list.d.ts +12 -0
  286. package/dist/theme/index.d.ts +1573 -0
  287. package/dist/theme/index.js +30 -0
  288. package/dist/types.d.ts +6 -0
  289. package/dist/utils/animations.d.ts +27 -0
  290. package/dist/{src/utils → utils}/animations.js +30 -4
  291. package/dist/utils/capitalize.d.ts +2 -0
  292. package/dist/utils/capitalize.js +4 -0
  293. package/dist/utils/ids.d.ts +1 -0
  294. package/dist/utils/ids.js +6 -0
  295. package/dist/utils/index.d.ts +6 -0
  296. package/dist/utils/normalize.d.ts +2 -0
  297. package/dist/{src/utils → utils}/normalize.js +4 -3
  298. package/dist/utils/orderBy.d.ts +2 -0
  299. package/dist/utils/responsive/Breakpoint.d.ts +9 -0
  300. package/dist/utils/responsive/Breakpoint.js +13 -0
  301. package/dist/utils/responsive/index.d.ts +2 -0
  302. package/dist/utils/responsive/utilities.d.ts +3 -0
  303. package/dist/{src/utils → utils}/responsive/utilities.js +9 -6
  304. package/package.json +23 -13
  305. package/dist/react-datepicker/dist/react-datepicker.min.css.js +0 -3
  306. package/dist/react-toastify/dist/ReactToastify.min.css.js +0 -3
  307. package/dist/src/components/ActionBar/index.js +0 -40
  308. package/dist/src/components/Alert/index.js +0 -133
  309. package/dist/src/components/Avatar/index.js +0 -74
  310. package/dist/src/components/Badge/index.js +0 -116
  311. package/dist/src/components/Banner/assets/default-image-small.svg.js +0 -5
  312. package/dist/src/components/Banner/assets/default-image.svg.js +0 -5
  313. package/dist/src/components/Banner/index.js +0 -159
  314. package/dist/src/components/BarChart/Tooltip.js +0 -48
  315. package/dist/src/components/BarChart/index.js +0 -95
  316. package/dist/src/components/BarStack/index.js +0 -136
  317. package/dist/src/components/Breadcrumbs/index.js +0 -82
  318. package/dist/src/components/Bullet/index.js +0 -98
  319. package/dist/src/components/Button/index.js +0 -311
  320. package/dist/src/components/Card/index.js +0 -67
  321. package/dist/src/components/Carousel/index.js +0 -128
  322. package/dist/src/components/Checkbox/index.js +0 -316
  323. package/dist/src/components/CheckboxGroup/index.js +0 -143
  324. package/dist/src/components/CopyButton/index.js +0 -37
  325. package/dist/src/components/DateInput/index.js +0 -242
  326. package/dist/src/components/Dialog/Context.js +0 -12
  327. package/dist/src/components/Dialog/index.js +0 -88
  328. package/dist/src/components/Dialog/subComponents/Button.js +0 -21
  329. package/dist/src/components/Dialog/subComponents/Buttons.js +0 -14
  330. package/dist/src/components/Dialog/subComponents/CancelButton.js +0 -14
  331. package/dist/src/components/Dialog/subComponents/Stack.js +0 -11
  332. package/dist/src/components/Dialog/subComponents/Text.js +0 -12
  333. package/dist/src/components/EmptyState/index.js +0 -112
  334. package/dist/src/components/Expandable/index.js +0 -96
  335. package/dist/src/components/GlobalAlert/GlobalAlertLink.js +0 -38
  336. package/dist/src/components/GlobalAlert/index.js +0 -82
  337. package/dist/src/components/LineChart/CustomLegend.js +0 -138
  338. package/dist/src/components/LineChart/Tooltip.js +0 -43
  339. package/dist/src/components/LineChart/helpers.js +0 -40
  340. package/dist/src/components/LineChart/index.js +0 -131
  341. package/dist/src/components/Link/index.js +0 -147
  342. package/dist/src/components/List/Body.js +0 -16
  343. package/dist/src/components/List/Cell.js +0 -43
  344. package/dist/src/components/List/HeaderCell.js +0 -90
  345. package/dist/src/components/List/HeaderRow.js +0 -43
  346. package/dist/src/components/List/ListContext.js +0 -138
  347. package/dist/src/components/List/Row.js +0 -185
  348. package/dist/src/components/List/SelectBar.js +0 -48
  349. package/dist/src/components/List/SkeletonRows.js +0 -53
  350. package/dist/src/components/List/index.js +0 -75
  351. package/dist/src/components/Loader/index.js +0 -100
  352. package/dist/src/components/Menu/Item.js +0 -112
  353. package/dist/src/components/Menu/index.js +0 -129
  354. package/dist/src/components/MenuV2/Group.js +0 -25
  355. package/dist/src/components/MenuV2/Item.js +0 -139
  356. package/dist/src/components/MenuV2/index.js +0 -116
  357. package/dist/src/components/Meter/index.js +0 -76
  358. package/dist/src/components/Modal/Dialog.js +0 -182
  359. package/dist/src/components/Modal/index.js +0 -113
  360. package/dist/src/components/Notice/index.js +0 -34
  361. package/dist/src/components/Notification/index.js +0 -77
  362. package/dist/src/components/NumberInput/index.js +0 -299
  363. package/dist/src/components/NumberInputV2/index.js +0 -284
  364. package/dist/src/components/Pagination/index.js +0 -117
  365. package/dist/src/components/PasswordCheck/index.js +0 -41
  366. package/dist/src/components/PasswordStrengthMeter/index.js +0 -102
  367. package/dist/src/components/PieChart/Legends.js +0 -138
  368. package/dist/src/components/PieChart/Tooltip.js +0 -61
  369. package/dist/src/components/PieChart/index.js +0 -125
  370. package/dist/src/components/Popover/index.js +0 -144
  371. package/dist/src/components/Popup/helpers.js +0 -252
  372. package/dist/src/components/Popup/index.js +0 -363
  373. package/dist/src/components/ProgressBar/index.js +0 -57
  374. package/dist/src/components/Radio/index.js +0 -157
  375. package/dist/src/components/RadioGroup/index.js +0 -131
  376. package/dist/src/components/Row/index.js +0 -41
  377. package/dist/src/components/SelectInput/index.js +0 -610
  378. package/dist/src/components/SelectInputV2/Dropdown.js +0 -594
  379. package/dist/src/components/SelectInputV2/DropdownOption.js +0 -130
  380. package/dist/src/components/SelectInputV2/SearchBarDropdown.js +0 -128
  381. package/dist/src/components/SelectInputV2/SelectBar.js +0 -282
  382. package/dist/src/components/SelectInputV2/SelectInputProvider.js +0 -169
  383. package/dist/src/components/SelectInputV2/findOptionInOptions.js +0 -11
  384. package/dist/src/components/SelectInputV2/index.js +0 -137
  385. package/dist/src/components/SelectableCard/index.js +0 -175
  386. package/dist/src/components/SelectableCardGroup/index.js +0 -141
  387. package/dist/src/components/Separator/index.js +0 -73
  388. package/dist/src/components/Skeleton/Block.js +0 -35
  389. package/dist/src/components/Skeleton/Blocks.js +0 -34
  390. package/dist/src/components/Skeleton/BoxWithIcon.js +0 -32
  391. package/dist/src/components/Skeleton/Donut.js +0 -55
  392. package/dist/src/components/Skeleton/IconSkeleton.js +0 -19
  393. package/dist/src/components/Skeleton/Line.js +0 -13
  394. package/dist/src/components/Skeleton/List.js +0 -51
  395. package/dist/src/components/Skeleton/Slider.js +0 -36
  396. package/dist/src/components/Skeleton/Square.js +0 -9
  397. package/dist/src/components/Skeleton/index.js +0 -82
  398. package/dist/src/components/Snippet/index.js +0 -200
  399. package/dist/src/components/Stack/index.js +0 -29
  400. package/dist/src/components/Status/index.js +0 -74
  401. package/dist/src/components/StepList/index.js +0 -69
  402. package/dist/src/components/Stepper/index.js +0 -150
  403. package/dist/src/components/SwitchButton/FocusOverlay.js +0 -37
  404. package/dist/src/components/SwitchButton/index.js +0 -108
  405. package/dist/src/components/Table/Body.js +0 -9
  406. package/dist/src/components/Table/Cell.js +0 -21
  407. package/dist/src/components/Table/Header.js +0 -15
  408. package/dist/src/components/Table/HeaderCell.js +0 -103
  409. package/dist/src/components/Table/HeaderRow.js +0 -32
  410. package/dist/src/components/Table/Row.js +0 -89
  411. package/dist/src/components/Table/SelectBar.js +0 -48
  412. package/dist/src/components/Table/SkeletonRows.js +0 -51
  413. package/dist/src/components/Table/TableContext.js +0 -90
  414. package/dist/src/components/Table/index.js +0 -82
  415. package/dist/src/components/Tabs/Tab.js +0 -138
  416. package/dist/src/components/Tabs/TabMenu.js +0 -59
  417. package/dist/src/components/Tabs/TabMenuItem.js +0 -36
  418. package/dist/src/components/Tabs/TabsContext.js +0 -6
  419. package/dist/src/components/Tabs/index.js +0 -117
  420. package/dist/src/components/Tag/index.js +0 -169
  421. package/dist/src/components/TagInput/index.js +0 -309
  422. package/dist/src/components/TagList/index.js +0 -106
  423. package/dist/src/components/Text/index.js +0 -107
  424. package/dist/src/components/TextArea/index.js +0 -210
  425. package/dist/src/components/TextInput/index.js +0 -451
  426. package/dist/src/components/TextInputV2/index.js +0 -289
  427. package/dist/src/components/TimeInput/index.js +0 -37
  428. package/dist/src/components/Toaster/index.js +0 -131
  429. package/dist/src/components/Toggle/index.js +0 -160
  430. package/dist/src/components/ToggleGroup/index.js +0 -122
  431. package/dist/src/components/Tooltip/index.js +0 -55
  432. package/dist/src/components/VerificationCode/index.js +0 -222
  433. package/dist/src/helpers/legend.js +0 -13
  434. package/dist/src/helpers/recursivelyGetChildrenString.js +0 -11
  435. package/dist/src/hooks/useIsOverflowing.js +0 -34
  436. package/dist/src/index.js +0 -77
  437. package/dist/src/theme/index.js +0 -29
  438. package/dist/src/utils/capitalize.js +0 -3
  439. package/dist/src/utils/ids.js +0 -7
  440. package/dist/src/utils/responsive/Breakpoint.js +0 -12
@@ -1,210 +0,0 @@
1
- import _styled from '@emotion/styled/base';
2
- import { Icon } from '@ultraviolet/icons';
3
- import { forwardRef, useId, useMemo } from 'react';
4
- import { Button, SIZE_HEIGHT } from '../Button/index.js';
5
- import { Row } from '../Row/index.js';
6
- import { Stack } from '../Stack/index.js';
7
- import { Text } from '../Text/index.js';
8
- import { Tooltip } from '../Tooltip/index.js';
9
- import { jsxs, jsx } from '@emotion/react/jsx-runtime';
10
-
11
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
12
- const STATE_ICON_SIZE = 16;
13
- const StyledTextAreaWrapper = /*#__PURE__*/_styled("div", {
14
- target: "enu776d2"
15
- })(process.env.NODE_ENV === "production" ? {
16
- name: "8k1832",
17
- styles: "position:relative;display:flex"
18
- } : {
19
- name: "8k1832",
20
- styles: "position:relative;display:flex",
21
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
- });
23
- const StyledTextAreaAbsoluteStack = /*#__PURE__*/_styled(Stack, {
24
- target: "enu776d1"
25
- })("position:absolute;top:", ({
26
- theme
27
- }) => theme.space['1.5'], ";right:", ({
28
- theme
29
- }) => theme.space['1'], ";");
30
- const StyledTextArea = /*#__PURE__*/_styled('textarea', {
31
- shouldForwardProp: prop => !['hasSentimentIcon', 'isClearable'].includes(prop),
32
- target: "enu776d0"
33
- })("width:100%;resize:vertical;background:", ({
34
- theme
35
- }) => theme.colors.neutral.background, ";border:1px solid ", ({
36
- theme
37
- }) => theme.colors.neutral.border, ";color:", ({
38
- theme
39
- }) => theme.colors.neutral.text, ";&::placeholder{color:", ({
40
- theme
41
- }) => theme.colors.neutral.textWeak, ";}border-radius:", ({
42
- theme
43
- }) => theme.radii.default, ";padding:", ({
44
- theme
45
- }) => `${theme.space['1.5']} ${theme.space['1']} ${theme.space['1.5']} ${theme.space['2']}`, ";padding-right:", ({
46
- theme,
47
- isClearable,
48
- hasSentimentIcon
49
- }) => /* including 1 optional if both element is visible + 1 because content is absolute 1space unit from right */
50
- `calc(${theme.space[isClearable && hasSentimentIcon ? '4' : '3']} + ${isClearable ? `${SIZE_HEIGHT.xsmall}px` : '0px'} + ${hasSentimentIcon ? `${STATE_ICON_SIZE}px` : '0px'})`, ";&[data-success='true']{border-color:", ({
51
- theme
52
- }) => theme.colors.success.border, ";}&[data-error='true']{border-color:", ({
53
- theme
54
- }) => theme.colors.danger.border, ";}&[data-readOnly='true']{background:", ({
55
- theme
56
- }) => theme.colors.neutral.backgroundWeak, ";border-color:", ({
57
- theme
58
- }) => theme.colors.neutral.border, ";}&[data-disabled='true']{background:", ({
59
- theme
60
- }) => theme.colors.neutral.backgroundDisabled, ";border-color:", ({
61
- theme
62
- }) => theme.colors.neutral.borderDisabled, ";&::placeholder{color:", ({
63
- theme
64
- }) => theme.colors.neutral.textWeakDisabled, ";}}&:not([data-disabled='true']):hover{&:hover{border-color:", ({
65
- theme
66
- }) => theme.colors.primary.border, ";}&:focus{outline:none;border-color:", ({
67
- theme
68
- }) => theme.colors.primary.border, ";box-shadow:", ({
69
- theme
70
- }) => theme.shadows.focusPrimary, ";}}");
71
- /**
72
- * This component offers an extended textarea HTML
73
- */
74
- const TextArea = /*#__PURE__*/forwardRef(({
75
- id,
76
- className,
77
- tabIndex,
78
- value,
79
- onChange,
80
- placeholder,
81
- rows = 3,
82
- disabled = false,
83
- readOnly = false,
84
- success,
85
- error,
86
- helper,
87
- minLength,
88
- maxLength,
89
- tooltip,
90
- label,
91
- autoFocus,
92
- required = false,
93
- 'data-testid': dataTestId,
94
- name,
95
- onFocus,
96
- onBlur,
97
- clearable = false,
98
- labelDescription
99
- }, ref) => {
100
- const localId = useId();
101
- const sentiment = useMemo(() => {
102
- if (error) {
103
- return 'danger';
104
- }
105
- if (success) {
106
- return 'success';
107
- }
108
- return 'neutral';
109
- }, [error, success]);
110
- const notice = success || error || helper;
111
- const computedClearable = clearable && !!value;
112
- return jsxs(Stack, {
113
- gap: "0.5",
114
- className: className,
115
- children: [label || labelDescription ? jsxs(Stack, {
116
- direction: "row",
117
- gap: "1",
118
- alignItems: "center",
119
- children: [label ? jsxs(Stack, {
120
- direction: "row",
121
- gap: "0.5",
122
- alignItems: "start",
123
- children: [jsx(Text, {
124
- as: "label",
125
- variant: "bodyStrong",
126
- sentiment: "neutral",
127
- htmlFor: id ?? localId,
128
- children: label
129
- }), required ? jsx(Icon, {
130
- name: "asterisk",
131
- color: "danger",
132
- size: 8
133
- }) : null]
134
- }) : null, labelDescription ?? null]
135
- }) : null, jsx(Tooltip, {
136
- text: tooltip,
137
- children: jsxs(StyledTextAreaWrapper, {
138
- children: [jsx(StyledTextArea, {
139
- "aria-invalid": !!error,
140
- id: id ?? localId,
141
- tabIndex: tabIndex,
142
- autoFocus: autoFocus,
143
- disabled: disabled,
144
- rows: rows,
145
- ref: ref,
146
- value: value,
147
- onChange: event => {
148
- onChange(event.currentTarget.value);
149
- },
150
- hasSentimentIcon: !!success || !!error,
151
- "data-disabled": disabled,
152
- "data-readOnly": readOnly,
153
- "data-success": !!success,
154
- "data-error": !!error,
155
- isClearable: !!computedClearable,
156
- minLength: minLength,
157
- maxLength: maxLength,
158
- placeholder: placeholder,
159
- "data-testid": dataTestId,
160
- name: name,
161
- onFocus: onFocus,
162
- onBlur: onBlur
163
- }), jsxs(StyledTextAreaAbsoluteStack, {
164
- direction: "row",
165
- alignItems: "center",
166
- gap: "1",
167
- children: [computedClearable ? jsx(Button, {
168
- "aria-label": "clear value",
169
- variant: "ghost",
170
- size: "xsmall",
171
- icon: "close",
172
- onClick: () => {
173
- onChange('');
174
- },
175
- sentiment: "neutral"
176
- }) : null, success ? jsx(Icon, {
177
- name: "checkbox-circle-outline",
178
- color: "success",
179
- size: STATE_ICON_SIZE
180
- }) : null, error ? jsx(Icon, {
181
- name: "alert",
182
- color: "danger",
183
- variant: "outlined"
184
- }) : null]
185
- })]
186
- })
187
- }), notice || maxLength ? jsxs(Row, {
188
- templateColumns: "minmax(0, 1fr) min-content",
189
- gap: "1",
190
- children: [jsxs("div", {
191
- children: [error || success || typeof helper === 'string' ? jsx(Text, {
192
- as: "p",
193
- variant: "caption",
194
- sentiment: sentiment,
195
- prominence: !error && !success ? 'weak' : 'default',
196
- disabled: disabled,
197
- children: error || success || helper
198
- }) : null, !error && !success && typeof helper !== 'string' && helper ? helper : null]
199
- }), maxLength ? jsxs(Text, {
200
- as: "div",
201
- sentiment: "neutral",
202
- prominence: "weak",
203
- variant: "caption",
204
- children: [value?.length ?? 0, "/", maxLength]
205
- }) : null]
206
- }) : null]
207
- });
208
- });
209
-
210
- export { TextArea };
@@ -1,451 +0,0 @@
1
- import _styled from '@emotion/styled/base';
2
- import { css } from '@emotion/react';
3
- import randomName from '@scaleway/random-name';
4
- import { Icon } from '@ultraviolet/icons';
5
- import { forwardRef, useRef, useState, useCallback, useImperativeHandle, useEffect, useMemo } from 'react';
6
- import { Button } from '../Button/index.js';
7
- import { Expandable } from '../Expandable/index.js';
8
- import { Notice } from '../Notice/index.js';
9
- import { Separator } from '../Separator/index.js';
10
- import { Stack } from '../Stack/index.js';
11
- import { Text } from '../Text/index.js';
12
- import { jsx, jsxs } from '@emotion/react/jsx-runtime';
13
-
14
- function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
15
- const inputSizes = {
16
- medium: {
17
- default: `
18
- height: 48px;
19
- padding-left: 8px;
20
- padding-right: 20px;
21
- padding-top: 14px;
22
- `,
23
- full: `
24
- padding: 8px;
25
- `
26
- },
27
- small: {
28
- default: `
29
- height: 30px;
30
- padding-left: 8px;
31
- padding-right: 8px;
32
- padding-top: 14px;
33
- font-size: 14px;
34
- `,
35
- full: `
36
- padding: 4px 8px;
37
- `
38
- }
39
- };
40
- const StyledSeparator = /*#__PURE__*/_styled(Separator, {
41
- target: "el3h3g98"
42
- })("margin:1px 0px;height:calc(100% - 2px);background-color:", ({
43
- theme: {
44
- colors
45
- }
46
- }) => colors.neutral.backgroundStrong, ";");
47
- var _ref2 = process.env.NODE_ENV === "production" ? {
48
- name: "176jwhy",
49
- styles: "pointer-events:auto;>button{box-shadow:none!important;}"
50
- } : {
51
- name: "176jwhy",
52
- styles: "pointer-events:auto;>button{box-shadow:none!important;}",
53
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
54
- };
55
- const StyledRightElement = /*#__PURE__*/_styled('div', {
56
- shouldForwardProp: prop => !['edit', 'touchable'].includes(prop),
57
- target: "el3h3g97"
58
- })(({
59
- theme: {
60
- colors,
61
- space
62
- }
63
- }) => /*#__PURE__*/css("pointer-events:none;position:absolute;right:0;bottom:0;top:0;padding:0 ", space['1'], ";display:flex;gap:", space['1'], ";align-items:center;transition:transform 150ms,color 150ms;color:", colors.neutral.textWeak, ";&:hover,&:focus-within{color:", colors.neutral.textWeakHover, ";}"), " ", ({
64
- touchable
65
- }) => touchable && _ref2, ";");
66
- var _ref = process.env.NODE_ENV === "production" ? {
67
- name: "z8qxmc",
68
- styles: "transform:translate(-9.6%, -3px) scale(0.8)"
69
- } : {
70
- name: "z8qxmc",
71
- styles: "transform:translate(-9.6%, -3px) scale(0.8)",
72
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
73
- };
74
- const StyledLabel = /*#__PURE__*/_styled('label', {
75
- shouldForwardProp: prop => !['edit', 'error', 'resizable', 'fillAvailable'].includes(prop),
76
- target: "el3h3g96"
77
- })("display:block;position:absolute;left:0;top:0;padding-left:8px;padding-right:8px;pointer-events:none;color:", ({
78
- theme: {
79
- colors
80
- }
81
- }) => colors.neutral.textWeak, ";white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;height:48px;font-size:", ({
82
- theme
83
- }) => theme.typography.bodySmall, ";transition:transform 150ms;transform:translate(0, 12px) scale(1);", ({
84
- edit
85
- }) => edit && _ref, " ", ({
86
- disabled,
87
- theme: {
88
- colors
89
- }
90
- }) => disabled && /*#__PURE__*/css("color:", colors.neutral.textDisabled, ";"), " ", ({
91
- readOnly,
92
- theme: {
93
- colors
94
- }
95
- }) => readOnly && /*#__PURE__*/css("color:", colors.neutral.textDisabled, ";"), " ", ({
96
- error,
97
- theme: {
98
- colors
99
- }
100
- }) => error && /*#__PURE__*/css("color:", colors.danger.text, ";"), ";");
101
- const StyledRelativeDiv = /*#__PURE__*/_styled("div", {
102
- target: "el3h3g95"
103
- })(process.env.NODE_ENV === "production" ? {
104
- name: "bjn8wh",
105
- styles: "position:relative"
106
- } : {
107
- name: "bjn8wh",
108
- styles: "position:relative",
109
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
110
- });
111
- const StyledError = /*#__PURE__*/_styled("div", {
112
- target: "el3h3g94"
113
- })("font-size:12px;color:", ({
114
- theme
115
- }) => theme.colors.danger.text, ";padding-top:", ({
116
- theme
117
- }) => theme.space['0.25'], ";");
118
- const StyledNotice = /*#__PURE__*/_styled(Notice, {
119
- target: "el3h3g93"
120
- })("margin-top:", ({
121
- theme
122
- }) => theme.space['0.5'], ";");
123
- const StyledInput = /*#__PURE__*/_styled('input', {
124
- shouldForwardProp: prop => !['as', 'error', 'fillAvailable', 'hasLabel', 'isPlaceholderVisible', 'multiline', 'resizable', 'inputSize', 'paddingRightFactor', 'rightComponentLength', 'unit'].includes(prop),
125
- target: "el3h3g92"
126
- })("transition:border-color 0.2s ease,box-shadow 0.2s ease;appearance:none;background-color:", ({
127
- theme: {
128
- colors
129
- }
130
- }) => colors.neutral.background, ";background-image:none;border:1px solid ", ({
131
- theme: {
132
- colors
133
- }
134
- }) => colors.neutral.border, ";border-radius:", ({
135
- theme: {
136
- radii
137
- }
138
- }) => radii.default, ";color:", ({
139
- theme: {
140
- colors
141
- }
142
- }) => colors.neutral.text, ";display:block;max-width:100%;outline:none;position:relative;width:100%;padding-left:", ({
143
- theme
144
- }) => theme.space['1'], ";padding-right:", ({
145
- theme
146
- }) => theme.space['1'], ";padding-top:14px;font-size:16px;line-height:24px;&::placeholder{color:", ({
147
- theme: {
148
- colors
149
- }
150
- }) => colors.neutral.textWeak, ";opacity:0;}&:hover,&:focus{border-color:", ({
151
- theme: {
152
- colors
153
- }
154
- }) => colors.primary.borderHover, ";}&:focus{box-shadow:", ({
155
- theme: {
156
- shadows
157
- }
158
- }) => shadows.focusPrimary, ";border-color:", ({
159
- theme: {
160
- colors
161
- }
162
- }) => colors.primary.borderHover, ";}", ({
163
- isPlaceholderVisible
164
- }) => isPlaceholderVisible && `&::placeholder {
165
- opacity: 1;
166
- }`, " ", ({
167
- disabled,
168
- theme: {
169
- colors
170
- }
171
- }) => disabled && `cursor: default;
172
- pointer-events: none;
173
- background-color: ${colors.neutral.backgroundDisabled};
174
- border-color: ${colors.neutral.borderDisabled};
175
- color: ${colors.neutral.textDisabled};`, " ", ({
176
- readOnly,
177
- theme: {
178
- colors
179
- }
180
- }) => readOnly && `background-color: ${colors.neutral.backgroundDisabled};
181
- border-color: ${colors.neutral.borderDisabled};
182
- color: ${colors.neutral.text};`, " ", ({
183
- inputSize
184
- }) => inputSizes[inputSize]?.default, " ", ({
185
- inputSize,
186
- hasLabel
187
- }) => !!inputSize && !hasLabel && inputSizes[inputSize]?.full, " ", ({
188
- error,
189
- theme: {
190
- colors,
191
- shadows
192
- }
193
- }) => error && `border-color: ${colors.danger.border};
194
-
195
- &:hover,
196
- &:focus {
197
- border-color: ${colors.danger.borderHover};
198
- }
199
-
200
- &:focus {
201
- box-shadow: ${shadows.focusDanger};
202
- border-color: ${colors.danger.borderHover};
203
- }`, " ", ({
204
- multiline,
205
- resizable,
206
- fillAvailable
207
- }) => multiline && `
208
- padding-top: 20px;
209
- height: ${fillAvailable ? '100%' : 'initial'};
210
- resize: ${resizable === false ? 'none' : 'vertical'};
211
- `, " ", ({
212
- multiline,
213
- hasLabel,
214
- theme
215
- }) => multiline && !hasLabel && `
216
- padding-top: ${theme.space['1']};
217
- `, " ", ({
218
- paddingRightFactor,
219
- rightComponentLength,
220
- unit,
221
- theme
222
- }) => paddingRightFactor > 0 && `
223
- padding-right: calc(${unit ? `${unit.length} * ${theme.space['1']} + ` : ''}${paddingRightFactor + (unit ? rightComponentLength - 1 : rightComponentLength)} * ${theme.space['4']});
224
- `, ";");
225
- const RightComponent = /*#__PURE__*/_styled(Stack, {
226
- target: "el3h3g91"
227
- })(process.env.NODE_ENV === "production" ? {
228
- name: "9bmev",
229
- styles: "min-width:24px"
230
- } : {
231
- name: "9bmev",
232
- styles: "min-width:24px",
233
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
234
- });
235
- const UnitLabel = /*#__PURE__*/_styled(Text, {
236
- target: "el3h3g90"
237
- })("padding:", ({
238
- theme
239
- }) => theme.space['1'], " 0;line-height:18px;");
240
-
241
- /**
242
- * TextInput component allows users to input text, with options for customization and validation.
243
- * It supports various input types and should be appropriately sized with clear labeling.
244
- */
245
- const TextInput = /*#__PURE__*/forwardRef(({
246
- 'data-testid': dataTestId,
247
- ariaControls,
248
- autoComplete = 'on',
249
- autoFocus,
250
- className,
251
- cols,
252
- defaultValue,
253
- disabled,
254
- edit: forceEdit,
255
- error,
256
- fillAvailable,
257
- generated,
258
- height,
259
- id,
260
- label,
261
- multiline,
262
- name,
263
- notice,
264
- noTopLabel = false,
265
- onBlur,
266
- onChange,
267
- onFocus,
268
- onKeyUp,
269
- onKeyDown,
270
- placeholder,
271
- random,
272
- readOnly,
273
- required,
274
- resizable,
275
- rows,
276
- size = 'medium',
277
- tabIndex,
278
- type = 'text',
279
- unit,
280
- valid,
281
- value,
282
- wrap,
283
- inputProps,
284
- min,
285
- max
286
- }, ref) => {
287
- const controlRef = useRef(null);
288
- const [visited, setVisited] = useState(false);
289
- const [passwordVisible, setPasswordVisible] = useState(false);
290
- const togglePasswordVisibility = useCallback(() => setPasswordVisible(x => !x), []);
291
-
292
- // Forward ref to parent ref
293
- useImperativeHandle(ref, () => controlRef, []);
294
-
295
- // Focus when password is visible
296
- useEffect(() => {
297
- if (passwordVisible) {
298
- controlRef?.current?.focus();
299
- }
300
- }, [passwordVisible]);
301
- const handlePassVisibilityClick = useCallback(() => togglePasswordVisibility(), [togglePasswordVisibility]);
302
- const randomize = useCallback(() => onChange?.(randomName(random)), [onChange, random]);
303
- const handleClickRandomize = useCallback(() => randomize(), [randomize]);
304
- const handleFocus = useCallback(event => {
305
- if (!visited && !readOnly) {
306
- setVisited(true);
307
- }
308
- if (onFocus) {
309
- onFocus(event);
310
- }
311
- }, [visited, readOnly, onFocus]);
312
- const handleChange = useCallback(event => onChange?.(event.target.value), [onChange]);
313
- const isPassToggleable = type === 'toggleable-password';
314
- const hasLabel = !!label && !noTopLabel && size === 'medium';
315
- const edit = hasLabel && (forceEdit || visited || value || error || generated);
316
- const isPlaceholderVisible = !hasLabel || !!edit;
317
- const hasRightElement = !!(valid !== undefined || isPassToggleable || random || unit);
318
- const getType = () => {
319
- if (isPassToggleable) {
320
- return passwordVisible || generated ? 'text' : 'password';
321
- }
322
- return multiline ? undefined : type;
323
- };
324
- const inputSize = size;
325
- const rightComponentsArray = useMemo(() => {
326
- const rightComponents = [];
327
- if (isPassToggleable && !generated) {
328
- rightComponents.push(jsx(Button, {
329
- "data-testid": dataTestId ? `${dataTestId}-visibility-button` : undefined,
330
- "aria-label": passwordVisible ? 'hide' : 'show',
331
- onClick: handlePassVisibilityClick,
332
- variant: "ghost",
333
- sentiment: "neutral",
334
- icon: passwordVisible ? 'eye-off' : 'eye',
335
- size: "small"
336
- }, "password-visible"));
337
- }
338
- if (random) {
339
- rightComponents.push(jsx(Button, {
340
- "data-testid": dataTestId ? `${dataTestId}-randomize-button` : undefined,
341
- "aria-label": "randomize",
342
- onClick: handleClickRandomize,
343
- disabled: disabled,
344
- icon: "auto-fix",
345
- variant: "ghost",
346
- sentiment: "neutral",
347
- size: "small"
348
- }, "random"));
349
- }
350
- if (valid === false || valid === true) {
351
- rightComponents.push(jsx(Icon, {
352
- name: !valid ? 'close' : 'check',
353
- color: !valid ? 'danger' : 'success',
354
- size: 20
355
- }, "valid"));
356
- }
357
- if (unit) {
358
- rightComponents.push(jsx(UnitLabel, {
359
- variant: "bodySmall",
360
- as: "p",
361
- prominence: "weak",
362
- children: unit
363
- }, "unit"));
364
- }
365
- return rightComponents;
366
- }, [disabled, generated, handleClickRandomize, handlePassVisibilityClick, isPassToggleable, passwordVisible, random, unit, valid, dataTestId]);
367
- const showSeparator = required && hasRightElement || unit;
368
- const paddingRightFactor = (required ? 1 : 0) + (showSeparator ? 0.5 : 0);
369
- return jsxs("div", {
370
- className: className,
371
- children: [jsxs(StyledRelativeDiv, {
372
- children: [jsx(StyledInput, {
373
- "aria-controls": ariaControls,
374
- "aria-label": label || undefined,
375
- "aria-labelledby": hasLabel ? ariaControls : undefined,
376
- as: multiline ? 'textarea' : 'input',
377
- autoComplete: autoComplete,
378
- autoFocus: autoFocus,
379
- cols: cols,
380
- "data-testid": dataTestId,
381
- defaultValue: defaultValue,
382
- disabled: disabled,
383
- error: !!error,
384
- fillAvailable: fillAvailable,
385
- hasLabel: hasLabel,
386
- paddingRightFactor: paddingRightFactor,
387
- rightComponentLength: rightComponentsArray.length,
388
- unit: unit,
389
- id: id,
390
- inputSize: inputSize,
391
- isPlaceholderVisible: isPlaceholderVisible,
392
- multiline: multiline,
393
- name: name,
394
- onBlur: onBlur,
395
- onChange: handleChange,
396
- onFocus: handleFocus,
397
- onKeyUp: onKeyUp,
398
- onKeyDown: onKeyDown,
399
- placeholder: placeholder,
400
- readOnly: readOnly,
401
- ref: controlRef,
402
- resizable: resizable,
403
- rows: rows,
404
- style: {
405
- height
406
- },
407
- tabIndex: tabIndex,
408
- type: getType(),
409
- value: value === null ? '' : value,
410
- wrap: wrap,
411
- min: min,
412
- max: max,
413
- required: required,
414
- ...inputProps
415
- }), hasLabel && jsx(StyledLabel, {
416
- edit: !!edit,
417
- disabled: disabled,
418
- readOnly: readOnly,
419
- error: !!error,
420
- id: ariaControls,
421
- htmlFor: id,
422
- "aria-live": "assertive",
423
- children: label
424
- }), hasRightElement || required ? jsxs(StyledRightElement, {
425
- edit: !!edit,
426
- touchable: isPassToggleable || !!random,
427
- children: [required ? jsx(Icon, {
428
- name: "asterisk",
429
- color: "danger",
430
- size: 10
431
- }) : null, showSeparator ? jsx(StyledSeparator, {
432
- direction: "vertical"
433
- }) : null, rightComponentsArray.length > 0 ? jsx(RightComponent, {
434
- justifyContent: "center",
435
- direction: "row",
436
- alignItems: "center",
437
- children: rightComponentsArray
438
- }) : null]
439
- }) : null]
440
- }), jsx(Expandable, {
441
- opened: !!error,
442
- children: jsx(StyledError, {
443
- children: error
444
- })
445
- }), notice ? jsx(StyledNotice, {
446
- children: notice
447
- }) : null]
448
- });
449
- });
450
-
451
- export { TextInput };