@spear-ai/spectral 1.13.1 → 1.14.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 (721) hide show
  1. package/dist/Accordion.d.ts +66 -46
  2. package/dist/Accordion.d.ts.map +1 -0
  3. package/dist/Accordion.js +113 -4
  4. package/dist/Accordion.js.map +1 -0
  5. package/dist/Alert/AlertBase.d.ts +75 -41
  6. package/dist/Alert/AlertBase.d.ts.map +1 -0
  7. package/dist/Alert/AlertBase.js +48 -39
  8. package/dist/Alert/AlertBase.js.map +1 -0
  9. package/dist/Alert.d.ts +24 -10
  10. package/dist/Alert.d.ts.map +1 -0
  11. package/dist/Alert.js +62 -50
  12. package/dist/Alert.js.map +1 -0
  13. package/dist/Avatar.d.ts +24 -11
  14. package/dist/Avatar.d.ts.map +1 -0
  15. package/dist/Avatar.js +87 -68
  16. package/dist/Avatar.js.map +1 -0
  17. package/dist/Badge.d.ts +19 -8
  18. package/dist/Badge.d.ts.map +1 -0
  19. package/dist/Badge.js +18 -13
  20. package/dist/Badge.js.map +1 -0
  21. package/dist/Button.d.ts +54 -26
  22. package/dist/Button.d.ts.map +1 -0
  23. package/dist/Button.js +72 -57
  24. package/dist/Button.js.map +1 -0
  25. package/dist/ButtonGroup/ButtonGroupButton.d.ts +25 -12
  26. package/dist/ButtonGroup/ButtonGroupButton.d.ts.map +1 -0
  27. package/dist/ButtonGroup/ButtonGroupButton.js +24 -19
  28. package/dist/ButtonGroup/ButtonGroupButton.js.map +1 -0
  29. package/dist/ButtonGroup.d.ts +60 -31
  30. package/dist/ButtonGroup.d.ts.map +1 -0
  31. package/dist/ButtonGroup.js +64 -49
  32. package/dist/ButtonGroup.js.map +1 -0
  33. package/dist/ButtonIcon.d.ts +32 -16
  34. package/dist/ButtonIcon.d.ts.map +1 -0
  35. package/dist/ButtonIcon.js +43 -35
  36. package/dist/ButtonIcon.js.map +1 -0
  37. package/dist/Checkbox/CheckboxBase.d.ts +54 -26
  38. package/dist/Checkbox/CheckboxBase.d.ts.map +1 -0
  39. package/dist/Checkbox/CheckboxBase.js +106 -74
  40. package/dist/Checkbox/CheckboxBase.js.map +1 -0
  41. package/dist/Checkbox.d.ts +49 -24
  42. package/dist/Checkbox.d.ts.map +1 -0
  43. package/dist/Checkbox.js +49 -40
  44. package/dist/Checkbox.js.map +1 -0
  45. package/dist/Combobox.d.ts +54 -23
  46. package/dist/Combobox.d.ts.map +1 -0
  47. package/dist/Combobox.js +203 -4
  48. package/dist/Combobox.js.map +1 -0
  49. package/dist/ControlGroup/ControlGroupSelect.d.ts +73 -43
  50. package/dist/ControlGroup/ControlGroupSelect.d.ts.map +1 -0
  51. package/dist/ControlGroup/ControlGroupSelect.js +159 -121
  52. package/dist/ControlGroup/ControlGroupSelect.js.map +1 -0
  53. package/dist/ControlGroup.d.ts +43 -21
  54. package/dist/ControlGroup.d.ts.map +1 -0
  55. package/dist/ControlGroup.js +54 -41
  56. package/dist/ControlGroup.js.map +1 -0
  57. package/dist/DataCard/Card.d.ts +36 -9
  58. package/dist/DataCard/Card.d.ts.map +1 -0
  59. package/dist/DataCard/Card.js +57 -37
  60. package/dist/DataCard/Card.js.map +1 -0
  61. package/dist/DataCard.d.ts +23 -9
  62. package/dist/DataCard.d.ts.map +1 -0
  63. package/dist/DataCard.js +40 -36
  64. package/dist/DataCard.js.map +1 -0
  65. package/dist/DateTimePicker/Calendar.d.ts +24 -11
  66. package/dist/DateTimePicker/Calendar.d.ts.map +1 -0
  67. package/dist/DateTimePicker/Calendar.js +54 -3
  68. package/dist/DateTimePicker/Calendar.js.map +1 -0
  69. package/dist/DateTimePicker/DateTimeDisplayInput.d.ts +24 -18
  70. package/dist/DateTimePicker/DateTimeDisplayInput.d.ts.map +1 -0
  71. package/dist/DateTimePicker/DateTimeDisplayInput.js +360 -213
  72. package/dist/DateTimePicker/DateTimeDisplayInput.js.map +1 -0
  73. package/dist/DateTimePicker/DateTimeInput.d.ts +41 -19
  74. package/dist/DateTimePicker/DateTimeInput.d.ts.map +1 -0
  75. package/dist/DateTimePicker/DateTimeInput.js +151 -98
  76. package/dist/DateTimePicker/DateTimeInput.js.map +1 -0
  77. package/dist/DateTimePicker/DateTimeUtils.d.ts +121 -109
  78. package/dist/DateTimePicker/DateTimeUtils.d.ts.map +1 -0
  79. package/dist/DateTimePicker/DateTimeUtils.js +296 -2
  80. package/dist/DateTimePicker/DateTimeUtils.js.map +1 -0
  81. package/dist/DateTimePicker/TimePeriodSelect.d.ts +16 -10
  82. package/dist/DateTimePicker/TimePeriodSelect.d.ts.map +1 -0
  83. package/dist/DateTimePicker/TimePeriodSelect.js +54 -40
  84. package/dist/DateTimePicker/TimePeriodSelect.js.map +1 -0
  85. package/dist/DateTimePicker/TimePicker.d.ts +29 -14
  86. package/dist/DateTimePicker/TimePicker.d.ts.map +1 -0
  87. package/dist/DateTimePicker/TimePicker.js +68 -54
  88. package/dist/DateTimePicker/TimePicker.js.map +1 -0
  89. package/dist/DateTimePicker.d.ts +56 -31
  90. package/dist/DateTimePicker.d.ts.map +1 -0
  91. package/dist/DateTimePicker.js +86 -71
  92. package/dist/DateTimePicker.js.map +1 -0
  93. package/dist/Dialog.d.ts +60 -21
  94. package/dist/Dialog.d.ts.map +1 -0
  95. package/dist/Dialog.js +103 -72
  96. package/dist/Dialog.js.map +1 -0
  97. package/dist/Drawer.d.ts +32 -14
  98. package/dist/Drawer.d.ts.map +1 -0
  99. package/dist/Drawer.js +46 -41
  100. package/dist/Drawer.js.map +1 -0
  101. package/dist/DropdownMenu.d.ts +84 -51
  102. package/dist/DropdownMenu.d.ts.map +1 -0
  103. package/dist/DropdownMenu.js +156 -3
  104. package/dist/DropdownMenu.js.map +1 -0
  105. package/dist/FormFieldMessage.d.ts +32 -8
  106. package/dist/FormFieldMessage.d.ts.map +1 -0
  107. package/dist/FormFieldMessage.js +64 -45
  108. package/dist/FormFieldMessage.js.map +1 -0
  109. package/dist/HoverCard.d.ts +51 -25
  110. package/dist/HoverCard.d.ts.map +1 -0
  111. package/dist/HoverCard.js +67 -3
  112. package/dist/HoverCard.js.map +1 -0
  113. package/dist/Icons/AdjustmentsIcon.d.ts +16 -3
  114. package/dist/Icons/AdjustmentsIcon.d.ts.map +1 -0
  115. package/dist/Icons/AdjustmentsIcon.js +84 -78
  116. package/dist/Icons/AdjustmentsIcon.js.map +1 -0
  117. package/dist/Icons/AnalyzeIcon.d.ts +16 -3
  118. package/dist/Icons/AnalyzeIcon.d.ts.map +1 -0
  119. package/dist/Icons/AnalyzeIcon.js +56 -50
  120. package/dist/Icons/AnalyzeIcon.js.map +1 -0
  121. package/dist/Icons/AnnotationsIcon.d.ts +16 -3
  122. package/dist/Icons/AnnotationsIcon.d.ts.map +1 -0
  123. package/dist/Icons/AnnotationsIcon.js +26 -20
  124. package/dist/Icons/AnnotationsIcon.js.map +1 -0
  125. package/dist/Icons/ApprovedIcon.d.ts +16 -3
  126. package/dist/Icons/ApprovedIcon.d.ts.map +1 -0
  127. package/dist/Icons/ApprovedIcon.js +32 -26
  128. package/dist/Icons/ApprovedIcon.js.map +1 -0
  129. package/dist/Icons/ArrowDownIcon.d.ts +16 -3
  130. package/dist/Icons/ArrowDownIcon.d.ts.map +1 -0
  131. package/dist/Icons/ArrowDownIcon.js +26 -20
  132. package/dist/Icons/ArrowDownIcon.js.map +1 -0
  133. package/dist/Icons/ArrowUpIcon.d.ts +16 -3
  134. package/dist/Icons/ArrowUpIcon.d.ts.map +1 -0
  135. package/dist/Icons/ArrowUpIcon.js +26 -20
  136. package/dist/Icons/ArrowUpIcon.js.map +1 -0
  137. package/dist/Icons/BoxToolIcon.d.ts +16 -3
  138. package/dist/Icons/BoxToolIcon.d.ts.map +1 -0
  139. package/dist/Icons/BoxToolIcon.js +23 -17
  140. package/dist/Icons/BoxToolIcon.js.map +1 -0
  141. package/dist/Icons/CalendarIcon.d.ts +16 -3
  142. package/dist/Icons/CalendarIcon.d.ts.map +1 -0
  143. package/dist/Icons/CalendarIcon.js +49 -43
  144. package/dist/Icons/CalendarIcon.js.map +1 -0
  145. package/dist/Icons/CheckCircleIcon.d.ts +16 -3
  146. package/dist/Icons/CheckCircleIcon.d.ts.map +1 -0
  147. package/dist/Icons/CheckCircleIcon.js +32 -26
  148. package/dist/Icons/CheckCircleIcon.js.map +1 -0
  149. package/dist/Icons/CheckSquareIcon.d.ts +16 -3
  150. package/dist/Icons/CheckSquareIcon.d.ts.map +1 -0
  151. package/dist/Icons/CheckSquareIcon.js +32 -26
  152. package/dist/Icons/CheckSquareIcon.js.map +1 -0
  153. package/dist/Icons/CheckmarkIcon.d.ts +17 -3
  154. package/dist/Icons/CheckmarkIcon.d.ts.map +1 -0
  155. package/dist/Icons/CheckmarkIcon.js +28 -22
  156. package/dist/Icons/CheckmarkIcon.js.map +1 -0
  157. package/dist/Icons/ChevronDownIcon.d.ts +16 -3
  158. package/dist/Icons/ChevronDownIcon.d.ts.map +1 -0
  159. package/dist/Icons/ChevronDownIcon.js +28 -22
  160. package/dist/Icons/ChevronDownIcon.js.map +1 -0
  161. package/dist/Icons/ChevronUpIcon.d.ts +16 -3
  162. package/dist/Icons/ChevronUpIcon.d.ts.map +1 -0
  163. package/dist/Icons/ChevronUpIcon.js +28 -22
  164. package/dist/Icons/ChevronUpIcon.js.map +1 -0
  165. package/dist/Icons/ClockIcon.d.ts +16 -3
  166. package/dist/Icons/ClockIcon.d.ts.map +1 -0
  167. package/dist/Icons/ClockIcon.js +32 -26
  168. package/dist/Icons/ClockIcon.js.map +1 -0
  169. package/dist/Icons/CloseCircleIcon.d.ts +16 -3
  170. package/dist/Icons/CloseCircleIcon.d.ts.map +1 -0
  171. package/dist/Icons/CloseCircleIcon.js +32 -26
  172. package/dist/Icons/CloseCircleIcon.js.map +1 -0
  173. package/dist/Icons/CloseIcon.d.ts +16 -3
  174. package/dist/Icons/CloseIcon.d.ts.map +1 -0
  175. package/dist/Icons/CloseIcon.js +24 -18
  176. package/dist/Icons/CloseIcon.js.map +1 -0
  177. package/dist/Icons/Crosshairs2Icon.d.ts +16 -3
  178. package/dist/Icons/Crosshairs2Icon.d.ts.map +1 -0
  179. package/dist/Icons/Crosshairs2Icon.js +56 -50
  180. package/dist/Icons/Crosshairs2Icon.js.map +1 -0
  181. package/dist/Icons/CrosshairsIcon.d.ts +16 -3
  182. package/dist/Icons/CrosshairsIcon.d.ts.map +1 -0
  183. package/dist/Icons/CrosshairsIcon.js +25 -19
  184. package/dist/Icons/CrosshairsIcon.js.map +1 -0
  185. package/dist/Icons/DashboardIcon.d.ts +16 -3
  186. package/dist/Icons/DashboardIcon.d.ts.map +1 -0
  187. package/dist/Icons/DashboardIcon.js +42 -36
  188. package/dist/Icons/DashboardIcon.js.map +1 -0
  189. package/dist/Icons/DatabaseIcon.d.ts +16 -3
  190. package/dist/Icons/DatabaseIcon.d.ts.map +1 -0
  191. package/dist/Icons/DatabaseIcon.js +42 -36
  192. package/dist/Icons/DatabaseIcon.js.map +1 -0
  193. package/dist/Icons/DeleteIcon.d.ts +16 -3
  194. package/dist/Icons/DeleteIcon.d.ts.map +1 -0
  195. package/dist/Icons/DeleteIcon.js +42 -36
  196. package/dist/Icons/DeleteIcon.js.map +1 -0
  197. package/dist/Icons/DurationIcon.d.ts +16 -3
  198. package/dist/Icons/DurationIcon.d.ts.map +1 -0
  199. package/dist/Icons/DurationIcon.js +63 -57
  200. package/dist/Icons/DurationIcon.js.map +1 -0
  201. package/dist/Icons/EditIcon.d.ts +16 -3
  202. package/dist/Icons/EditIcon.d.ts.map +1 -0
  203. package/dist/Icons/EditIcon.js +32 -26
  204. package/dist/Icons/EditIcon.js.map +1 -0
  205. package/dist/Icons/EmailIcon.d.ts +16 -3
  206. package/dist/Icons/EmailIcon.d.ts.map +1 -0
  207. package/dist/Icons/EmailIcon.js +32 -26
  208. package/dist/Icons/EmailIcon.js.map +1 -0
  209. package/dist/Icons/EraserIcon.d.ts +16 -3
  210. package/dist/Icons/EraserIcon.d.ts.map +1 -0
  211. package/dist/Icons/EraserIcon.js +27 -23
  212. package/dist/Icons/EraserIcon.js.map +1 -0
  213. package/dist/Icons/ErrorIcon.d.ts +16 -3
  214. package/dist/Icons/ErrorIcon.d.ts.map +1 -0
  215. package/dist/Icons/ErrorIcon.js +33 -27
  216. package/dist/Icons/ErrorIcon.js.map +1 -0
  217. package/dist/Icons/EyeClosedIcon.d.ts +16 -3
  218. package/dist/Icons/EyeClosedIcon.d.ts.map +1 -0
  219. package/dist/Icons/EyeClosedIcon.js +35 -29
  220. package/dist/Icons/EyeClosedIcon.js.map +1 -0
  221. package/dist/Icons/EyeClosedIcon2.d.ts +16 -3
  222. package/dist/Icons/EyeClosedIcon2.d.ts.map +1 -0
  223. package/dist/Icons/EyeClosedIcon2.js +33 -27
  224. package/dist/Icons/EyeClosedIcon2.js.map +1 -0
  225. package/dist/Icons/EyeOpenIcon.d.ts +16 -3
  226. package/dist/Icons/EyeOpenIcon.d.ts.map +1 -0
  227. package/dist/Icons/EyeOpenIcon.js +28 -22
  228. package/dist/Icons/EyeOpenIcon.js.map +1 -0
  229. package/dist/Icons/FileDownloadIcon.d.ts +16 -3
  230. package/dist/Icons/FileDownloadIcon.d.ts.map +1 -0
  231. package/dist/Icons/FileDownloadIcon.js +49 -43
  232. package/dist/Icons/FileDownloadIcon.js.map +1 -0
  233. package/dist/Icons/GoToFirstIcon.d.ts +16 -3
  234. package/dist/Icons/GoToFirstIcon.d.ts.map +1 -0
  235. package/dist/Icons/GoToFirstIcon.js +32 -26
  236. package/dist/Icons/GoToFirstIcon.js.map +1 -0
  237. package/dist/Icons/GoToLastIcon.d.ts +16 -3
  238. package/dist/Icons/GoToLastIcon.d.ts.map +1 -0
  239. package/dist/Icons/GoToLastIcon.js +32 -26
  240. package/dist/Icons/GoToLastIcon.js.map +1 -0
  241. package/dist/Icons/HarmonicCursorsIcon.d.ts +16 -3
  242. package/dist/Icons/HarmonicCursorsIcon.d.ts.map +1 -0
  243. package/dist/Icons/HarmonicCursorsIcon.js +29 -23
  244. package/dist/Icons/HarmonicCursorsIcon.js.map +1 -0
  245. package/dist/Icons/IconBase.d.ts +38 -14
  246. package/dist/Icons/IconBase.d.ts.map +1 -0
  247. package/dist/Icons/IconBase.js +61 -41
  248. package/dist/Icons/IconBase.js.map +1 -0
  249. package/dist/Icons/InfoIcon.d.ts +16 -3
  250. package/dist/Icons/InfoIcon.d.ts.map +1 -0
  251. package/dist/Icons/InfoIcon.js +42 -36
  252. package/dist/Icons/InfoIcon.js.map +1 -0
  253. package/dist/Icons/KeyboardIcon.d.ts +16 -3
  254. package/dist/Icons/KeyboardIcon.d.ts.map +1 -0
  255. package/dist/Icons/KeyboardIcon.js +32 -26
  256. package/dist/Icons/KeyboardIcon.js.map +1 -0
  257. package/dist/Icons/LabelIcon.d.ts +16 -3
  258. package/dist/Icons/LabelIcon.d.ts.map +1 -0
  259. package/dist/Icons/LabelIcon.js +25 -19
  260. package/dist/Icons/LabelIcon.js.map +1 -0
  261. package/dist/Icons/LassoIcon.d.ts +16 -3
  262. package/dist/Icons/LassoIcon.d.ts.map +1 -0
  263. package/dist/Icons/LassoIcon.js +42 -36
  264. package/dist/Icons/LassoIcon.js.map +1 -0
  265. package/dist/Icons/LineToolIcon.d.ts +16 -3
  266. package/dist/Icons/LineToolIcon.d.ts.map +1 -0
  267. package/dist/Icons/LineToolIcon.js +54 -48
  268. package/dist/Icons/LineToolIcon.js.map +1 -0
  269. package/dist/Icons/LiveViewIcon.d.ts +16 -3
  270. package/dist/Icons/LiveViewIcon.d.ts.map +1 -0
  271. package/dist/Icons/LiveViewIcon.js +56 -50
  272. package/dist/Icons/LiveViewIcon.js.map +1 -0
  273. package/dist/Icons/LoaderIcon.d.ts +16 -3
  274. package/dist/Icons/LoaderIcon.d.ts.map +1 -0
  275. package/dist/Icons/LoaderIcon.js +35 -31
  276. package/dist/Icons/LoaderIcon.js.map +1 -0
  277. package/dist/Icons/LocationIcon.d.ts +16 -3
  278. package/dist/Icons/LocationIcon.d.ts.map +1 -0
  279. package/dist/Icons/LocationIcon.js +32 -26
  280. package/dist/Icons/LocationIcon.js.map +1 -0
  281. package/dist/Icons/LogoutIcon.d.ts +16 -3
  282. package/dist/Icons/LogoutIcon.d.ts.map +1 -0
  283. package/dist/Icons/LogoutIcon.js +26 -20
  284. package/dist/Icons/LogoutIcon.js.map +1 -0
  285. package/dist/Icons/MaximizeIcon.d.ts +16 -3
  286. package/dist/Icons/MaximizeIcon.d.ts.map +1 -0
  287. package/dist/Icons/MaximizeIcon.js +49 -43
  288. package/dist/Icons/MaximizeIcon.js.map +1 -0
  289. package/dist/Icons/MeasureIcon.d.ts +16 -3
  290. package/dist/Icons/MeasureIcon.d.ts.map +1 -0
  291. package/dist/Icons/MeasureIcon.js +84 -78
  292. package/dist/Icons/MeasureIcon.js.map +1 -0
  293. package/dist/Icons/MenuDotsIcon.d.ts +16 -3
  294. package/dist/Icons/MenuDotsIcon.d.ts.map +1 -0
  295. package/dist/Icons/MenuDotsIcon.js +42 -36
  296. package/dist/Icons/MenuDotsIcon.js.map +1 -0
  297. package/dist/Icons/MenuIcon.d.ts +16 -3
  298. package/dist/Icons/MenuIcon.d.ts.map +1 -0
  299. package/dist/Icons/MenuIcon.js +42 -36
  300. package/dist/Icons/MenuIcon.js.map +1 -0
  301. package/dist/Icons/MessagesIcon.d.ts +16 -3
  302. package/dist/Icons/MessagesIcon.d.ts.map +1 -0
  303. package/dist/Icons/MessagesIcon.js +39 -33
  304. package/dist/Icons/MessagesIcon.js.map +1 -0
  305. package/dist/Icons/MetadataIcon.d.ts +16 -3
  306. package/dist/Icons/MetadataIcon.d.ts.map +1 -0
  307. package/dist/Icons/MetadataIcon.js +26 -20
  308. package/dist/Icons/MetadataIcon.js.map +1 -0
  309. package/dist/Icons/MinimizeIcon.d.ts +16 -3
  310. package/dist/Icons/MinimizeIcon.d.ts.map +1 -0
  311. package/dist/Icons/MinimizeIcon.js +49 -43
  312. package/dist/Icons/MinimizeIcon.js.map +1 -0
  313. package/dist/Icons/MinusIcon.d.ts +16 -3
  314. package/dist/Icons/MinusIcon.d.ts.map +1 -0
  315. package/dist/Icons/MinusIcon.js +24 -18
  316. package/dist/Icons/MinusIcon.js.map +1 -0
  317. package/dist/Icons/OntologyIcon.d.ts +16 -3
  318. package/dist/Icons/OntologyIcon.d.ts.map +1 -0
  319. package/dist/Icons/OntologyIcon.js +93 -87
  320. package/dist/Icons/OntologyIcon.js.map +1 -0
  321. package/dist/Icons/PanelIconClose.d.ts +16 -3
  322. package/dist/Icons/PanelIconClose.d.ts.map +1 -0
  323. package/dist/Icons/PanelIconClose.js +34 -28
  324. package/dist/Icons/PanelIconClose.js.map +1 -0
  325. package/dist/Icons/PanelIconOpen.d.ts +16 -3
  326. package/dist/Icons/PanelIconOpen.d.ts.map +1 -0
  327. package/dist/Icons/PanelIconOpen.js +34 -28
  328. package/dist/Icons/PanelIconOpen.js.map +1 -0
  329. package/dist/Icons/PauseIcon.d.ts +16 -3
  330. package/dist/Icons/PauseIcon.d.ts.map +1 -0
  331. package/dist/Icons/PauseIcon.js +32 -26
  332. package/dist/Icons/PauseIcon.js.map +1 -0
  333. package/dist/Icons/PlayIcon.d.ts +16 -3
  334. package/dist/Icons/PlayIcon.d.ts.map +1 -0
  335. package/dist/Icons/PlayIcon.js +26 -20
  336. package/dist/Icons/PlayIcon.js.map +1 -0
  337. package/dist/Icons/PlusIcon.d.ts +16 -3
  338. package/dist/Icons/PlusIcon.d.ts.map +1 -0
  339. package/dist/Icons/PlusIcon.js +26 -20
  340. package/dist/Icons/PlusIcon.js.map +1 -0
  341. package/dist/Icons/PolygonIcon.d.ts +17 -3
  342. package/dist/Icons/PolygonIcon.d.ts.map +1 -0
  343. package/dist/Icons/PolygonIcon.js +56 -50
  344. package/dist/Icons/PolygonIcon.js.map +1 -0
  345. package/dist/Icons/PrinterIcon.d.ts +16 -3
  346. package/dist/Icons/PrinterIcon.d.ts.map +1 -0
  347. package/dist/Icons/PrinterIcon.js +26 -20
  348. package/dist/Icons/PrinterIcon.js.map +1 -0
  349. package/dist/Icons/ProgressCheckIcon.d.ts +16 -3
  350. package/dist/Icons/ProgressCheckIcon.d.ts.map +1 -0
  351. package/dist/Icons/ProgressCheckIcon.js +63 -57
  352. package/dist/Icons/ProgressCheckIcon.js.map +1 -0
  353. package/dist/Icons/ResetIcon.d.ts +16 -3
  354. package/dist/Icons/ResetIcon.d.ts.map +1 -0
  355. package/dist/Icons/ResetIcon.js +23 -17
  356. package/dist/Icons/ResetIcon.js.map +1 -0
  357. package/dist/Icons/ReviewedIcon.d.ts +16 -3
  358. package/dist/Icons/ReviewedIcon.d.ts.map +1 -0
  359. package/dist/Icons/ReviewedIcon.js +42 -36
  360. package/dist/Icons/ReviewedIcon.js.map +1 -0
  361. package/dist/Icons/ScissorsIcon.d.ts +16 -3
  362. package/dist/Icons/ScissorsIcon.d.ts.map +1 -0
  363. package/dist/Icons/ScissorsIcon.js +28 -22
  364. package/dist/Icons/ScissorsIcon.js.map +1 -0
  365. package/dist/Icons/SearchIcon.d.ts +16 -3
  366. package/dist/Icons/SearchIcon.d.ts.map +1 -0
  367. package/dist/Icons/SearchIcon.js +32 -26
  368. package/dist/Icons/SearchIcon.js.map +1 -0
  369. package/dist/Icons/SettingsIcon.d.ts +16 -3
  370. package/dist/Icons/SettingsIcon.d.ts.map +1 -0
  371. package/dist/Icons/SettingsIcon.js +32 -26
  372. package/dist/Icons/SettingsIcon.js.map +1 -0
  373. package/dist/Icons/SortAscendingIcon.d.ts +16 -3
  374. package/dist/Icons/SortAscendingIcon.d.ts.map +1 -0
  375. package/dist/Icons/SortAscendingIcon.js +56 -50
  376. package/dist/Icons/SortAscendingIcon.js.map +1 -0
  377. package/dist/Icons/SortAtoZIcon.d.ts +16 -3
  378. package/dist/Icons/SortAtoZIcon.d.ts.map +1 -0
  379. package/dist/Icons/SortAtoZIcon.js +56 -50
  380. package/dist/Icons/SortAtoZIcon.js.map +1 -0
  381. package/dist/Icons/SortDescendingIcon.d.ts +16 -3
  382. package/dist/Icons/SortDescendingIcon.d.ts.map +1 -0
  383. package/dist/Icons/SortDescendingIcon.js +56 -50
  384. package/dist/Icons/SortDescendingIcon.js.map +1 -0
  385. package/dist/Icons/SortZtoAIcon.d.ts +16 -3
  386. package/dist/Icons/SortZtoAIcon.d.ts.map +1 -0
  387. package/dist/Icons/SortZtoAIcon.js +56 -50
  388. package/dist/Icons/SortZtoAIcon.js.map +1 -0
  389. package/dist/Icons/SparklesIcon.d.ts +16 -3
  390. package/dist/Icons/SparklesIcon.d.ts.map +1 -0
  391. package/dist/Icons/SparklesIcon.js +26 -20
  392. package/dist/Icons/SparklesIcon.js.map +1 -0
  393. package/dist/Icons/StackIcon.d.ts +16 -3
  394. package/dist/Icons/StackIcon.d.ts.map +1 -0
  395. package/dist/Icons/StackIcon.js +32 -26
  396. package/dist/Icons/StackIcon.js.map +1 -0
  397. package/dist/Icons/StarIcon.d.ts +16 -3
  398. package/dist/Icons/StarIcon.d.ts.map +1 -0
  399. package/dist/Icons/StarIcon.js +26 -20
  400. package/dist/Icons/StarIcon.js.map +1 -0
  401. package/dist/Icons/TrashIcon.d.ts +16 -3
  402. package/dist/Icons/TrashIcon.d.ts.map +1 -0
  403. package/dist/Icons/TrashIcon.js +23 -17
  404. package/dist/Icons/TrashIcon.js.map +1 -0
  405. package/dist/Icons/UndoIcon.d.ts +16 -3
  406. package/dist/Icons/UndoIcon.d.ts.map +1 -0
  407. package/dist/Icons/UndoIcon.js +26 -20
  408. package/dist/Icons/UndoIcon.js.map +1 -0
  409. package/dist/Icons/UploadIcon.d.ts +16 -3
  410. package/dist/Icons/UploadIcon.d.ts.map +1 -0
  411. package/dist/Icons/UploadIcon.js +42 -36
  412. package/dist/Icons/UploadIcon.js.map +1 -0
  413. package/dist/Icons/User2Icon.d.ts +16 -3
  414. package/dist/Icons/User2Icon.d.ts.map +1 -0
  415. package/dist/Icons/User2Icon.js +32 -26
  416. package/dist/Icons/User2Icon.js.map +1 -0
  417. package/dist/Icons/UserIcon.d.ts +16 -3
  418. package/dist/Icons/UserIcon.d.ts.map +1 -0
  419. package/dist/Icons/UserIcon.js +25 -19
  420. package/dist/Icons/UserIcon.js.map +1 -0
  421. package/dist/Icons/WarningIcon.d.ts +16 -3
  422. package/dist/Icons/WarningIcon.d.ts.map +1 -0
  423. package/dist/Icons/WarningIcon.js +25 -19
  424. package/dist/Icons/WarningIcon.js.map +1 -0
  425. package/dist/Icons/ZoomAllIcon.d.ts +16 -3
  426. package/dist/Icons/ZoomAllIcon.d.ts.map +1 -0
  427. package/dist/Icons/ZoomAllIcon.js +77 -71
  428. package/dist/Icons/ZoomAllIcon.js.map +1 -0
  429. package/dist/Icons/ZoomXIcon.d.ts +16 -3
  430. package/dist/Icons/ZoomXIcon.d.ts.map +1 -0
  431. package/dist/Icons/ZoomXIcon.js +42 -36
  432. package/dist/Icons/ZoomXIcon.js.map +1 -0
  433. package/dist/Icons/ZoomYIcon.d.ts +16 -3
  434. package/dist/Icons/ZoomYIcon.d.ts.map +1 -0
  435. package/dist/Icons/ZoomYIcon.js +42 -36
  436. package/dist/Icons/ZoomYIcon.js.map +1 -0
  437. package/dist/Icons.d.ts +82 -0
  438. package/dist/Icons.js +83 -82
  439. package/dist/IconsAnimated/PanelLeftCloseIcon.d.ts +15 -2
  440. package/dist/IconsAnimated/PanelLeftCloseIcon.d.ts.map +1 -0
  441. package/dist/IconsAnimated/PanelLeftCloseIcon.js +45 -35
  442. package/dist/IconsAnimated/PanelLeftCloseIcon.js.map +1 -0
  443. package/dist/IconsAnimated/PanelLeftOpenIcon.d.ts +15 -2
  444. package/dist/IconsAnimated/PanelLeftOpenIcon.d.ts.map +1 -0
  445. package/dist/IconsAnimated/PanelLeftOpenIcon.js +45 -35
  446. package/dist/IconsAnimated/PanelLeftOpenIcon.js.map +1 -0
  447. package/dist/IconsAnimated.d.ts +4 -0
  448. package/dist/IconsAnimated.js +5 -4
  449. package/dist/Input/InputUtils.d.ts +16 -11
  450. package/dist/Input/InputUtils.d.ts.map +1 -0
  451. package/dist/Input/InputUtils.js +47 -36
  452. package/dist/Input/InputUtils.js.map +1 -0
  453. package/dist/Input.d.ts +31 -26
  454. package/dist/Input.d.ts.map +1 -0
  455. package/dist/Input.js +161 -111
  456. package/dist/Input.js.map +1 -0
  457. package/dist/InputNumeric.d.ts +33 -12
  458. package/dist/InputNumeric.d.ts.map +1 -0
  459. package/dist/InputNumeric.js +146 -102
  460. package/dist/InputNumeric.js.map +1 -0
  461. package/dist/InputOTP.d.ts +95 -54
  462. package/dist/InputOTP.d.ts.map +1 -0
  463. package/dist/InputOTP.js +161 -3
  464. package/dist/InputOTP.js.map +1 -0
  465. package/dist/Kbd.d.ts +31 -16
  466. package/dist/Kbd.d.ts.map +1 -0
  467. package/dist/Kbd.js +55 -46
  468. package/dist/Kbd.js.map +1 -0
  469. package/dist/Label.d.ts +19 -9
  470. package/dist/Label.d.ts.map +1 -0
  471. package/dist/Label.js +16 -12
  472. package/dist/Label.js.map +1 -0
  473. package/dist/MultiSelect/MultiSelectBase.d.ts +81 -41
  474. package/dist/MultiSelect/MultiSelectBase.d.ts.map +1 -0
  475. package/dist/MultiSelect/MultiSelectBase.js +318 -235
  476. package/dist/MultiSelect/MultiSelectBase.js.map +1 -0
  477. package/dist/MultiSelect.d.ts +40 -23
  478. package/dist/MultiSelect.d.ts.map +1 -0
  479. package/dist/MultiSelect.js +31 -26
  480. package/dist/MultiSelect.js.map +1 -0
  481. package/dist/Popover.d.ts +28 -8
  482. package/dist/Popover.d.ts.map +1 -0
  483. package/dist/Popover.js +41 -28
  484. package/dist/Popover.js.map +1 -0
  485. package/dist/RadioButton.d.ts +36 -15
  486. package/dist/RadioButton.d.ts.map +1 -0
  487. package/dist/RadioButton.js +34 -26
  488. package/dist/RadioButton.js.map +1 -0
  489. package/dist/RadioButtonGroup/RadioButtonGroupBase.d.ts +50 -23
  490. package/dist/RadioButtonGroup/RadioButtonGroupBase.d.ts.map +1 -0
  491. package/dist/RadioButtonGroup/RadioButtonGroupBase.js +63 -45
  492. package/dist/RadioButtonGroup/RadioButtonGroupBase.js.map +1 -0
  493. package/dist/RadioButtonGroup.d.ts +31 -10
  494. package/dist/RadioButtonGroup.d.ts.map +1 -0
  495. package/dist/RadioButtonGroup.js +16 -11
  496. package/dist/RadioButtonGroup.js.map +1 -0
  497. package/dist/RadioGroup.d.ts +62 -45
  498. package/dist/RadioGroup.d.ts.map +1 -0
  499. package/dist/RadioGroup.js +184 -3
  500. package/dist/RadioGroup.js.map +1 -0
  501. package/dist/Select.d.ts +38 -33
  502. package/dist/Select.d.ts.map +1 -0
  503. package/dist/Select.js +142 -116
  504. package/dist/Select.js.map +1 -0
  505. package/dist/Separator.d.ts +22 -10
  506. package/dist/Separator.d.ts.map +1 -0
  507. package/dist/Separator.js +20 -16
  508. package/dist/Separator.js.map +1 -0
  509. package/dist/Skeleton.d.ts +11 -2
  510. package/dist/Skeleton.d.ts.map +1 -0
  511. package/dist/Skeleton.js +14 -10
  512. package/dist/Skeleton.js.map +1 -0
  513. package/dist/Slider.d.ts +49 -26
  514. package/dist/Slider.d.ts.map +1 -0
  515. package/dist/Slider.js +167 -3
  516. package/dist/Slider.js.map +1 -0
  517. package/dist/SpectralProvider.d.ts +3 -30
  518. package/dist/SpectralProvider.js +4 -11
  519. package/dist/Switch/SwitchBase.d.ts +51 -24
  520. package/dist/Switch/SwitchBase.d.ts.map +1 -0
  521. package/dist/Switch/SwitchBase.js +91 -72
  522. package/dist/Switch/SwitchBase.js.map +1 -0
  523. package/dist/Switch.d.ts +53 -24
  524. package/dist/Switch.d.ts.map +1 -0
  525. package/dist/Switch.js +118 -3
  526. package/dist/Switch.js.map +1 -0
  527. package/dist/Tabs/TabsBase.d.ts +94 -50
  528. package/dist/Tabs/TabsBase.d.ts.map +1 -0
  529. package/dist/Tabs/TabsBase.js +213 -152
  530. package/dist/Tabs/TabsBase.js.map +1 -0
  531. package/dist/Tabs/tabsUtils.d.ts +35 -30
  532. package/dist/Tabs/tabsUtils.d.ts.map +1 -0
  533. package/dist/Tabs/tabsUtils.js +121 -49
  534. package/dist/Tabs/tabsUtils.js.map +1 -0
  535. package/dist/Tabs.d.ts +55 -35
  536. package/dist/Tabs.d.ts.map +1 -0
  537. package/dist/Tabs.js +81 -60
  538. package/dist/Tabs.js.map +1 -0
  539. package/dist/Textarea/TextareaUtils.d.ts +24 -13
  540. package/dist/Textarea/TextareaUtils.d.ts.map +1 -0
  541. package/dist/Textarea/TextareaUtils.js +52 -29
  542. package/dist/Textarea/TextareaUtils.js.map +1 -0
  543. package/dist/Textarea.d.ts +33 -25
  544. package/dist/Textarea.d.ts.map +1 -0
  545. package/dist/Textarea.js +94 -67
  546. package/dist/Textarea.js.map +1 -0
  547. package/dist/Toast.d.ts +63 -34
  548. package/dist/Toast.d.ts.map +1 -0
  549. package/dist/Toast.js +115 -3
  550. package/dist/Toast.js.map +1 -0
  551. package/dist/Toggle/ToggleBase.d.ts +29 -11
  552. package/dist/Toggle/ToggleBase.d.ts.map +1 -0
  553. package/dist/Toggle/ToggleBase.js +55 -41
  554. package/dist/Toggle/ToggleBase.js.map +1 -0
  555. package/dist/Toggle.d.ts +34 -16
  556. package/dist/Toggle.d.ts.map +1 -0
  557. package/dist/Toggle.js +46 -32
  558. package/dist/Toggle.js.map +1 -0
  559. package/dist/ToggleGroup/ToggleGroupBase.d.ts +45 -30
  560. package/dist/ToggleGroup/ToggleGroupBase.d.ts.map +1 -0
  561. package/dist/ToggleGroup/ToggleGroupBase.js +162 -111
  562. package/dist/ToggleGroup/ToggleGroupBase.js.map +1 -0
  563. package/dist/ToggleGroup/ToggleGroupItem.d.ts +31 -13
  564. package/dist/ToggleGroup/ToggleGroupItem.d.ts.map +1 -0
  565. package/dist/ToggleGroup/ToggleGroupItem.js +35 -27
  566. package/dist/ToggleGroup/ToggleGroupItem.js.map +1 -0
  567. package/dist/ToggleGroup/ToggleGroupSplitMenuItem.d.ts +49 -20
  568. package/dist/ToggleGroup/ToggleGroupSplitMenuItem.d.ts.map +1 -0
  569. package/dist/ToggleGroup/ToggleGroupSplitMenuItem.js +123 -91
  570. package/dist/ToggleGroup/ToggleGroupSplitMenuItem.js.map +1 -0
  571. package/dist/ToggleGroup.d.ts +26 -10
  572. package/dist/ToggleGroup.d.ts.map +1 -0
  573. package/dist/ToggleGroup.js +35 -31
  574. package/dist/ToggleGroup.js.map +1 -0
  575. package/dist/Tooltip.d.ts +35 -12
  576. package/dist/Tooltip.d.ts.map +1 -0
  577. package/dist/Tooltip.js +68 -3
  578. package/dist/Tooltip.js.map +1 -0
  579. package/dist/Tray.d.ts +105 -61
  580. package/dist/Tray.d.ts.map +1 -0
  581. package/dist/Tray.js +120 -102
  582. package/dist/Tray.js.map +1 -0
  583. package/dist/components/Icons/iconTypes.d.ts +17 -0
  584. package/dist/components/Icons/iconTypes.d.ts.map +1 -0
  585. package/dist/components/IconsAnimated/iconTypes.d.ts +15 -0
  586. package/dist/components/IconsAnimated/iconTypes.d.ts.map +1 -0
  587. package/dist/components/SpectralProvider/SpectralProvider.d.ts +35 -0
  588. package/dist/components/SpectralProvider/SpectralProvider.d.ts.map +1 -0
  589. package/dist/components/SpectralProvider/SpectralProvider.js +33 -0
  590. package/dist/components/SpectralProvider/SpectralProvider.js.map +1 -0
  591. package/dist/components/ToggleGroup/ToggleGroup.context.js +14 -0
  592. package/dist/components/ToggleGroup/ToggleGroup.context.js.map +1 -0
  593. package/dist/hooks/useAccordionAutoScroll.d.ts +7 -2
  594. package/dist/hooks/useAccordionAutoScroll.d.ts.map +1 -1
  595. package/dist/hooks/useAccordionAutoScroll.js +71 -45
  596. package/dist/hooks/useAccordionAutoScroll.js.map +1 -0
  597. package/dist/hooks/useControllableState.d.ts +12 -8
  598. package/dist/hooks/useControllableState.d.ts.map +1 -1
  599. package/dist/hooks/useControllableState.js +23 -12
  600. package/dist/hooks/useControllableState.js.map +1 -0
  601. package/dist/hooks/useConvertToOklch.d.ts +6 -2
  602. package/dist/hooks/useConvertToOklch.d.ts.map +1 -1
  603. package/dist/hooks/useConvertToOklch.js +87 -42
  604. package/dist/hooks/useConvertToOklch.js.map +1 -0
  605. package/dist/hooks/useTheme.d.ts +10 -6
  606. package/dist/hooks/useTheme.d.ts.map +1 -1
  607. package/dist/hooks/useTheme.js +26 -18
  608. package/dist/hooks/useTheme.js.map +1 -0
  609. package/dist/hooks/useUncontrolledState.d.ts +8 -4
  610. package/dist/hooks/useUncontrolledState.d.ts.map +1 -1
  611. package/dist/hooks/useUncontrolledState.js +21 -11
  612. package/dist/hooks/useUncontrolledState.js.map +1 -0
  613. package/dist/index.d.ts +129 -47
  614. package/dist/index.js +130 -0
  615. package/dist/primitives/button.d.ts +22 -9
  616. package/dist/primitives/button.d.ts.map +1 -1
  617. package/dist/primitives/button.js +21 -15
  618. package/dist/primitives/button.js.map +1 -0
  619. package/dist/primitives/input-group.d.ts +46 -17
  620. package/dist/primitives/input-group.d.ts.map +1 -1
  621. package/dist/primitives/input-group.js +66 -43
  622. package/dist/primitives/input-group.js.map +1 -0
  623. package/dist/primitives/input.d.ts +16 -6
  624. package/dist/primitives/input.d.ts.map +1 -1
  625. package/dist/primitives/input.js +15 -10
  626. package/dist/primitives/input.js.map +1 -0
  627. package/dist/primitives/popover.d.ts +35 -9
  628. package/dist/primitives/popover.d.ts.map +1 -1
  629. package/dist/primitives/popover.js +56 -33
  630. package/dist/primitives/popover.js.map +1 -0
  631. package/dist/primitives/select.d.ts +60 -17
  632. package/dist/primitives/select.d.ts.map +1 -1
  633. package/dist/primitives/select.js +133 -3
  634. package/dist/primitives/select.js.map +1 -0
  635. package/dist/primitives/slot.d.ts +23 -14
  636. package/dist/primitives/slot.d.ts.map +1 -1
  637. package/dist/primitives/slot.js +53 -29
  638. package/dist/primitives/slot.js.map +1 -0
  639. package/dist/primitives/textarea.d.ts +11 -2
  640. package/dist/primitives/textarea.d.ts.map +1 -1
  641. package/dist/primitives/textarea.js +14 -9
  642. package/dist/primitives/textarea.js.map +1 -0
  643. package/dist/styles/horizon/colors.css +1 -0
  644. package/dist/styles/horizon-tokens.css +9 -0
  645. package/dist/styles/spectral.css +2 -2
  646. package/dist/utils/constants.d.ts +5 -1
  647. package/dist/utils/constants.d.ts.map +1 -1
  648. package/dist/utils/constants.js +5 -2
  649. package/dist/utils/constants.js.map +1 -0
  650. package/dist/utils/dropdownPositioning.d.ts +14 -9
  651. package/dist/utils/dropdownPositioning.d.ts.map +1 -1
  652. package/dist/utils/dropdownPositioning.js +57 -34
  653. package/dist/utils/dropdownPositioning.js.map +1 -0
  654. package/dist/utils/formFieldUtils.d.ts +93 -73
  655. package/dist/utils/formFieldUtils.d.ts.map +1 -1
  656. package/dist/utils/formFieldUtils.js +171 -106
  657. package/dist/utils/formFieldUtils.js.map +1 -0
  658. package/dist/utils/sharedUtils.d.ts +10 -6
  659. package/dist/utils/sharedUtils.d.ts.map +1 -1
  660. package/dist/utils/sharedUtils.js +23 -8
  661. package/dist/utils/sharedUtils.js.map +1 -0
  662. package/dist/utils/twUtils.d.ts +7 -2
  663. package/dist/utils/twUtils.d.ts.map +1 -1
  664. package/dist/utils/twUtils.js +12 -2
  665. package/dist/utils/twUtils.js.map +1 -0
  666. package/package.json +32 -24
  667. package/dist/.js +0 -129
  668. package/dist/Accordion-dVZHqyv8.js +0 -363
  669. package/dist/AnimatePresence-Bz_JZ2ah.js +0 -178
  670. package/dist/App.d.ts +0 -2
  671. package/dist/App.d.ts.map +0 -1
  672. package/dist/App.js +0 -9
  673. package/dist/Calendar-FXWVuKWS.js +0 -3109
  674. package/dist/Combination-MimnVFUU.js +0 -698
  675. package/dist/Combobox-DRQqx0os.js +0 -6379
  676. package/dist/DateTimeUtils-BJUAMuot.js +0 -2098
  677. package/dist/DropdownMenu-BO_RPCVU.js +0 -870
  678. package/dist/HoverCard-BhxgELKP.js +0 -201
  679. package/dist/Icons/index.d.ts +0 -81
  680. package/dist/InputOTP-DLn7ja7J.js +0 -464
  681. package/dist/RadioGroup-D-XjCU4Q.js +0 -333
  682. package/dist/Slider-CPYW_VYu.js +0 -490
  683. package/dist/Switch-CSmXtkia.js +0 -145
  684. package/dist/Toast-BuaZxqlt.js +0 -711
  685. package/dist/ToggleGroup/ToggleGroup.context.d.ts +0 -9
  686. package/dist/ToggleGroup/ToggleGroup.context.js +0 -11
  687. package/dist/Tooltip-CTjKOfvC.js +0 -389
  688. package/dist/builtin_esm-external-require-react-ItzZuLxx.js +0 -8
  689. package/dist/chunk-DmRZw4Wy.js +0 -17
  690. package/dist/clsx-Bfoz3aNJ.js +0 -16
  691. package/dist/dist-B9w6c9RC.js +0 -190
  692. package/dist/dist-Br_xj9vz.js +0 -12
  693. package/dist/dist-C-2mar4Y.js +0 -28
  694. package/dist/dist-C4MHwt9g.js +0 -10
  695. package/dist/dist-C6pGYii-.js +0 -6
  696. package/dist/dist-Cc8NfAO6.js +0 -122
  697. package/dist/dist-CcsVPym2.js +0 -68
  698. package/dist/dist-CrYg_9Cu.js +0 -913
  699. package/dist/dist-CwYxT5fv.js +0 -1287
  700. package/dist/dist-D9FsQh8P.js +0 -65
  701. package/dist/dist-DBLajRTL.js +0 -149
  702. package/dist/dist-DEkDg4Sk.js +0 -249
  703. package/dist/dist-DT46nqCO.js +0 -216
  704. package/dist/dist-PfrTYHr_.js +0 -29
  705. package/dist/dist-iDaHUF3d.js +0 -129
  706. package/dist/dist-s1uWaZYZ.js +0 -11
  707. package/dist/dist-tMzzRwxG.js +0 -33
  708. package/dist/index.d.ts.map +0 -1
  709. package/dist/main.d.ts +0 -1
  710. package/dist/main.d.ts.map +0 -1
  711. package/dist/main.js +0 -18960
  712. package/dist/proxy-BFVscmYQ.js +0 -4920
  713. package/dist/select-DFE8xm1L.js +0 -768
  714. package/dist/styles/base-colors.css +0 -62
  715. package/dist/styles/main.css +0 -2
  716. package/dist/styles/theme.css +0 -869
  717. package/dist/twUtils-BpqlKSeB.js +0 -1673
  718. package/dist/use-animation-BeSipRjB.js +0 -57
  719. package/dist/utils/dropdownPositioning.test.d.ts +0 -2
  720. package/dist/utils/dropdownPositioning.test.d.ts.map +0 -1
  721. package/dist/utils/dropdownPositioning.test.js +0 -22
@@ -1,32 +1,55 @@
1
- 'use client'
2
- import { useCallback as e } from "react";
1
+ 'use client';
2
+ import { useCallback } from "react";
3
+
3
4
  //#region src/components/Textarea/TextareaUtils.tsx
4
- var t = (e, t, n) => {
5
- let r = e.target.value;
6
- r.length <= t && n?.(r);
7
- }, n = (e, t, n, r) => {
8
- let i = e.clipboardData.getData("text"), a = n || "", o = e.currentTarget.selectionStart || 0, s = e.currentTarget.selectionEnd || 0, c = a.substring(0, o), l = a.substring(s);
9
- if ((c + i + l).length > t) {
10
- let e = s - o, n = t - a.length + e, u = c + i.substring(0, Math.max(0, n)) + l;
11
- r?.(u);
5
+ /**
6
+ * Handle change events to respect character limit
7
+ */
8
+ const handleTextareaChange = (e, maxLength, onChange) => {
9
+ const newValue = e.target.value;
10
+ if (newValue.length <= maxLength) onChange?.(newValue);
11
+ };
12
+ /**
13
+ * Handle paste event to truncate text at character limit
14
+ */
15
+ const handleTextareaPaste = (e, maxLength, value, onChange) => {
16
+ const pastedText = e.clipboardData.getData("text");
17
+ const currentValue = value || "";
18
+ const cursorStart = e.currentTarget.selectionStart || 0;
19
+ const cursorEnd = e.currentTarget.selectionEnd || 0;
20
+ const beforeCursor = currentValue.substring(0, cursorStart);
21
+ const afterCursor = currentValue.substring(cursorEnd);
22
+ if ((beforeCursor + pastedText + afterCursor).length > maxLength) {
23
+ const selectedLength = cursorEnd - cursorStart;
24
+ const availableSpace = maxLength - currentValue.length + selectedLength;
25
+ const truncatedValue = beforeCursor + pastedText.substring(0, Math.max(0, availableSpace)) + afterCursor;
26
+ onChange?.(truncatedValue);
12
27
  }
13
- }, r = ({ maxLength: r, value: i, onChange: a, onFocus: o, onBlur: s }) => ({
14
- handleFocus: e((e) => {
15
- o?.(e);
16
- }, [o]),
17
- handleBlur: e((e) => {
18
- s?.(e);
19
- }, [s]),
20
- handleChange: e((e) => {
21
- t(e, r, a);
22
- }, [r, a]),
23
- handlePaste: e((e) => {
24
- n(e, r, i, a);
25
- }, [
26
- i,
27
- r,
28
- a
29
- ])
30
- });
28
+ };
29
+ /**
30
+ * Custom hook for textarea functionality with character limits and event handling
31
+ */
32
+ const useTextarea = ({ maxLength, value, onChange, onFocus, onBlur }) => {
33
+ return {
34
+ handleFocus: useCallback((e) => {
35
+ onFocus?.(e);
36
+ }, [onFocus]),
37
+ handleBlur: useCallback((e) => {
38
+ onBlur?.(e);
39
+ }, [onBlur]),
40
+ handleChange: useCallback((e) => {
41
+ handleTextareaChange(e, maxLength, onChange);
42
+ }, [maxLength, onChange]),
43
+ handlePaste: useCallback((e) => {
44
+ handleTextareaPaste(e, maxLength, value, onChange);
45
+ }, [
46
+ value,
47
+ maxLength,
48
+ onChange
49
+ ])
50
+ };
51
+ };
52
+
31
53
  //#endregion
32
- export { r as useTextarea };
54
+ export { useTextarea };
55
+ //# sourceMappingURL=TextareaUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextareaUtils.js","names":[],"sources":["../../src/components/Textarea/TextareaUtils.tsx"],"sourcesContent":["import { useCallback, type ChangeEvent, type ClipboardEvent, type FocusEvent } from 'react'\n\nexport interface UseTextareaOptions {\n maxLength: number\n onBlur?: (e: FocusEvent<HTMLTextAreaElement>) => void\n onChange: (value: string) => void\n onFocus?: (e: FocusEvent<HTMLTextAreaElement>) => void\n value: string\n}\n\nexport interface UseTextareaReturn {\n handleBlur: (e: FocusEvent<HTMLTextAreaElement>) => void\n handleChange: (e: ChangeEvent<HTMLTextAreaElement>) => void\n handleFocus: (e: FocusEvent<HTMLTextAreaElement>) => void\n handlePaste: (e: ClipboardEvent<HTMLTextAreaElement>) => void\n}\n\n/**\n * Handle change events to respect character limit\n */\nconst handleTextareaChange = (e: ChangeEvent<HTMLTextAreaElement>, maxLength: number, onChange: UseTextareaOptions['onChange']): void => {\n const newValue = e.target.value\n\n // Only allow changes that don't exceed the character limit\n if (newValue.length <= maxLength) {\n onChange?.(newValue)\n }\n}\n\n/**\n * Handle paste event to truncate text at character limit\n */\nconst handleTextareaPaste = (e: ClipboardEvent<HTMLTextAreaElement>, maxLength: number, value: string, onChange?: (value: string) => void): void => {\n const pastedText = e.clipboardData.getData('text')\n const currentValue = value || ''\n const cursorStart = e.currentTarget.selectionStart || 0\n const cursorEnd = e.currentTarget.selectionEnd || 0\n\n // Calculate what the new value would be after paste\n const beforeCursor = currentValue.substring(0, cursorStart)\n const afterCursor = currentValue.substring(cursorEnd)\n const potentialNewValue = beforeCursor + pastedText + afterCursor\n\n // If pasting would exceed the limit, truncate the pasted content\n if (potentialNewValue.length > maxLength) {\n // Calculate how many characters we can accept from the pasted content\n const selectedLength = cursorEnd - cursorStart\n const availableSpace = maxLength - currentValue.length + selectedLength\n const truncatedPaste = pastedText.substring(0, Math.max(0, availableSpace))\n\n // Create the truncated result\n const truncatedValue = beforeCursor + truncatedPaste + afterCursor\n\n // Call onChange with the truncated value\n onChange?.(truncatedValue)\n }\n}\n\n/**\n * Custom hook for textarea functionality with character limits and event handling\n */\nexport const useTextarea = ({ maxLength, value, onChange, onFocus, onBlur }: UseTextareaOptions): UseTextareaReturn => {\n const handleFocus = useCallback(\n (e: FocusEvent<HTMLTextAreaElement>): void => {\n onFocus?.(e)\n },\n [onFocus],\n )\n\n const handleBlur = useCallback(\n (e: FocusEvent<HTMLTextAreaElement>): void => {\n onBlur?.(e)\n },\n [onBlur],\n )\n\n const handleChange = useCallback(\n (e: ChangeEvent<HTMLTextAreaElement>): void => {\n handleTextareaChange(e, maxLength, onChange)\n },\n [maxLength, onChange],\n )\n\n const handlePaste = useCallback(\n (e: ClipboardEvent<HTMLTextAreaElement>): void => {\n handleTextareaPaste(e, maxLength, value, onChange)\n },\n [value, maxLength, onChange],\n )\n\n return {\n handleFocus,\n handleBlur,\n handleChange,\n handlePaste,\n }\n}\n"],"mappings":";;;;;;;AAoBA,MAAM,wBAAwB,GAAqC,WAAmB,aAAmD;CACvI,MAAM,WAAW,EAAE,OAAO;AAG1B,KAAI,SAAS,UAAU,UACrB,YAAW,SAAS;;;;;AAOxB,MAAM,uBAAuB,GAAwC,WAAmB,OAAe,aAA6C;CAClJ,MAAM,aAAa,EAAE,cAAc,QAAQ,OAAO;CAClD,MAAM,eAAe,SAAS;CAC9B,MAAM,cAAc,EAAE,cAAc,kBAAkB;CACtD,MAAM,YAAY,EAAE,cAAc,gBAAgB;CAGlD,MAAM,eAAe,aAAa,UAAU,GAAG,YAAY;CAC3D,MAAM,cAAc,aAAa,UAAU,UAAU;AAIrD,MAH0B,eAAe,aAAa,aAGhC,SAAS,WAAW;EAExC,MAAM,iBAAiB,YAAY;EACnC,MAAM,iBAAiB,YAAY,aAAa,SAAS;EAIzD,MAAM,iBAAiB,eAHA,WAAW,UAAU,GAAG,KAAK,IAAI,GAAG,eAAe,CAGtB,GAAG;AAGvD,aAAW,eAAe;;;;;;AAO9B,MAAa,eAAe,EAAE,WAAW,OAAO,UAAU,SAAS,aAAoD;AA6BrH,QAAO;EACL,aA7BkB,aACjB,MAA6C;AAC5C,aAAU,EAAE;KAEd,CAAC,QAAQ,CAyBE;EACX,YAvBiB,aAChB,MAA6C;AAC5C,YAAS,EAAE;KAEb,CAAC,OAAO,CAmBE;EACV,cAjBmB,aAClB,MAA8C;AAC7C,wBAAqB,GAAG,WAAW,SAAS;KAE9C,CAAC,WAAW,SAAS,CAaT;EACZ,aAXkB,aACjB,MAAiD;AAChD,uBAAoB,GAAG,WAAW,OAAO,SAAS;KAEpD;GAAC;GAAO;GAAW;GAAS,CAOjB;EACZ"}
@@ -1,27 +1,35 @@
1
- import { BaseFormFieldProps, FormFieldState } from './utils/formFieldUtils';
2
- import { ComponentProps, FocusEvent, Ref } from 'react';
3
- export type TextareaState = FormFieldState;
4
- export type TextareaProps = Omit<ComponentProps<'textarea'>, 'onChange'> & {
5
- className?: string | undefined;
6
- errorMessage?: BaseFormFieldProps['errorMessage'];
7
- id?: string | undefined;
8
- label: string;
9
- labelClassName?: string;
10
- maxLength?: number | undefined;
11
- name: string;
12
- onBlur?: (e: FocusEvent<HTMLTextAreaElement>) => void;
13
- onChange?: (value: string) => void;
14
- onFocus?: (e: FocusEvent<HTMLTextAreaElement>) => void;
15
- placeholder?: string | undefined;
16
- required?: boolean;
17
- state?: TextareaState;
18
- value?: string | undefined;
19
- warningMessage?: BaseFormFieldProps['errorMessage'];
20
- };
21
- export declare const Textarea: {
22
- (allProps: TextareaProps & {
23
- ref?: Ref<HTMLTextAreaElement>;
24
- }): import("react/jsx-runtime").JSX.Element;
25
- displayName: string;
1
+ 'use client';
2
+ import { BaseFormFieldProps, FormFieldState } from "./utils/formFieldUtils.js";
3
+ import { ComponentProps, FocusEvent, Ref } from "react";
4
+ import * as _$react_jsx_runtime0 from "react/jsx-runtime";
5
+
6
+ //#region src/components/Textarea/Textarea.d.ts
7
+ type TextareaState = FormFieldState;
8
+ type TextareaProps = Omit<ComponentProps<'textarea'>, 'onChange'> & {
9
+ className?: string | undefined;
10
+ errorMessage?: BaseFormFieldProps['errorMessage'];
11
+ id?: string | undefined;
12
+ label: string;
13
+ labelClassName?: string;
14
+ maxLength?: number | undefined; /** Number of message lines to reserve (default: 1). */
15
+ messageReserveLines?: number; /** Whether to keep message space reserved when hidden (default: true). */
16
+ messageReserveSpace?: boolean;
17
+ name: string;
18
+ onBlur?: (e: FocusEvent<HTMLTextAreaElement>) => void;
19
+ onChange?: (value: string) => void;
20
+ onFocus?: (e: FocusEvent<HTMLTextAreaElement>) => void;
21
+ placeholder?: string | undefined;
22
+ required?: boolean;
23
+ state?: TextareaState;
24
+ value?: string | undefined;
25
+ warningMessage?: BaseFormFieldProps['errorMessage'];
26
26
  };
27
+ declare function Textarea(allProps: TextareaProps & {
28
+ ref?: Ref<HTMLTextAreaElement>;
29
+ }): _$react_jsx_runtime0.JSX.Element;
30
+ declare namespace Textarea {
31
+ var displayName: string;
32
+ }
33
+ //#endregion
34
+ export { Textarea, TextareaProps, TextareaState };
27
35
  //# sourceMappingURL=Textarea.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Textarea.d.ts","names":[],"sources":["../src/components/Textarea/Textarea.tsx"],"mappings":";;;;;;KAQY,aAAA,GAAgB,cAAA;AAAA,KAIhB,aAAA,GAAgB,IAAA,CAAK,cAAA;EAC/B,SAAA;EACA,YAAA,GAAe,kBAAA;EACf,EAAA;EACA,KAAA;EACA,cAAA;EACA,SAAA,uBANU;EAQV,mBAAA;EAEA,mBAAA;EACA,IAAA;EACA,MAAA,IAAU,CAAA,EAAG,UAAA,CAAW,mBAAA;EACxB,QAAA,IAAY,KAAA;EACZ,OAAA,IAAW,CAAA,EAAG,UAAA,CAAW,mBAAA;EACzB,WAAA;EACA,QAAA;EACA,KAAA,GAAQ,aAAA;EACR,KAAA;EACA,cAAA,GAAiB,kBAAA;AAAA;AAAA,0BAiBjB,QAAA,EAAU,aAAA;EACR,GAAA,GAAM,GAAA,CAAI,mBAAA;AAAA,IACX,oBAAA,CAAA,GAAA,CAAA,OAAA;AAAA"}
package/dist/Textarea.js CHANGED
@@ -1,97 +1,124 @@
1
- 'use client'
2
- import './styles/main.css'
3
- import { LoaderIcon as e } from "./Icons/LoaderIcon.js";
4
- import { t } from "./twUtils-BpqlKSeB.js";
5
- import { ErrorMessage as n, WarningMessage as r } from "./FormFieldMessage.js";
6
- import { getAriaProps as i, getErrorMessageId as a, getTextareaClasses as o, useFormFieldId as s, useFormFieldState as c } from "./utils/formFieldUtils.js";
7
- import { useUncontrolledState as ee } from "./hooks/useUncontrolledState.js";
8
- import { Label as l } from "./Label.js";
9
- import { useTextarea as u } from "./Textarea/TextareaUtils.js";
10
- import { useRef as d } from "react";
11
- import { jsx as f, jsxs as p } from "react/jsx-runtime";
1
+ 'use client';
2
+ import { LoaderIcon } from "./Icons/LoaderIcon.js";
3
+ import { cn } from "./utils/twUtils.js";
4
+ import { ErrorMessage, WarningMessage } from "./FormFieldMessage.js";
5
+ import { getAriaProps, getErrorMessageId, getTextareaClasses, useFormFieldId, useFormFieldState } from "./utils/formFieldUtils.js";
6
+ import { useUncontrolledState } from "./hooks/useUncontrolledState.js";
7
+ import { Label } from "./Label.js";
8
+ import { useTextarea } from "./Textarea/TextareaUtils.js";
9
+ import { useRef } from "react";
10
+ import { jsx, jsxs } from "react/jsx-runtime";
11
+
12
12
  //#region src/components/Textarea/Textarea.tsx
13
- var m = "absolute right-4 top-4", h = (e) => e || "off", g = (e, n) => t("absolute bottom-2 right-3 text-xs pointer-events-none z-10 tabular-nums", e >= n ? "text-danger-400" : "text-text-secondary"), _ = (_) => {
14
- let { ref: v, autoComplete: y, className: b, defaultValue: x, disabled: S, errorMessage: C, id: w, label: T, labelClassName: E, maxLength: D = 280, name: O, onBlur: k, onChange: A, onFocus: j, placeholder: M, required: N, state: P = "default", value: F, warningMessage: I, ...L } = _, R = s(w, O), z = a(R), B = `${R}-warning`, V = P === "error" ? z : P === "warning" && I ? B : void 0, H = d(null), U = v ?? H, [W, G] = ee({
15
- value: F,
16
- defaultValue: typeof x == "string" ? x : x == null ? "" : String(x),
17
- onChange: A
18
- }), { handleFocus: K, handleBlur: q, handleChange: J, handlePaste: Y } = u({
19
- maxLength: D,
20
- value: W,
21
- onChange: G,
22
- onFocus: j,
23
- onBlur: k
24
- }), { isDisabled: X, isLoading: Z } = c(S, P), Q = i(P, L["aria-describedby"], N, V), $ = W?.length || 0, te = o(P, b);
25
- return /* @__PURE__ */ p("div", {
13
+ const LOADING_ICON_CLASSES = "absolute right-4 top-4";
14
+ const getAutoCompleteValue = (autoComplete) => {
15
+ if (autoComplete) return autoComplete;
16
+ return "off";
17
+ };
18
+ const getCounterClasses = (currentLength, maxLength) => {
19
+ return cn("absolute bottom-2 right-3 text-xs pointer-events-none z-10 tabular-nums", currentLength >= maxLength ? "text-danger-400" : "text-text-secondary");
20
+ };
21
+ const Textarea = (allProps) => {
22
+ const { ref, autoComplete, className, defaultValue, disabled, errorMessage, id, label, labelClassName, maxLength = 280, messageReserveLines = 1, messageReserveSpace = true, name, onBlur, onChange, onFocus, placeholder, required, state = "default", value: valueProp, warningMessage, ...props } = allProps;
23
+ const textareaId = useFormFieldId(id, name);
24
+ const errorMessageId = getErrorMessageId(textareaId);
25
+ const warningMessageId = `${textareaId}-warning`;
26
+ const messageId = state === "error" ? errorMessageId : state === "warning" && warningMessage ? warningMessageId : void 0;
27
+ const internalRef = useRef(null);
28
+ const textareaRef = ref ?? internalRef;
29
+ const [value, setValue] = useUncontrolledState({
30
+ value: valueProp,
31
+ defaultValue: typeof defaultValue === "string" ? defaultValue : defaultValue !== void 0 && defaultValue !== null ? String(defaultValue) : "",
32
+ onChange
33
+ });
34
+ const { handleFocus, handleBlur, handleChange, handlePaste } = useTextarea({
35
+ maxLength,
36
+ value,
37
+ onChange: setValue,
38
+ onFocus,
39
+ onBlur
40
+ });
41
+ const { isDisabled, isLoading } = useFormFieldState(disabled, state);
42
+ const ariaProps = getAriaProps(state, props["aria-describedby"], required, messageId);
43
+ const currentLength = value?.length || 0;
44
+ const textareaClasses = getTextareaClasses(state, className);
45
+ const getCSSCustomProperties = () => ({
46
+ "--textarea-min-height": "6rem",
47
+ "--textarea-max-height": "12rem",
48
+ "--textarea-border-radius": "0.5rem"
49
+ });
50
+ return /* @__PURE__ */ jsxs("div", {
26
51
  className: "w-full",
27
52
  children: [
28
- T && /* @__PURE__ */ f(l, {
53
+ label && /* @__PURE__ */ jsx(Label, {
29
54
  "data-testid": "spectral-textarea-label",
30
- htmlFor: R,
31
- className: t("mb-2 block", X && "cursor-not-allowed opacity-50", E),
32
- children: T
55
+ htmlFor: textareaId,
56
+ className: cn("mb-2 block", isDisabled && "cursor-not-allowed opacity-50", labelClassName),
57
+ children: label
33
58
  }),
34
- /* @__PURE__ */ p("div", {
59
+ /* @__PURE__ */ jsxs("div", {
35
60
  className: "relative",
36
61
  children: [
37
- /* @__PURE__ */ f("textarea", {
62
+ /* @__PURE__ */ jsx("textarea", {
38
63
  "aria-multiline": "true",
39
- autoComplete: h(y),
40
- className: te,
41
- "data-state": P,
64
+ autoComplete: getAutoCompleteValue(autoComplete),
65
+ className: textareaClasses,
66
+ "data-state": state,
42
67
  "data-testid": "spectral-textarea",
43
- disabled: X,
44
- id: R,
45
- name: O,
46
- onBlur: q,
47
- onChange: J,
48
- onFocus: K,
49
- onPaste: Y,
50
- placeholder: M,
51
- ref: U,
52
- required: N,
68
+ disabled: isDisabled,
69
+ id: textareaId,
70
+ name,
71
+ onBlur: handleBlur,
72
+ onChange: handleChange,
73
+ onFocus: handleFocus,
74
+ onPaste: handlePaste,
75
+ placeholder,
76
+ ref: textareaRef,
77
+ required,
53
78
  spellCheck: "true",
54
- style: {
55
- "--textarea-min-height": "6rem",
56
- "--textarea-max-height": "12rem",
57
- "--textarea-border-radius": "0.5rem"
58
- },
59
- value: W,
60
- ...Q,
61
- ...L
79
+ style: getCSSCustomProperties(),
80
+ value,
81
+ ...ariaProps,
82
+ ...props
62
83
  }),
63
- Z && /* @__PURE__ */ f("div", {
64
- className: m,
84
+ isLoading && /* @__PURE__ */ jsx("div", {
85
+ className: LOADING_ICON_CLASSES,
65
86
  "data-testid": "spectral-textarea-loading-icon",
66
- children: /* @__PURE__ */ f(e, { size: 24 })
87
+ children: /* @__PURE__ */ jsx(LoaderIcon, { size: 24 })
67
88
  }),
68
- /* @__PURE__ */ p("div", {
69
- "aria-label": $ + " of " + D + " characters used",
89
+ /* @__PURE__ */ jsxs("div", {
90
+ "aria-label": currentLength + " of " + maxLength + " characters used",
70
91
  "aria-live": "polite",
71
- className: g($, D),
92
+ className: getCounterClasses(currentLength, maxLength),
72
93
  "data-testid": "spectral-textarea-counter",
73
94
  role: "status",
74
95
  children: [
75
- $,
96
+ currentLength,
76
97
  "/",
77
- D
98
+ maxLength
78
99
  ]
79
100
  })
80
101
  ]
81
102
  }),
82
- /* @__PURE__ */ f(n, {
103
+ /* @__PURE__ */ jsx(ErrorMessage, {
83
104
  dataTestId: "spectral-textarea-error-message",
84
- id: z,
85
- message: P === "error" ? C : null
105
+ id: errorMessageId,
106
+ message: state === "error" ? errorMessage : null,
107
+ messageReserveLines,
108
+ messageReserveSpace
86
109
  }),
87
- /* @__PURE__ */ f(r, {
110
+ /* @__PURE__ */ jsx(WarningMessage, {
88
111
  dataTestId: "spectral-textarea-warning-message",
89
- id: B,
90
- message: P === "warning" ? I : null
112
+ id: warningMessageId,
113
+ message: state === "warning" ? warningMessage : null,
114
+ messageReserveLines,
115
+ messageReserveSpace
91
116
  })
92
117
  ]
93
118
  });
94
119
  };
95
- _.displayName = "Textarea";
120
+ Textarea.displayName = "Textarea";
121
+
96
122
  //#endregion
97
- export { _ as Textarea };
123
+ export { Textarea };
124
+ //# sourceMappingURL=Textarea.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Textarea.js","names":[],"sources":["../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import { LoaderIcon } from '@components/Icons'\nimport { Label } from '@components/Label/Label'\nimport { useUncontrolledState } from '@hooks/useUncontrolledState'\nimport { ErrorMessage, getAriaProps, getErrorMessageId, getTextareaClasses, useFormFieldId, useFormFieldState, WarningMessage, type BaseFormFieldProps, type FormFieldState } from '@utils/formFieldUtils'\nimport { cn } from '@utils/twUtils'\nimport { useRef, type ComponentProps, type CSSProperties, type FocusEvent, type Ref } from 'react'\nimport { useTextarea } from './TextareaUtils'\n\nexport type TextareaState = FormFieldState\n\ntype AutoCompleteValue = 'on' | 'off' | 'name' | 'email' | 'username' | 'street-address' | (string & {})\n\nexport type TextareaProps = Omit<ComponentProps<'textarea'>, 'onChange'> & {\n className?: string | undefined\n errorMessage?: BaseFormFieldProps['errorMessage']\n id?: string | undefined\n label: string\n labelClassName?: string\n maxLength?: number | undefined\n /** Number of message lines to reserve (default: 1). */\n messageReserveLines?: number\n /** Whether to keep message space reserved when hidden (default: true). */\n messageReserveSpace?: boolean\n name: string\n onBlur?: (e: FocusEvent<HTMLTextAreaElement>) => void\n onChange?: (value: string) => void\n onFocus?: (e: FocusEvent<HTMLTextAreaElement>) => void\n placeholder?: string | undefined\n required?: boolean\n state?: TextareaState\n value?: string | undefined\n warningMessage?: BaseFormFieldProps['errorMessage']\n}\n\nconst LOADING_ICON_CLASSES = 'absolute right-4 top-4'\n\nconst getAutoCompleteValue = (autoComplete?: string): AutoCompleteValue => {\n if (autoComplete) return autoComplete\n return 'off'\n}\n\nconst getCounterClasses = (currentLength: number, maxLength: number): string => {\n const baseClasses = 'absolute bottom-2 right-3 text-xs pointer-events-none z-10 tabular-nums'\n const colorClass = currentLength >= maxLength ? 'text-danger-400' : 'text-text-secondary'\n return cn(baseClasses, colorClass)\n}\n\nexport const Textarea = (\n allProps: TextareaProps & {\n ref?: Ref<HTMLTextAreaElement>\n },\n) => {\n const {\n ref,\n autoComplete,\n className,\n defaultValue,\n disabled,\n errorMessage,\n id,\n label,\n labelClassName,\n maxLength = 280,\n messageReserveLines = 1,\n messageReserveSpace = true,\n name,\n onBlur,\n onChange,\n onFocus,\n placeholder,\n required,\n state = 'default',\n value: valueProp,\n warningMessage,\n ...props\n } = allProps\n const textareaId = useFormFieldId(id, name)\n const errorMessageId = getErrorMessageId(textareaId)\n const warningMessageId = `${textareaId}-warning`\n const messageId = state === 'error' ? errorMessageId : state === 'warning' && warningMessage ? warningMessageId : undefined\n const internalRef = useRef<HTMLTextAreaElement>(null)\n const textareaRef = ref ?? internalRef\n const normalizedDefaultValue = typeof defaultValue === 'string' ? defaultValue : defaultValue !== undefined && defaultValue !== null ? String(defaultValue) : ''\n const [value, setValue] = useUncontrolledState<string>({\n value: valueProp,\n defaultValue: normalizedDefaultValue,\n onChange,\n })\n\n const { handleFocus, handleBlur, handleChange, handlePaste } = useTextarea({\n maxLength,\n value,\n onChange: setValue,\n onFocus,\n onBlur,\n })\n\n const { isDisabled, isLoading } = useFormFieldState(disabled, state)\n const ariaProps = getAriaProps(state, props['aria-describedby'], required, messageId)\n const currentLength = value?.length || 0\n const textareaClasses = getTextareaClasses(state, className)\n\n const getCSSCustomProperties = () => ({\n '--textarea-min-height': '6rem',\n '--textarea-max-height': '12rem',\n '--textarea-border-radius': '0.5rem',\n })\n\n return (\n <div className='w-full'>\n {label && (\n <Label data-testid='spectral-textarea-label' htmlFor={textareaId} className={cn('mb-2 block', isDisabled && 'cursor-not-allowed opacity-50', labelClassName)}>\n {label}\n </Label>\n )}\n <div className='relative'>\n <textarea\n aria-multiline='true'\n autoComplete={getAutoCompleteValue(autoComplete)}\n className={textareaClasses}\n data-state={state}\n data-testid='spectral-textarea'\n disabled={isDisabled}\n id={textareaId}\n name={name}\n onBlur={handleBlur}\n onChange={handleChange}\n onFocus={handleFocus}\n onPaste={handlePaste}\n placeholder={placeholder}\n ref={textareaRef}\n required={required}\n spellCheck='true'\n style={getCSSCustomProperties() as CSSProperties}\n value={value}\n {...ariaProps}\n {...props}\n />\n\n {isLoading && (\n <div className={LOADING_ICON_CLASSES} data-testid='spectral-textarea-loading-icon'>\n <LoaderIcon size={24} />\n </div>\n )}\n\n <div\n // oxlint will throw an error when passing ternaries in for aria-label\n aria-label={currentLength + ' of ' + maxLength + ' characters used'}\n aria-live='polite'\n className={getCounterClasses(currentLength, maxLength)}\n data-testid='spectral-textarea-counter'\n role='status'\n >\n {currentLength}/{maxLength}\n </div>\n </div>\n\n <ErrorMessage dataTestId='spectral-textarea-error-message' id={errorMessageId} message={state === 'error' ? errorMessage : null} messageReserveLines={messageReserveLines} messageReserveSpace={messageReserveSpace} />\n <WarningMessage dataTestId='spectral-textarea-warning-message' id={warningMessageId} message={state === 'warning' ? warningMessage : null} messageReserveLines={messageReserveLines} messageReserveSpace={messageReserveSpace} />\n </div>\n )\n}\nTextarea.displayName = 'Textarea'\n"],"mappings":";;;;;;;;;;;;AAkCA,MAAM,uBAAuB;AAE7B,MAAM,wBAAwB,iBAA6C;AACzE,KAAI,aAAc,QAAO;AACzB,QAAO;;AAGT,MAAM,qBAAqB,eAAuB,cAA8B;AAG9E,QAAO,GAAG,2EADS,iBAAiB,YAAY,oBAAoB,sBAClC;;AAGpC,MAAa,YACX,aAGG;CACH,MAAM,EACJ,KACA,cACA,WACA,cACA,UACA,cACA,IACA,OACA,gBACA,YAAY,KACZ,sBAAsB,GACtB,sBAAsB,MACtB,MACA,QACA,UACA,SACA,aACA,UACA,QAAQ,WACR,OAAO,WACP,gBACA,GAAG,UACD;CACJ,MAAM,aAAa,eAAe,IAAI,KAAK;CAC3C,MAAM,iBAAiB,kBAAkB,WAAW;CACpD,MAAM,mBAAmB,GAAG,WAAW;CACvC,MAAM,YAAY,UAAU,UAAU,iBAAiB,UAAU,aAAa,iBAAiB,mBAAmB;CAClH,MAAM,cAAc,OAA4B,KAAK;CACrD,MAAM,cAAc,OAAO;CAE3B,MAAM,CAAC,OAAO,YAAY,qBAA6B;EACrD,OAAO;EACP,cAH6B,OAAO,iBAAiB,WAAW,eAAe,iBAAiB,UAAa,iBAAiB,OAAO,OAAO,aAAa,GAAG;EAI5J;EACD,CAAC;CAEF,MAAM,EAAE,aAAa,YAAY,cAAc,gBAAgB,YAAY;EACzE;EACA;EACA,UAAU;EACV;EACA;EACD,CAAC;CAEF,MAAM,EAAE,YAAY,cAAc,kBAAkB,UAAU,MAAM;CACpE,MAAM,YAAY,aAAa,OAAO,MAAM,qBAAqB,UAAU,UAAU;CACrF,MAAM,gBAAgB,OAAO,UAAU;CACvC,MAAM,kBAAkB,mBAAmB,OAAO,UAAU;CAE5D,MAAM,gCAAgC;EACpC,yBAAyB;EACzB,yBAAyB;EACzB,4BAA4B;EAC7B;AAED,QACE,qBAAC,OAAD;EAAK,WAAU;YAAf;GACG,SACC,oBAAC,OAAD;IAAO,eAAY;IAA0B,SAAS;IAAY,WAAW,GAAG,cAAc,cAAc,iCAAiC,eAAe;cACzJ;IACK;GAEV,qBAAC,OAAD;IAAK,WAAU;cAAf;KACE,oBAAC,YAAD;MACE,kBAAe;MACf,cAAc,qBAAqB,aAAa;MAChD,WAAW;MACX,cAAY;MACZ,eAAY;MACZ,UAAU;MACV,IAAI;MACE;MACN,QAAQ;MACR,UAAU;MACV,SAAS;MACT,SAAS;MACI;MACb,KAAK;MACK;MACV,YAAW;MACX,OAAO,wBAAwB;MACxB;MACP,GAAI;MACJ,GAAI;MACJ;KAED,aACC,oBAAC,OAAD;MAAK,WAAW;MAAsB,eAAY;gBAChD,oBAAC,YAAD,EAAY,MAAM,IAAM;MACpB;KAGR,qBAAC,OAAD;MAEE,cAAY,gBAAgB,SAAS,YAAY;MACjD,aAAU;MACV,WAAW,kBAAkB,eAAe,UAAU;MACtD,eAAY;MACZ,MAAK;gBANP;OAQG;OAAc;OAAE;OACb;;KACF;;GAEN,oBAAC,cAAD;IAAc,YAAW;IAAkC,IAAI;IAAgB,SAAS,UAAU,UAAU,eAAe;IAA2B;IAA0C;IAAuB;GACvN,oBAAC,gBAAD;IAAgB,YAAW;IAAoC,IAAI;IAAkB,SAAS,UAAU,YAAY,iBAAiB;IAA2B;IAA0C;IAAuB;GAC7N;;;AAGV,SAAS,cAAc"}
package/dist/Toast.d.ts CHANGED
@@ -1,43 +1,72 @@
1
- import { VariantProps } from 'class-variance-authority';
2
- import { ReactNode } from 'react';
3
- import { ToasterProps as SonnerToasterProps } from 'sonner';
1
+ 'use client';
2
+ import { ReactNode } from "react";
3
+ import * as _$react_jsx_runtime0 from "react/jsx-runtime";
4
+ import { VariantProps } from "class-variance-authority";
5
+ import { ToasterProps as ToasterProps$1 } from "sonner";
6
+ import * as _$class_variance_authority_types0 from "class-variance-authority/types";
7
+
8
+ //#region src/components/Toast/Toast.d.ts
4
9
  type ToastVariant = 'default' | 'success' | 'error' | 'info' | 'warning';
5
10
  type ToastPosition = 'top-left' | 'top-center' | 'top-right' | 'bottom-left' | 'bottom-center' | 'bottom-right';
6
- export interface ToastProps extends VariantProps<typeof toastVariants> {
7
- className?: string;
8
- containerAriaLabel?: string;
9
- dataTestId?: string;
10
- message?: string | ReactNode;
11
- duration?: number;
12
- icon?: ReactNode;
13
- id?: string | number;
14
- onAutoClose?: () => void;
15
- position?: ToastPosition;
16
- variant?: ToastVariant;
11
+ interface ToastProps extends VariantProps<typeof toastVariants> {
12
+ className?: string;
13
+ containerAriaLabel?: string;
14
+ dataTestId?: string;
15
+ message?: string | ReactNode;
16
+ duration?: number;
17
+ icon?: ReactNode;
18
+ id?: string | number;
19
+ onAutoClose?: () => void;
20
+ position?: ToastPosition;
21
+ variant?: ToastVariant;
17
22
  }
18
- export interface ToasterProps extends Omit<SonnerToasterProps, 'toastOptions'> {
19
- gap?: number;
20
- offset?: number | string;
21
- position?: ToastPosition;
22
- visibleToasts?: number;
23
+ interface ToasterProps extends Omit<ToasterProps$1, 'toastOptions'> {
24
+ gap?: number;
25
+ offset?: number | string;
26
+ position?: ToastPosition;
27
+ visibleToasts?: number;
23
28
  }
24
29
  declare const toastVariants: (props?: ({
25
- variant?: "default" | "success" | "warning" | "info" | "error" | null | undefined;
26
- } & import('class-variance-authority/types').ClassProp) | undefined) => string;
27
- export declare const Toast: {
28
- ({ className, containerAriaLabel, dataTestId, icon, message, variant }: ToastProps): import("react/jsx-runtime").JSX.Element;
29
- displayName: string;
30
+ variant?: "default" | "error" | "info" | "success" | "warning" | null | undefined;
31
+ } & _$class_variance_authority_types0.ClassProp) | undefined) => string;
32
+ declare const Toast: {
33
+ ({
34
+ className,
35
+ containerAriaLabel,
36
+ dataTestId,
37
+ icon,
38
+ message,
39
+ variant
40
+ }: ToastProps): _$react_jsx_runtime0.JSX.Element;
41
+ displayName: string;
30
42
  } & {
31
- Provider: {
32
- ({ gap, offset, position, visibleToasts, ...props }: ToasterProps): import("react/jsx-runtime").JSX.Element;
33
- displayName: string;
34
- };
43
+ Provider: {
44
+ ({
45
+ gap,
46
+ offset,
47
+ position,
48
+ visibleToasts,
49
+ ...props
50
+ }: ToasterProps): _$react_jsx_runtime0.JSX.Element;
51
+ displayName: string;
52
+ };
35
53
  };
36
- export declare const toast: (({ className, containerAriaLabel, dataTestId, duration, icon, message, onAutoClose, position, variant }: ToastProps) => string | number) & {
37
- success: (options: Omit<ToastProps, "variant">) => string | number;
38
- error: (options: Omit<ToastProps, "variant">) => string | number;
39
- info: (options: Omit<ToastProps, "variant">) => string | number;
40
- warning: (options: Omit<ToastProps, "variant">) => string | number;
54
+ declare const toast: (({
55
+ className,
56
+ containerAriaLabel,
57
+ dataTestId,
58
+ duration,
59
+ icon,
60
+ message,
61
+ onAutoClose,
62
+ position,
63
+ variant
64
+ }: ToastProps) => string | number) & {
65
+ success: (options: Omit<ToastProps, 'variant'>) => string | number;
66
+ error: (options: Omit<ToastProps, 'variant'>) => string | number;
67
+ info: (options: Omit<ToastProps, 'variant'>) => string | number;
68
+ warning: (options: Omit<ToastProps, 'variant'>) => string | number;
41
69
  };
42
- export {};
70
+ //#endregion
71
+ export { Toast, ToastProps, ToasterProps, toast };
43
72
  //# sourceMappingURL=Toast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.d.ts","names":[],"sources":["../src/components/Toast/Toast.tsx"],"mappings":";;;;;;;;KAMK,YAAA;AAAA,KACA,aAAA;AAAA,UAEY,UAAA,SAAmB,YAAA,QAAoB,aAAA;EACtD,SAAA;EACA,kBAAA;EACA,UAAA;EACA,OAAA,YAAmB,SAAA;EACnB,QAAA;EACA,IAAA,GAAO,SAAA;EACP,EAAA;EACA,WAAA;EACA,QAAA,GAAW,aAAA;EACX,OAAA,GAAU,YAAA;AAAA;AAAA,UAGK,YAAA,SAAqB,IAAA,CAAK,cAAA;EACzC,GAAA;EACA,MAAA;EACA,QAAA,GAAW,aAAA;EACX,aAAA;AAAA;AAAA,cAGI,aAAA,GAAa,KAAA;;IAajB,iCAAA,CAAA,SAAA;AAAA,cAuEW,KAAA;EAAA;;;;;;;KA3B+G,UAAA,GAAU,oBAAA,CAAA,GAAA,CAAA,OAAA;;;;;;;;;;OAnB5B,YAAA,GAAY,oBAAA,CAAA,GAAA,CAAA,OAAA;;;;cAkDzG,KAAA;EAAK,SAAA;EAAA,kBAAA;EAAA,UAAA;EAAA,QAAA;EAAA,IAAA;EAAA,OAAA;EAAA,WAAA;EAAA,QAAA;EAAA;AAAA,GAZ4H,UAAA;qBAazH,IAAA,CAAK,UAAA;mBACP,IAAA,CAAK,UAAA;kBACN,IAAA,CAAK,UAAA;qBACF,IAAA,CAAK,UAAA;AAAA"}
package/dist/Toast.js CHANGED
@@ -1,3 +1,115 @@
1
- 'use client'
2
- import { n as e, t } from "./Toast-BuaZxqlt.js";
3
- export { t as Toast, e as toast };
1
+ 'use client';
2
+ import { CheckSquareIcon } from "./Icons/CheckSquareIcon.js";
3
+ import { CloseCircleIcon } from "./Icons/CloseCircleIcon.js";
4
+ import { InfoIcon } from "./Icons/InfoIcon.js";
5
+ import { WarningIcon } from "./Icons/WarningIcon.js";
6
+ import { cn } from "./utils/twUtils.js";
7
+ import "react";
8
+ import { jsx, jsxs } from "react/jsx-runtime";
9
+ import { cva } from "class-variance-authority";
10
+ import { Toaster, toast as toast$1 } from "sonner";
11
+
12
+ //#region src/components/Toast/Toast.tsx
13
+ const toastVariants = cva("rounded-md px-4 py-3 text-sm gap-3 shadow-lg flex max-w-[420px] min-w-[300px] items-start border", {
14
+ variants: { variant: {
15
+ default: "border-toast-border bg-toast-bg text-toast-text",
16
+ success: "border-toast-success-border bg-toast-success-bg text-toast-success-text",
17
+ error: "border-toast-danger-border bg-toast-danger-bg text-toast-danger-text",
18
+ info: "border-toast-info-border bg-toast-info-bg text-toast-info-text",
19
+ warning: "border-toast-warning-border bg-toast-warning-bg text-toast-warning-text"
20
+ } },
21
+ defaultVariants: { variant: "default" }
22
+ });
23
+ const messageVariants = cva("mt-1 text-sm opacity-90", {
24
+ variants: { variant: {
25
+ default: "text-toast-text",
26
+ success: "text-toast-success-text",
27
+ error: "text-toast-danger-text",
28
+ info: "text-toast-info-text",
29
+ warning: "text-toast-warning-text"
30
+ } },
31
+ defaultVariants: { variant: "default" }
32
+ });
33
+ const variantIcons = {
34
+ default: null,
35
+ success: /* @__PURE__ */ jsx(CheckSquareIcon, { className: "size-5 shrink-0 text-toast-success-icon" }),
36
+ info: /* @__PURE__ */ jsx(InfoIcon, { className: "size-5 shrink-0 text-toast-info-icon" }),
37
+ warning: /* @__PURE__ */ jsx(WarningIcon, { className: "size-5 shrink-0 text-toast-warning-icon" }),
38
+ error: /* @__PURE__ */ jsx(CloseCircleIcon, { className: "size-5 shrink-0 text-toast-danger-icon" })
39
+ };
40
+ const ToastProvider = ({ gap = 14, offset = 32, position = "bottom-right", visibleToasts = 3, ...props }) => {
41
+ return /* @__PURE__ */ jsx(Toaster, {
42
+ position,
43
+ visibleToasts,
44
+ offset,
45
+ gap,
46
+ toastOptions: {
47
+ unstyled: true,
48
+ classNames: { toast: "spectral-toast" }
49
+ },
50
+ ...props
51
+ });
52
+ };
53
+ ToastProvider.displayName = "Toast.Provider";
54
+ const ToastComponent = ({ className, containerAriaLabel = "Notification", dataTestId, icon, message, variant = "default" }) => {
55
+ const resolvedVariant = variant ?? "default";
56
+ const displayIcon = icon ?? variantIcons[resolvedVariant];
57
+ return /* @__PURE__ */ jsxs("div", {
58
+ "aria-label": containerAriaLabel,
59
+ className: cn(toastVariants({ variant: resolvedVariant }), className),
60
+ "data-variant": resolvedVariant,
61
+ "data-testid": dataTestId ?? `spectral-toast-${resolvedVariant}`,
62
+ role: "status",
63
+ "aria-live": "polite",
64
+ children: [displayIcon && /* @__PURE__ */ jsx("div", {
65
+ className: "mt-0.5",
66
+ "aria-hidden": "true",
67
+ children: displayIcon
68
+ }), /* @__PURE__ */ jsx("div", {
69
+ className: "flex flex-col",
70
+ children: /* @__PURE__ */ jsx("p", {
71
+ className: messageVariants({ variant: resolvedVariant }),
72
+ children: message
73
+ })
74
+ })]
75
+ });
76
+ };
77
+ ToastComponent.displayName = "Toast";
78
+ const showToast = ({ className, containerAriaLabel, dataTestId, duration = 4e3, icon, message, onAutoClose, position, variant = "default" }) => {
79
+ return toast$1.custom((id) => /* @__PURE__ */ jsx(ToastComponent, {
80
+ className,
81
+ containerAriaLabel,
82
+ dataTestId,
83
+ icon,
84
+ id,
85
+ message,
86
+ variant
87
+ }), {
88
+ duration,
89
+ onAutoClose,
90
+ position
91
+ });
92
+ };
93
+ const Toast = Object.assign(ToastComponent, { Provider: ToastProvider });
94
+ const toast = Object.assign(showToast, {
95
+ success: (options) => showToast({
96
+ ...options,
97
+ variant: "success"
98
+ }),
99
+ error: (options) => showToast({
100
+ ...options,
101
+ variant: "error"
102
+ }),
103
+ info: (options) => showToast({
104
+ ...options,
105
+ variant: "info"
106
+ }),
107
+ warning: (options) => showToast({
108
+ ...options,
109
+ variant: "warning"
110
+ })
111
+ });
112
+
113
+ //#endregion
114
+ export { Toast, toast };
115
+ //# sourceMappingURL=Toast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toast.js","names":["SonnerToaster","sonnerToast"],"sources":["../src/components/Toast/Toast.tsx"],"sourcesContent":["import { CheckSquareIcon, CloseCircleIcon, InfoIcon, WarningIcon } from '@components/Icons'\nimport { cn } from '@utils/twUtils'\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { type ReactNode } from 'react'\nimport { toast as sonnerToast, Toaster as SonnerToaster, type ToasterProps as SonnerToasterProps } from 'sonner'\n\ntype ToastVariant = 'default' | 'success' | 'error' | 'info' | 'warning'\ntype ToastPosition = 'top-left' | 'top-center' | 'top-right' | 'bottom-left' | 'bottom-center' | 'bottom-right'\n\nexport interface ToastProps extends VariantProps<typeof toastVariants> {\n className?: string\n containerAriaLabel?: string\n dataTestId?: string\n message?: string | ReactNode\n duration?: number\n icon?: ReactNode\n id?: string | number\n onAutoClose?: () => void\n position?: ToastPosition\n variant?: ToastVariant\n}\n\nexport interface ToasterProps extends Omit<SonnerToasterProps, 'toastOptions'> {\n gap?: number\n offset?: number | string\n position?: ToastPosition\n visibleToasts?: number\n}\n\nconst toastVariants = cva('rounded-md px-4 py-3 text-sm gap-3 shadow-lg flex max-w-[420px] min-w-[300px] items-start border', {\n variants: {\n variant: {\n default: 'border-toast-border bg-toast-bg text-toast-text',\n success: 'border-toast-success-border bg-toast-success-bg text-toast-success-text',\n error: 'border-toast-danger-border bg-toast-danger-bg text-toast-danger-text',\n info: 'border-toast-info-border bg-toast-info-bg text-toast-info-text',\n warning: 'border-toast-warning-border bg-toast-warning-bg text-toast-warning-text',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n})\n\nconst messageVariants = cva('mt-1 text-sm opacity-90', {\n variants: {\n variant: {\n default: 'text-toast-text',\n success: 'text-toast-success-text',\n error: 'text-toast-danger-text',\n info: 'text-toast-info-text',\n warning: 'text-toast-warning-text',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n})\n\nconst variantIcons: Record<ToastVariant, ReactNode> = {\n default: null,\n success: <CheckSquareIcon className='size-5 shrink-0 text-toast-success-icon' />,\n info: <InfoIcon className='size-5 shrink-0 text-toast-info-icon' />,\n warning: <WarningIcon className='size-5 shrink-0 text-toast-warning-icon' />,\n error: <CloseCircleIcon className='size-5 shrink-0 text-toast-danger-icon' />,\n}\n\nconst ToastProvider = ({ gap = 14, offset = 32, position = 'bottom-right', visibleToasts = 3, ...props }: ToasterProps) => {\n return (\n <SonnerToaster\n position={position}\n visibleToasts={visibleToasts}\n offset={offset}\n gap={gap}\n toastOptions={{\n unstyled: true,\n classNames: {\n toast: 'spectral-toast',\n },\n }}\n {...props}\n />\n )\n}\nToastProvider.displayName = 'Toast.Provider'\n\nconst ToastComponent = ({ className, containerAriaLabel = 'Notification', dataTestId, icon, message, variant = 'default' }: ToastProps) => {\n const resolvedVariant = variant ?? 'default'\n const displayIcon = icon ?? variantIcons[resolvedVariant]\n\n return (\n <div aria-label={containerAriaLabel} className={cn(toastVariants({ variant: resolvedVariant }), className)} data-variant={resolvedVariant} data-testid={dataTestId ?? `spectral-toast-${resolvedVariant}`} role='status' aria-live='polite'>\n {displayIcon && (\n <div className='mt-0.5' aria-hidden='true'>\n {displayIcon}\n </div>\n )}\n <div className='flex flex-col'>\n <p className={messageVariants({ variant: resolvedVariant })}>{message}</p>\n </div>\n </div>\n )\n}\nToastComponent.displayName = 'Toast'\n\nconst showToast = ({ className, containerAriaLabel, dataTestId, duration = 4000, icon, message, onAutoClose, position, variant = 'default' }: ToastProps) => {\n return sonnerToast.custom((id) => <ToastComponent className={className} containerAriaLabel={containerAriaLabel} dataTestId={dataTestId} icon={icon} id={id} message={message} variant={variant} />, {\n duration,\n onAutoClose,\n position,\n })\n}\n\nexport const Toast = Object.assign(ToastComponent, {\n Provider: ToastProvider,\n})\n\nexport const toast = Object.assign(showToast, {\n success: (options: Omit<ToastProps, 'variant'>) => showToast({ ...options, variant: 'success' }),\n error: (options: Omit<ToastProps, 'variant'>) => showToast({ ...options, variant: 'error' }),\n info: (options: Omit<ToastProps, 'variant'>) => showToast({ ...options, variant: 'info' }),\n warning: (options: Omit<ToastProps, 'variant'>) => showToast({ ...options, variant: 'warning' }),\n})\n"],"mappings":";;;;;;;;;;;;AA6BA,MAAM,gBAAgB,IAAI,oGAAoG;CAC5H,UAAU,EACR,SAAS;EACP,SAAS;EACT,SAAS;EACT,OAAO;EACP,MAAM;EACN,SAAS;EACV,EACF;CACD,iBAAiB,EACf,SAAS,WACV;CACF,CAAC;AAEF,MAAM,kBAAkB,IAAI,2BAA2B;CACrD,UAAU,EACR,SAAS;EACP,SAAS;EACT,SAAS;EACT,OAAO;EACP,MAAM;EACN,SAAS;EACV,EACF;CACD,iBAAiB,EACf,SAAS,WACV;CACF,CAAC;AAEF,MAAM,eAAgD;CACpD,SAAS;CACT,SAAS,oBAAC,iBAAD,EAAiB,WAAU,2CAA4C;CAChF,MAAM,oBAAC,UAAD,EAAU,WAAU,wCAAyC;CACnE,SAAS,oBAAC,aAAD,EAAa,WAAU,2CAA4C;CAC5E,OAAO,oBAAC,iBAAD,EAAiB,WAAU,0CAA2C;CAC9E;AAED,MAAM,iBAAiB,EAAE,MAAM,IAAI,SAAS,IAAI,WAAW,gBAAgB,gBAAgB,GAAG,GAAG,YAA0B;AACzH,QACE,oBAACA,SAAD;EACY;EACK;EACP;EACH;EACL,cAAc;GACZ,UAAU;GACV,YAAY,EACV,OAAO,kBACR;GACF;EACD,GAAI;EACJ;;AAGN,cAAc,cAAc;AAE5B,MAAM,kBAAkB,EAAE,WAAW,qBAAqB,gBAAgB,YAAY,MAAM,SAAS,UAAU,gBAA4B;CACzI,MAAM,kBAAkB,WAAW;CACnC,MAAM,cAAc,QAAQ,aAAa;AAEzC,QACE,qBAAC,OAAD;EAAK,cAAY;EAAoB,WAAW,GAAG,cAAc,EAAE,SAAS,iBAAiB,CAAC,EAAE,UAAU;EAAE,gBAAc;EAAiB,eAAa,cAAc,kBAAkB;EAAmB,MAAK;EAAS,aAAU;YAAnO,CACG,eACC,oBAAC,OAAD;GAAK,WAAU;GAAS,eAAY;aACjC;GACG,GAER,oBAAC,OAAD;GAAK,WAAU;aACb,oBAAC,KAAD;IAAG,WAAW,gBAAgB,EAAE,SAAS,iBAAiB,CAAC;cAAG;IAAY;GACtE,EACF;;;AAGV,eAAe,cAAc;AAE7B,MAAM,aAAa,EAAE,WAAW,oBAAoB,YAAY,WAAW,KAAM,MAAM,SAAS,aAAa,UAAU,UAAU,gBAA4B;AAC3J,QAAOC,QAAY,QAAQ,OAAO,oBAAC,gBAAD;EAA2B;EAA+B;EAAgC;EAAkB;EAAU;EAAa;EAAkB;EAAW,GAAE;EAClM;EACA;EACA;EACD,CAAC;;AAGJ,MAAa,QAAQ,OAAO,OAAO,gBAAgB,EACjD,UAAU,eACX,CAAC;AAEF,MAAa,QAAQ,OAAO,OAAO,WAAW;CAC5C,UAAU,YAAyC,UAAU;EAAE,GAAG;EAAS,SAAS;EAAW,CAAC;CAChG,QAAQ,YAAyC,UAAU;EAAE,GAAG;EAAS,SAAS;EAAS,CAAC;CAC5F,OAAO,YAAyC,UAAU;EAAE,GAAG;EAAS,SAAS;EAAQ,CAAC;CAC1F,UAAU,YAAyC,UAAU;EAAE,GAAG;EAAS,SAAS;EAAW,CAAC;CACjG,CAAC"}