@masaraxui/react 1.0.0

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 (398) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +50 -0
  3. package/dist/components/accordion/accordion.d.ts +30 -0
  4. package/dist/components/accordion/accordion.js +191 -0
  5. package/dist/components/accordion/index.d.ts +25 -0
  6. package/dist/components/accordion/index.js +18 -0
  7. package/dist/components/alert/alert.d.ts +15 -0
  8. package/dist/components/alert/alert.js +152 -0
  9. package/dist/components/alert/index.d.ts +21 -0
  10. package/dist/components/alert/index.js +16 -0
  11. package/dist/components/alert-dialog/alert-dialog.d.ts +65 -0
  12. package/dist/components/alert-dialog/alert-dialog.js +309 -0
  13. package/dist/components/alert-dialog/index.d.ts +33 -0
  14. package/dist/components/alert-dialog/index.js +22 -0
  15. package/dist/components/autocomplete/autocomplete.d.ts +31 -0
  16. package/dist/components/autocomplete/autocomplete.js +241 -0
  17. package/dist/components/autocomplete/index.d.ts +25 -0
  18. package/dist/components/autocomplete/index.js +18 -0
  19. package/dist/components/avatar/avatar.d.ts +15 -0
  20. package/dist/components/avatar/avatar.js +93 -0
  21. package/dist/components/avatar/index.d.ts +17 -0
  22. package/dist/components/avatar/index.js +14 -0
  23. package/dist/components/badge/badge.d.ts +19 -0
  24. package/dist/components/badge/badge.js +87 -0
  25. package/dist/components/badge/index.d.ts +17 -0
  26. package/dist/components/badge/index.js +14 -0
  27. package/dist/components/breadcrumbs/breadcrumbs.d.ts +14 -0
  28. package/dist/components/breadcrumbs/breadcrumbs.js +84 -0
  29. package/dist/components/breadcrumbs/index.d.ts +15 -0
  30. package/dist/components/breadcrumbs/index.js +13 -0
  31. package/dist/components/button/button.d.ts +10 -0
  32. package/dist/components/button/button.js +49 -0
  33. package/dist/components/button/index.d.ts +15 -0
  34. package/dist/components/button/index.js +13 -0
  35. package/dist/components/button-group/button-group.d.ts +26 -0
  36. package/dist/components/button-group/button-group.js +82 -0
  37. package/dist/components/button-group/index.d.ts +16 -0
  38. package/dist/components/button-group/index.js +14 -0
  39. package/dist/components/calendar/calendar.d.ts +71 -0
  40. package/dist/components/calendar/calendar.js +283 -0
  41. package/dist/components/calendar/index.d.ts +91 -0
  42. package/dist/components/calendar/index.js +29 -0
  43. package/dist/components/calendar-year-picker/calendar-year-picker.d.ts +61 -0
  44. package/dist/components/calendar-year-picker/calendar-year-picker.js +411 -0
  45. package/dist/components/calendar-year-picker/index.d.ts +43 -0
  46. package/dist/components/calendar-year-picker/index.js +18 -0
  47. package/dist/components/calendar-year-picker/year-picker-context.d.ts +28 -0
  48. package/dist/components/calendar-year-picker/year-picker-context.js +39 -0
  49. package/dist/components/card/card.d.ts +22 -0
  50. package/dist/components/card/card.js +141 -0
  51. package/dist/components/card/index.d.ts +23 -0
  52. package/dist/components/card/index.js +17 -0
  53. package/dist/components/checkbox/checkbox.d.ts +22 -0
  54. package/dist/components/checkbox/checkbox.js +124 -0
  55. package/dist/components/checkbox/index.d.ts +19 -0
  56. package/dist/components/checkbox/index.js +15 -0
  57. package/dist/components/checkbox-group/checkbox-group.d.ts +14 -0
  58. package/dist/components/checkbox-group/checkbox-group.js +33 -0
  59. package/dist/components/checkbox-group/index.d.ts +3 -0
  60. package/dist/components/checkbox-group/index.js +3 -0
  61. package/dist/components/chip/chip.d.ts +14 -0
  62. package/dist/components/chip/chip.js +67 -0
  63. package/dist/components/chip/index.d.ts +15 -0
  64. package/dist/components/chip/index.js +13 -0
  65. package/dist/components/close-button/close-button.d.ts +8 -0
  66. package/dist/components/close-button/close-button.js +33 -0
  67. package/dist/components/close-button/index.d.ts +13 -0
  68. package/dist/components/close-button/index.js +12 -0
  69. package/dist/components/color-area/color-area.d.ts +11 -0
  70. package/dist/components/color-area/color-area.js +70 -0
  71. package/dist/components/color-area/index.d.ts +15 -0
  72. package/dist/components/color-area/index.js +13 -0
  73. package/dist/components/color-field/color-field.d.ts +9 -0
  74. package/dist/components/color-field/color-field.js +29 -0
  75. package/dist/components/color-field/index.d.ts +22 -0
  76. package/dist/components/color-field/index.js +18 -0
  77. package/dist/components/color-input-group/color-input-group.d.ts +19 -0
  78. package/dist/components/color-input-group/color-input-group.js +98 -0
  79. package/dist/components/color-input-group/index.d.ts +19 -0
  80. package/dist/components/color-input-group/index.js +15 -0
  81. package/dist/components/color-picker/color-picker.d.ts +21 -0
  82. package/dist/components/color-picker/color-picker.js +86 -0
  83. package/dist/components/color-picker/index.d.ts +17 -0
  84. package/dist/components/color-picker/index.js +14 -0
  85. package/dist/components/color-slider/color-slider.d.ts +50 -0
  86. package/dist/components/color-slider/color-slider.js +205 -0
  87. package/dist/components/color-slider/index.d.ts +19 -0
  88. package/dist/components/color-slider/index.js +15 -0
  89. package/dist/components/color-swatch/color-swatch.d.ts +8 -0
  90. package/dist/components/color-swatch/color-swatch.js +31 -0
  91. package/dist/components/color-swatch/index.d.ts +13 -0
  92. package/dist/components/color-swatch/index.js +12 -0
  93. package/dist/components/color-swatch-picker/color-swatch-picker.d.ts +20 -0
  94. package/dist/components/color-swatch-picker/color-swatch-picker.js +149 -0
  95. package/dist/components/color-swatch-picker/index.d.ts +19 -0
  96. package/dist/components/color-swatch-picker/index.js +15 -0
  97. package/dist/components/combo-box/combo-box.d.ts +34 -0
  98. package/dist/components/combo-box/combo-box.js +116 -0
  99. package/dist/components/combo-box/index.d.ts +20 -0
  100. package/dist/components/combo-box/index.js +16 -0
  101. package/dist/components/date-field/date-field.d.ts +9 -0
  102. package/dist/components/date-field/date-field.js +29 -0
  103. package/dist/components/date-field/index.d.ts +26 -0
  104. package/dist/components/date-field/index.js +20 -0
  105. package/dist/components/date-input-group/date-input-group.d.ts +25 -0
  106. package/dist/components/date-input-group/date-input-group.js +146 -0
  107. package/dist/components/date-input-group/index.d.ts +23 -0
  108. package/dist/components/date-input-group/index.js +17 -0
  109. package/dist/components/date-picker/date-picker.d.ts +30 -0
  110. package/dist/components/date-picker/date-picker.js +151 -0
  111. package/dist/components/date-picker/index.d.ts +31 -0
  112. package/dist/components/date-picker/index.js +15 -0
  113. package/dist/components/date-range-picker/date-range-picker.d.ts +36 -0
  114. package/dist/components/date-range-picker/date-range-picker.js +173 -0
  115. package/dist/components/date-range-picker/index.d.ts +36 -0
  116. package/dist/components/date-range-picker/index.js +16 -0
  117. package/dist/components/description/description.d.ts +9 -0
  118. package/dist/components/description/description.js +22 -0
  119. package/dist/components/description/index.d.ts +13 -0
  120. package/dist/components/description/index.js +12 -0
  121. package/dist/components/disclosure/disclosure.d.ts +27 -0
  122. package/dist/components/disclosure/disclosure.js +157 -0
  123. package/dist/components/disclosure/index.d.ts +23 -0
  124. package/dist/components/disclosure/index.js +17 -0
  125. package/dist/components/disclosure-group/disclosure-group.d.ts +8 -0
  126. package/dist/components/disclosure-group/disclosure-group.js +35 -0
  127. package/dist/components/disclosure-group/index.d.ts +15 -0
  128. package/dist/components/disclosure-group/index.js +13 -0
  129. package/dist/components/disclosure-group/use-disclosure-group-navigation.d.ts +14 -0
  130. package/dist/components/disclosure-group/use-disclosure-group-navigation.js +51 -0
  131. package/dist/components/drawer/drawer.d.ts +84 -0
  132. package/dist/components/drawer/drawer.js +439 -0
  133. package/dist/components/drawer/index.d.ts +69 -0
  134. package/dist/components/drawer/index.js +22 -0
  135. package/dist/components/dropdown/dropdown.d.ts +38 -0
  136. package/dist/components/dropdown/dropdown.js +156 -0
  137. package/dist/components/dropdown/index.d.ts +29 -0
  138. package/dist/components/dropdown/index.js +20 -0
  139. package/dist/components/empty-state/empty-state.d.ts +7 -0
  140. package/dist/components/empty-state/empty-state.js +20 -0
  141. package/dist/components/empty-state/index.d.ts +13 -0
  142. package/dist/components/empty-state/index.js +12 -0
  143. package/dist/components/error-message/error-message.d.ts +9 -0
  144. package/dist/components/error-message/error-message.js +22 -0
  145. package/dist/components/error-message/index.d.ts +13 -0
  146. package/dist/components/error-message/index.js +12 -0
  147. package/dist/components/field-error/field-error.d.ts +8 -0
  148. package/dist/components/field-error/field-error.js +21 -0
  149. package/dist/components/field-error/index.d.ts +13 -0
  150. package/dist/components/field-error/index.js +12 -0
  151. package/dist/components/fieldset/fieldset.d.ts +16 -0
  152. package/dist/components/fieldset/fieldset.js +88 -0
  153. package/dist/components/fieldset/index.d.ts +19 -0
  154. package/dist/components/fieldset/index.js +15 -0
  155. package/dist/components/form/form.d.ts +7 -0
  156. package/dist/components/form/form.js +13 -0
  157. package/dist/components/form/index.d.ts +11 -0
  158. package/dist/components/form/index.js +11 -0
  159. package/dist/components/header/header.d.ts +7 -0
  160. package/dist/components/header/header.js +21 -0
  161. package/dist/components/header/index.d.ts +9 -0
  162. package/dist/components/header/index.js +10 -0
  163. package/dist/components/icons.d.ts +18 -0
  164. package/dist/components/icons.js +243 -0
  165. package/dist/components/index.d.ts +84 -0
  166. package/dist/components/input/index.d.ts +13 -0
  167. package/dist/components/input/index.js +12 -0
  168. package/dist/components/input/input.d.ts +8 -0
  169. package/dist/components/input/input.js +31 -0
  170. package/dist/components/input-group/index.d.ts +21 -0
  171. package/dist/components/input-group/index.js +16 -0
  172. package/dist/components/input-group/input-group.d.ts +20 -0
  173. package/dist/components/input-group/input-group.js +129 -0
  174. package/dist/components/input-otp/index.d.ts +22 -0
  175. package/dist/components/input-otp/index.js +21 -0
  176. package/dist/components/input-otp/input-otp.d.ts +26 -0
  177. package/dist/components/input-otp/input-otp.js +139 -0
  178. package/dist/components/kbd/index.d.ts +19 -0
  179. package/dist/components/kbd/index.js +15 -0
  180. package/dist/components/kbd/kbd.constants.d.ts +3 -0
  181. package/dist/components/kbd/kbd.constants.js +51 -0
  182. package/dist/components/kbd/kbd.d.ts +24 -0
  183. package/dist/components/kbd/kbd.js +76 -0
  184. package/dist/components/label/index.d.ts +13 -0
  185. package/dist/components/label/index.js +12 -0
  186. package/dist/components/label/label.d.ts +8 -0
  187. package/dist/components/label/label.js +27 -0
  188. package/dist/components/link/index.d.ts +15 -0
  189. package/dist/components/link/index.js +13 -0
  190. package/dist/components/link/link.d.ts +10 -0
  191. package/dist/components/link/link.js +59 -0
  192. package/dist/components/list-box/index.d.ts +23 -0
  193. package/dist/components/list-box/index.js +18 -0
  194. package/dist/components/list-box/list-box.d.ts +9 -0
  195. package/dist/components/list-box/list-box.js +23 -0
  196. package/dist/components/list-box-item/index.d.ts +15 -0
  197. package/dist/components/list-box-item/index.js +13 -0
  198. package/dist/components/list-box-item/list-box-item.d.ts +15 -0
  199. package/dist/components/list-box-item/list-box-item.js +77 -0
  200. package/dist/components/list-box-section/index.d.ts +10 -0
  201. package/dist/components/list-box-section/index.js +10 -0
  202. package/dist/components/list-box-section/list-box-section.d.ts +8 -0
  203. package/dist/components/list-box-section/list-box-section.js +22 -0
  204. package/dist/components/menu/index.d.ts +24 -0
  205. package/dist/components/menu/index.js +18 -0
  206. package/dist/components/menu/menu.d.ts +9 -0
  207. package/dist/components/menu/menu.js +20 -0
  208. package/dist/components/menu-item/index.d.ts +17 -0
  209. package/dist/components/menu-item/index.js +14 -0
  210. package/dist/components/menu-item/menu-item.d.ts +20 -0
  211. package/dist/components/menu-item/menu-item.js +123 -0
  212. package/dist/components/menu-section/index.d.ts +10 -0
  213. package/dist/components/menu-section/index.js +10 -0
  214. package/dist/components/menu-section/menu-section.d.ts +8 -0
  215. package/dist/components/menu-section/menu-section.js +22 -0
  216. package/dist/components/meter/index.d.ts +34 -0
  217. package/dist/components/meter/index.js +15 -0
  218. package/dist/components/meter/meter.d.ts +29 -0
  219. package/dist/components/meter/meter.js +108 -0
  220. package/dist/components/modal/index.d.ts +33 -0
  221. package/dist/components/modal/index.js +22 -0
  222. package/dist/components/modal/modal.d.ts +53 -0
  223. package/dist/components/modal/modal.js +288 -0
  224. package/dist/components/number-field/index.d.ts +21 -0
  225. package/dist/components/number-field/index.js +16 -0
  226. package/dist/components/number-field/number-field.d.ts +20 -0
  227. package/dist/components/number-field/number-field.js +127 -0
  228. package/dist/components/pagination/index.d.ts +64 -0
  229. package/dist/components/pagination/index.js +21 -0
  230. package/dist/components/pagination/pagination.d.ts +84 -0
  231. package/dist/components/pagination/pagination.js +230 -0
  232. package/dist/components/popover/index.d.ts +23 -0
  233. package/dist/components/popover/index.js +17 -0
  234. package/dist/components/popover/popover.d.ts +24 -0
  235. package/dist/components/popover/popover.js +153 -0
  236. package/dist/components/progress-bar/index.d.ts +34 -0
  237. package/dist/components/progress-bar/index.js +15 -0
  238. package/dist/components/progress-bar/progress-bar.d.ts +29 -0
  239. package/dist/components/progress-bar/progress-bar.js +108 -0
  240. package/dist/components/progress-circle/index.d.ts +34 -0
  241. package/dist/components/progress-circle/index.js +15 -0
  242. package/dist/components/progress-circle/progress-circle.d.ts +29 -0
  243. package/dist/components/progress-circle/progress-circle.js +126 -0
  244. package/dist/components/rac/components.d.ts +1 -0
  245. package/dist/components/rac/index.d.ts +5 -0
  246. package/dist/components/rac/index.js +3 -0
  247. package/dist/components/rac/types.d.ts +3 -0
  248. package/dist/components/rac/utils.d.ts +1 -0
  249. package/dist/components/radio/index.d.ts +19 -0
  250. package/dist/components/radio/index.js +15 -0
  251. package/dist/components/radio/radio.d.ts +21 -0
  252. package/dist/components/radio/radio.js +97 -0
  253. package/dist/components/radio-group/index.d.ts +13 -0
  254. package/dist/components/radio-group/index.js +12 -0
  255. package/dist/components/radio-group/radio-group.d.ts +8 -0
  256. package/dist/components/radio-group/radio-group.js +27 -0
  257. package/dist/components/range-calendar/index.d.ts +91 -0
  258. package/dist/components/range-calendar/index.js +29 -0
  259. package/dist/components/range-calendar/range-calendar.d.ts +71 -0
  260. package/dist/components/range-calendar/range-calendar.js +298 -0
  261. package/dist/components/scroll-shadow/index.d.ts +21 -0
  262. package/dist/components/scroll-shadow/index.js +13 -0
  263. package/dist/components/scroll-shadow/scroll-shadow.d.ts +32 -0
  264. package/dist/components/scroll-shadow/scroll-shadow.js +76 -0
  265. package/dist/components/scroll-shadow/use-scroll-shadow.d.ts +11 -0
  266. package/dist/components/scroll-shadow/use-scroll-shadow.js +121 -0
  267. package/dist/components/search-field/index.d.ts +21 -0
  268. package/dist/components/search-field/index.js +16 -0
  269. package/dist/components/search-field/search-field.d.ts +23 -0
  270. package/dist/components/search-field/search-field.js +127 -0
  271. package/dist/components/select/index.d.ts +21 -0
  272. package/dist/components/select/index.js +16 -0
  273. package/dist/components/select/select.d.ts +24 -0
  274. package/dist/components/select/select.js +140 -0
  275. package/dist/components/separator/index.d.ts +13 -0
  276. package/dist/components/separator/index.js +12 -0
  277. package/dist/components/separator/separator.d.ts +8 -0
  278. package/dist/components/separator/separator.js +27 -0
  279. package/dist/components/skeleton/index.d.ts +13 -0
  280. package/dist/components/skeleton/index.js +12 -0
  281. package/dist/components/skeleton/skeleton.d.ts +7 -0
  282. package/dist/components/skeleton/skeleton.js +25 -0
  283. package/dist/components/slider/index.d.ts +23 -0
  284. package/dist/components/slider/index.js +17 -0
  285. package/dist/components/slider/slider.d.ts +23 -0
  286. package/dist/components/slider/slider.js +177 -0
  287. package/dist/components/spinner/index.d.ts +13 -0
  288. package/dist/components/spinner/index.js +12 -0
  289. package/dist/components/spinner/spinner.d.ts +7 -0
  290. package/dist/components/spinner/spinner.js +88 -0
  291. package/dist/components/surface/index.d.ts +14 -0
  292. package/dist/components/surface/index.js +13 -0
  293. package/dist/components/surface/surface.d.ts +12 -0
  294. package/dist/components/surface/surface.js +34 -0
  295. package/dist/components/switch/index.d.ts +21 -0
  296. package/dist/components/switch/index.js +16 -0
  297. package/dist/components/switch/switch.d.ts +20 -0
  298. package/dist/components/switch/switch.js +118 -0
  299. package/dist/components/switch-group/index.d.ts +13 -0
  300. package/dist/components/switch-group/index.js +12 -0
  301. package/dist/components/switch-group/switch-group.d.ts +7 -0
  302. package/dist/components/switch-group/switch-group.js +25 -0
  303. package/dist/components/table/index.d.ts +38 -0
  304. package/dist/components/table/index.js +25 -0
  305. package/dist/components/table/table.d.ts +50 -0
  306. package/dist/components/table/table.js +283 -0
  307. package/dist/components/tabs/index.d.ts +25 -0
  308. package/dist/components/tabs/index.js +18 -0
  309. package/dist/components/tabs/tabs.d.ts +37 -0
  310. package/dist/components/tabs/tabs.js +156 -0
  311. package/dist/components/tag/index.d.ts +15 -0
  312. package/dist/components/tag/index.js +13 -0
  313. package/dist/components/tag/tag.d.ts +14 -0
  314. package/dist/components/tag/tag.js +85 -0
  315. package/dist/components/tag-group/index.d.ts +15 -0
  316. package/dist/components/tag-group/index.js +14 -0
  317. package/dist/components/tag-group/tag-group.d.ts +20 -0
  318. package/dist/components/tag-group/tag-group.js +59 -0
  319. package/dist/components/text/index.d.ts +13 -0
  320. package/dist/components/text/index.js +12 -0
  321. package/dist/components/text/text.d.ts +8 -0
  322. package/dist/components/text/text.js +25 -0
  323. package/dist/components/textarea/index.d.ts +13 -0
  324. package/dist/components/textarea/index.js +12 -0
  325. package/dist/components/textarea/textarea.d.ts +8 -0
  326. package/dist/components/textarea/textarea.js +27 -0
  327. package/dist/components/textfield/index.d.ts +14 -0
  328. package/dist/components/textfield/index.js +13 -0
  329. package/dist/components/textfield/textfield.d.ts +18 -0
  330. package/dist/components/textfield/textfield.js +39 -0
  331. package/dist/components/time-field/index.d.ts +26 -0
  332. package/dist/components/time-field/index.js +20 -0
  333. package/dist/components/time-field/time-field.d.ts +9 -0
  334. package/dist/components/time-field/time-field.js +29 -0
  335. package/dist/components/toast/constants.d.ts +6 -0
  336. package/dist/components/toast/constants.js +15 -0
  337. package/dist/components/toast/index.d.ts +75 -0
  338. package/dist/components/toast/index.js +23 -0
  339. package/dist/components/toast/toast-queue.d.ts +70 -0
  340. package/dist/components/toast/toast-queue.js +147 -0
  341. package/dist/components/toast/toast.d.ts +69 -0
  342. package/dist/components/toast/toast.js +365 -0
  343. package/dist/components/toggle-button/index.d.ts +13 -0
  344. package/dist/components/toggle-button/index.js +12 -0
  345. package/dist/components/toggle-button/toggle-button.d.ts +8 -0
  346. package/dist/components/toggle-button/toggle-button.js +36 -0
  347. package/dist/components/toggle-button-group/index.d.ts +16 -0
  348. package/dist/components/toggle-button-group/index.js +14 -0
  349. package/dist/components/toggle-button-group/toggle-button-group.d.ts +25 -0
  350. package/dist/components/toggle-button-group/toggle-button-group.js +70 -0
  351. package/dist/components/toolbar/index.d.ts +19 -0
  352. package/dist/components/toolbar/index.js +12 -0
  353. package/dist/components/toolbar/toolbar.d.ts +11 -0
  354. package/dist/components/toolbar/toolbar.js +39 -0
  355. package/dist/components/tooltip/index.d.ts +19 -0
  356. package/dist/components/tooltip/index.js +15 -0
  357. package/dist/components/tooltip/tooltip.d.ts +20 -0
  358. package/dist/components/tooltip/tooltip.js +106 -0
  359. package/dist/hooks/index.d.ts +9 -0
  360. package/dist/hooks/use-css-variable.d.ts +36 -0
  361. package/dist/hooks/use-css-variable.js +72 -0
  362. package/dist/hooks/use-is-hydrated.d.ts +19 -0
  363. package/dist/hooks/use-is-hydrated.js +28 -0
  364. package/dist/hooks/use-isomorphic-layout-effect.d.ts +2 -0
  365. package/dist/hooks/use-isomorphic-layout-effect.js +6 -0
  366. package/dist/hooks/use-list-data.d.ts +111 -0
  367. package/dist/hooks/use-list-data.js +296 -0
  368. package/dist/hooks/use-measured-height.d.ts +4 -0
  369. package/dist/hooks/use-measured-height.js +47 -0
  370. package/dist/hooks/use-media-query.d.ts +6 -0
  371. package/dist/hooks/use-media-query.js +50 -0
  372. package/dist/hooks/use-mounted.d.ts +1 -0
  373. package/dist/hooks/use-mounted.js +15 -0
  374. package/dist/hooks/use-overlay-state.d.ts +52 -0
  375. package/dist/hooks/use-overlay-state.js +70 -0
  376. package/dist/hooks/use-safe-layout-effect.d.ts +2 -0
  377. package/dist/hooks/use-safe-layout-effect.js +6 -0
  378. package/dist/index.d.ts +3 -0
  379. package/dist/index.js +190 -0
  380. package/dist/prerelease.d.ts +4 -0
  381. package/dist/prerelease.js +50 -0
  382. package/dist/styles.css +2 -0
  383. package/dist/utils/assertion.d.ts +9 -0
  384. package/dist/utils/assertion.js +3 -0
  385. package/dist/utils/calendar.d.ts +12 -0
  386. package/dist/utils/calendar.js +52 -0
  387. package/dist/utils/children.d.ts +9 -0
  388. package/dist/utils/children.js +17 -0
  389. package/dist/utils/compose.d.ts +7 -0
  390. package/dist/utils/compose.js +18 -0
  391. package/dist/utils/index.d.ts +6 -0
  392. package/dist/utils/logger.d.ts +23 -0
  393. package/dist/utils/logger.js +78 -0
  394. package/dist/utils/tv.d.ts +3 -0
  395. package/dist/utils/variants.d.ts +73 -0
  396. package/dist/version.d.ts +1 -0
  397. package/dist/version.js +5 -0
  398. package/package.json +406 -0
@@ -0,0 +1,70 @@
1
+ import type { ButtonProps } from "../button";
2
+ import type { ReactNode } from "react";
3
+ import type { ToastOptions as RACToastOptions, UNSTABLE_ToastQueue as ToastQueuePrimitiveType } from "react-aria-components";
4
+ export interface ToastQueueOptions {
5
+ /** The maximum number of toasts to display at a time (visual only). */
6
+ maxVisibleToasts?: number;
7
+ /** Function to wrap updates in (i.e. document.startViewTransition()). */
8
+ wrapUpdate?: (fn: () => void) => void;
9
+ }
10
+ export declare class ToastQueue<T extends object = ToastContentValue> {
11
+ private queue;
12
+ readonly maxVisibleToasts?: number;
13
+ constructor(options?: ToastQueueOptions);
14
+ add(content: T, options?: RACToastOptions): string;
15
+ close(key: string): void;
16
+ pauseAll(): void;
17
+ resumeAll(): void;
18
+ clear(): void;
19
+ subscribe(fn: () => void): () => void;
20
+ get visibleToasts(): import("react-aria-components").QueuedToast<T>[];
21
+ getQueue(): ToastQueuePrimitiveType<T>;
22
+ }
23
+ export interface ToastContentValue {
24
+ indicator?: ReactNode | undefined;
25
+ title?: ReactNode | undefined;
26
+ description?: ReactNode | undefined;
27
+ variant?: "default" | "accent" | "success" | "warning" | "danger" | undefined;
28
+ actionProps?: ButtonProps | undefined;
29
+ isLoading?: boolean | undefined;
30
+ }
31
+ export interface MasaraxUIToastOptions {
32
+ description?: ReactNode;
33
+ indicator?: ReactNode;
34
+ variant?: ToastContentValue["variant"];
35
+ actionProps?: ButtonProps;
36
+ isLoading?: boolean;
37
+ timeout?: number;
38
+ onClose?: () => void;
39
+ }
40
+ export interface ToastPromiseOptions<T = unknown> {
41
+ loading: ReactNode;
42
+ success: ((data: T) => ReactNode) | ReactNode;
43
+ error: ((error: Error) => ReactNode) | ReactNode;
44
+ }
45
+ declare const toastQueue: ToastQueue<ToastContentValue>;
46
+ export declare const toast: {
47
+ (message: ReactNode, options?: MasaraxUIToastOptions): string;
48
+ success(message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">): string;
49
+ danger(message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">): string;
50
+ info(message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">): string;
51
+ warning(message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">): string;
52
+ promise<T>(promise: Promise<T> | (() => Promise<T>), options: ToastPromiseOptions<T>): string;
53
+ getQueue(): ToastQueuePrimitiveType<ToastContentValue>;
54
+ close(key: string): void;
55
+ pauseAll(): void;
56
+ resumeAll(): void;
57
+ clear(): void;
58
+ } & {
59
+ success: (message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">) => string;
60
+ danger: (message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">) => string;
61
+ info: (message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">) => string;
62
+ warning: (message: ReactNode, options?: Omit<MasaraxUIToastOptions, "variant">) => string;
63
+ promise: <T>(promise: Promise<T> | (() => Promise<T>), options: ToastPromiseOptions<T>) => string;
64
+ getQueue: () => ReturnType<() => ToastQueuePrimitiveType<ToastContentValue>>;
65
+ close: (key: string) => void;
66
+ pauseAll: () => void;
67
+ resumeAll: () => void;
68
+ clear: () => void;
69
+ };
70
+ export { toastQueue };
@@ -0,0 +1,147 @@
1
+ "use strict";
2
+ import { UNSTABLE_ToastQueue } from 'react-aria-components';
3
+ import { flushSync } from 'react-dom';
4
+ import { DEFAULT_RAC_MAX_VISIBLE_TOAST, DEFAULT_TOAST_TIMEOUT } from './constants.js';
5
+
6
+ /* ------------------------------------------------------------------------------------------------
7
+ * Toast Queue Options
8
+ * --------------------------------------------------------------------------------------------- */
9
+
10
+ /* ------------------------------------------------------------------------------------------------
11
+ * Toast Queue
12
+ * --------------------------------------------------------------------------------------------- */
13
+ class ToastQueue {
14
+ constructor(options) {
15
+ this.maxVisibleToasts = options?.maxVisibleToasts;
16
+ this.queue = new UNSTABLE_ToastQueue({
17
+ maxVisibleToasts: DEFAULT_RAC_MAX_VISIBLE_TOAST,
18
+ wrapUpdate: options?.wrapUpdate ? options.wrapUpdate : fn => {
19
+ if ("startViewTransition" in document) {
20
+ document.startViewTransition(() => {
21
+ flushSync(fn);
22
+ });
23
+ } else {
24
+ fn();
25
+ }
26
+ }
27
+ });
28
+ }
29
+ add(content, options) {
30
+ // Apply default timeout if not provided, but respect explicit 0 (persistent toast)
31
+ const timeout = options?.timeout !== undefined ? options.timeout : DEFAULT_TOAST_TIMEOUT;
32
+ return this.queue.add(content, {
33
+ ...options,
34
+ timeout
35
+ });
36
+ }
37
+ close(key) {
38
+ this.queue.close(key);
39
+ }
40
+ pauseAll() {
41
+ this.queue.pauseAll();
42
+ }
43
+ resumeAll() {
44
+ this.queue.resumeAll();
45
+ }
46
+ clear() {
47
+ this.queue.clear();
48
+ }
49
+ subscribe(fn) {
50
+ return this.queue.subscribe(fn);
51
+ }
52
+ get visibleToasts() {
53
+ return this.queue.visibleToasts;
54
+ }
55
+ getQueue() {
56
+ return this.queue;
57
+ }
58
+ }
59
+
60
+ /* ------------------------------------------------------------------------------------------------
61
+ * Toast Queue Instance
62
+ * --------------------------------------------------------------------------------------------- */
63
+
64
+ // Helper function to create toast
65
+ function createToastFunction(queue) {
66
+ const toastFn = (message, options) => {
67
+ // Use default timeout if not provided, but respect explicit 0 (persistent toast)
68
+ const timeout = options?.timeout !== undefined ? options.timeout : DEFAULT_TOAST_TIMEOUT;
69
+ return queue.add({
70
+ title: message,
71
+ description: options?.description,
72
+ indicator: options?.indicator,
73
+ variant: options?.variant || "default",
74
+ actionProps: options?.actionProps,
75
+ isLoading: options?.isLoading
76
+ }, {
77
+ timeout,
78
+ onClose: () => {
79
+ requestAnimationFrame(() => {
80
+ options?.onClose?.();
81
+ });
82
+ }
83
+ });
84
+ };
85
+
86
+ // Variant methods
87
+ toastFn.success = (message, options) => {
88
+ return toastFn(message, {
89
+ ...options,
90
+ variant: "success"
91
+ });
92
+ };
93
+ toastFn.danger = (message, options) => {
94
+ return toastFn(message, {
95
+ ...options,
96
+ variant: "danger"
97
+ });
98
+ };
99
+ toastFn.info = (message, options) => {
100
+ return toastFn(message, {
101
+ ...options,
102
+ variant: "accent"
103
+ });
104
+ };
105
+ toastFn.warning = (message, options) => {
106
+ return toastFn(message, {
107
+ ...options,
108
+ variant: "warning"
109
+ });
110
+ };
111
+
112
+ // Promise support
113
+ toastFn.promise = (promise, options) => {
114
+ const promiseFn = typeof promise === "function" ? promise() : promise;
115
+ const loadingId = queue.add({
116
+ title: options.loading,
117
+ variant: "default",
118
+ isLoading: true
119
+ }, {
120
+ timeout: 0 // Don't auto-close loading toasts
121
+ });
122
+ promiseFn.then(data => {
123
+ const successMessage = typeof options.success === "function" ? options.success(data) : options.success;
124
+ queue.close(loadingId);
125
+ return toastFn.success(successMessage);
126
+ }).catch(error => {
127
+ const errorMessage = typeof options.error === "function" ? options.error(error) : options.error;
128
+ queue.close(loadingId);
129
+ return toastFn.danger(errorMessage);
130
+ });
131
+ return loadingId;
132
+ };
133
+
134
+ // Expose queue methods for advanced usage
135
+ toastFn.getQueue = () => queue.getQueue();
136
+ toastFn.close = key => queue.close(key);
137
+ toastFn.pauseAll = () => queue.pauseAll();
138
+ toastFn.resumeAll = () => queue.resumeAll();
139
+ toastFn.clear = () => queue.clear();
140
+ return toastFn;
141
+ }
142
+ const toastQueue = new ToastQueue({
143
+ maxVisibleToasts: DEFAULT_RAC_MAX_VISIBLE_TOAST
144
+ });
145
+ const toast = createToastFunction(toastQueue);
146
+
147
+ export { ToastQueue, toast, toastQueue };
@@ -0,0 +1,69 @@
1
+ import type { ToastContentValue } from "./toast-queue";
2
+ import type { ToastVariants } from "@masaraxui/styles";
3
+ import type { ComponentPropsWithRef } from "react";
4
+ import type { ToastProps as ToastPrimitiveProps } from "react-aria-components";
5
+ import { Text as TextPrimitive, UNSTABLE_ToastContent as ToastContentPrimitive, UNSTABLE_ToastRegion as ToastRegionPrimitive } from "react-aria-components";
6
+ import { Button } from "../button";
7
+ import { CloseButton } from "../close-button";
8
+ import { ToastQueue } from "./toast-queue";
9
+ interface ToastProps<T extends object = ToastContentValue> extends ToastPrimitiveProps<T>, ToastVariants {
10
+ scaleFactor?: number;
11
+ }
12
+ declare const Toast: {
13
+ <T extends object = ToastContentValue>({ children, className, placement, scaleFactor, toast, variant, ...rest }: ToastProps<T>): import("react/jsx-runtime").JSX.Element;
14
+ displayName: string;
15
+ };
16
+ interface ToastContentProps extends ComponentPropsWithRef<typeof ToastContentPrimitive> {
17
+ }
18
+ declare const ToastContent: ({ children, className, ...rest }: ToastContentProps) => import("react/jsx-runtime").JSX.Element;
19
+ interface ToastIndicatorProps extends ComponentPropsWithRef<"div"> {
20
+ variant?: ToastVariants["variant"];
21
+ }
22
+ declare const ToastIndicator: {
23
+ ({ children, className, variant, ...rest }: ToastIndicatorProps): import("react/jsx-runtime").JSX.Element;
24
+ displayName: string;
25
+ };
26
+ interface ToastTitleProps extends ComponentPropsWithRef<typeof TextPrimitive> {
27
+ }
28
+ declare const ToastTitle: {
29
+ ({ children, className, ...rest }: ToastTitleProps): import("react/jsx-runtime").JSX.Element;
30
+ displayName: string;
31
+ };
32
+ interface ToastDescriptionProps extends ComponentPropsWithRef<typeof TextPrimitive> {
33
+ }
34
+ declare const ToastDescription: {
35
+ ({ children, className, ...rest }: ToastDescriptionProps): import("react/jsx-runtime").JSX.Element;
36
+ displayName: string;
37
+ };
38
+ interface ToastCloseButtonProps extends ComponentPropsWithRef<typeof CloseButton> {
39
+ }
40
+ declare const ToastCloseButton: {
41
+ ({ className, ...rest }: ToastCloseButtonProps): import("react/jsx-runtime").JSX.Element;
42
+ displayName: string;
43
+ };
44
+ interface ToastActionButtonProps extends ComponentPropsWithRef<typeof Button> {
45
+ }
46
+ declare const ToastActionButton: {
47
+ ({ children, className, ...rest }: ToastActionButtonProps): import("react/jsx-runtime").JSX.Element;
48
+ displayName: string;
49
+ };
50
+ type ToastRegionPrimitiveProps<T extends object = ToastContentValue> = ComponentPropsWithRef<typeof ToastRegionPrimitive<T>>;
51
+ interface ToastProviderProps<T extends object = ToastContentValue> extends Omit<ToastRegionPrimitiveProps<T>, "queue" | "children"> {
52
+ children?: ToastRegionPrimitiveProps<T>["children"];
53
+ /** The gap between toasts. @default 8 */
54
+ gap?: number;
55
+ /** The maximum number of toasts to display at a time (visual only). */
56
+ maxVisibleToasts?: number;
57
+ /** The scale factor for toasts. @default 0.05 */
58
+ scaleFactor?: number;
59
+ placement?: ToastVariants["placement"];
60
+ queue?: ToastQueue<T>;
61
+ /** The width of the toast. @default 460 */
62
+ width?: number | string;
63
+ }
64
+ declare const ToastProvider: {
65
+ <T extends object = ToastContentValue>({ children, className, gap, maxVisibleToasts, placement, queue: queueProp, scaleFactor, width, ...rest }: ToastProviderProps<T>): import("react/jsx-runtime").JSX.Element;
66
+ displayName: string;
67
+ };
68
+ export { ToastQueue, Toast, ToastActionButton, ToastCloseButton, ToastContent, ToastDescription, ToastIndicator, ToastProvider, ToastTitle, };
69
+ export type { ToastActionButtonProps, ToastCloseButtonProps, ToastContentProps, ToastDescriptionProps, ToastIndicatorProps, ToastProps, ToastProviderProps, ToastTitleProps, };
@@ -0,0 +1,365 @@
1
+ "use client";
2
+ import { toastVariants } from '@masaraxui/styles';
3
+ import React__default, { useContext, createContext, useRef, useEffect, useMemo, useCallback } from 'react';
4
+ import { UNSTABLE_ToastStateContext, UNSTABLE_Toast, Text, UNSTABLE_ToastContent, UNSTABLE_ToastRegion } from 'react-aria-components';
5
+ import { dataAttr } from '../../utils/assertion.js';
6
+ import { composeTwRenderProps, composeSlotClassName } from '../../utils/compose.js';
7
+ import { Button } from '../button/index.js';
8
+ import { CloseButton } from '../close-button/index.js';
9
+ import { InfoIcon, DangerIcon, WarningIcon, SuccessIcon } from '../icons.js';
10
+ import { Spinner } from '../spinner/index.js';
11
+ import { DEFAULT_SCALE_FACTOR, DEFAULT_GAP, DEFAULT_MAX_VISIBLE_TOAST, DEFAULT_TOAST_WIDTH } from './constants.js';
12
+ import { toast } from './toast-queue.js';
13
+ export { ToastQueue } from './toast-queue.js';
14
+ import { jsx, jsxs } from 'react/jsx-runtime';
15
+ import { useMeasuredHeight } from '../../hooks/use-measured-height.js';
16
+ import { useMediaQuery } from '../../hooks/use-media-query.js';
17
+
18
+ const ToastContext = /*#__PURE__*/createContext({});
19
+
20
+ /* ------------------------------------------------------------------------------------------------
21
+ * Toast
22
+ * --------------------------------------------------------------------------------------------- */
23
+
24
+ const Toast = ({
25
+ children,
26
+ className,
27
+ placement,
28
+ scaleFactor = DEFAULT_SCALE_FACTOR,
29
+ toast,
30
+ variant,
31
+ ...rest
32
+ }) => {
33
+ const {
34
+ gap = DEFAULT_GAP,
35
+ heightsByKey,
36
+ maxVisibleToasts = DEFAULT_MAX_VISIBLE_TOAST,
37
+ onToastHeightChange,
38
+ placement: contextPlacement,
39
+ scaleFactor: contextScaleFactor,
40
+ slots
41
+ } = useContext(ToastContext);
42
+ const finalPlacement = placement ?? contextPlacement;
43
+ const finalScaleFactor = scaleFactor ?? contextScaleFactor;
44
+ const state = useContext(UNSTABLE_ToastStateContext);
45
+ const visibleToasts = state.visibleToasts;
46
+ const index = visibleToasts.indexOf(toast);
47
+ const isFrontmost = index <= 0;
48
+ const isBottom = finalPlacement?.startsWith("bottom");
49
+ const isHidden = index >= maxVisibleToasts;
50
+ const toastKey = toast?.key;
51
+ const toastRef = useRef(null);
52
+ const {
53
+ height: toastHeight
54
+ } = useMeasuredHeight(toastRef);
55
+ useEffect(() => {
56
+ if (toastKey && typeof toastHeight === "number") {
57
+ onToastHeightChange?.(toastKey, toastHeight);
58
+ }
59
+ }, [toastKey, toastHeight, onToastHeightChange]);
60
+ const style = useMemo(() => {
61
+ const frontToastKey = visibleToasts[0]?.key;
62
+ const frontHeight = (frontToastKey ? heightsByKey?.[frontToastKey] : undefined) ?? toastHeight ?? 0;
63
+ const offset = index * gap;
64
+ const translateY = (isBottom ? -1 : 1) * offset;
65
+ const scale = 1 - index * finalScaleFactor;
66
+ return {
67
+ viewTransitionName: `toast-${String(toast.key).replace(/[^a-zA-Z0-9]/g, "-")}`,
68
+ translate: `0 ${translateY}px 0`,
69
+ scale: `${scale}`,
70
+ zIndex: visibleToasts.length - index,
71
+ tabindex: isFrontmost ? 0 : -1,
72
+ ...(frontHeight ? {
73
+ "--front-height": `${frontHeight}px`
74
+ } : null),
75
+ opacity: isHidden ? 0 : 1,
76
+ pointerEvents: isHidden ? "none" : "auto",
77
+ ...rest.style
78
+ };
79
+ }, [finalScaleFactor, gap, heightsByKey, index, isBottom, isFrontmost, isHidden, rest.style, toast?.key, toastHeight, visibleToasts]);
80
+ return /*#__PURE__*/jsx(UNSTABLE_Toast, {
81
+ ref: toastRef,
82
+ "aria-hidden": isHidden,
83
+ className: composeTwRenderProps(className, slots?.toast({
84
+ variant
85
+ })),
86
+ "data-frontmost": dataAttr(isFrontmost),
87
+ "data-hidden": dataAttr(isHidden),
88
+ "data-index": index,
89
+ "data-slot": "toast",
90
+ style: style,
91
+ toast: toast,
92
+ ...rest,
93
+ children: children
94
+ });
95
+ };
96
+ Toast.displayName = "MasaraxUI.Toast";
97
+
98
+ /* ------------------------------------------------------------------------------------------------
99
+ * Toast Content
100
+ * --------------------------------------------------------------------------------------------- */
101
+
102
+ const ToastContent = ({
103
+ children,
104
+ className,
105
+ ...rest
106
+ }) => {
107
+ const {
108
+ slots
109
+ } = useContext(ToastContext);
110
+ return /*#__PURE__*/jsx(UNSTABLE_ToastContent, {
111
+ className: composeSlotClassName(slots?.content, className),
112
+ "data-slot": "toast-content",
113
+ ...rest,
114
+ children: children
115
+ });
116
+ };
117
+
118
+ /* ------------------------------------------------------------------------------------------------
119
+ * Toast Indicator
120
+ * --------------------------------------------------------------------------------------------- */
121
+
122
+ const ToastIndicator = ({
123
+ children,
124
+ className,
125
+ variant,
126
+ ...rest
127
+ }) => {
128
+ const {
129
+ slots
130
+ } = useContext(ToastContext);
131
+ const getDefaultIcon = useCallback(() => {
132
+ switch (variant) {
133
+ case "accent":
134
+ return /*#__PURE__*/jsx(InfoIcon, {
135
+ "data-slot": "toast-default-icon"
136
+ });
137
+ case "success":
138
+ return /*#__PURE__*/jsx(SuccessIcon, {
139
+ "data-slot": "toast-default-icon"
140
+ });
141
+ case "warning":
142
+ return /*#__PURE__*/jsx(WarningIcon, {
143
+ "data-slot": "toast-default-icon"
144
+ });
145
+ case "danger":
146
+ return /*#__PURE__*/jsx(DangerIcon, {
147
+ "data-slot": "toast-default-icon"
148
+ });
149
+ default:
150
+ return /*#__PURE__*/jsx(InfoIcon, {
151
+ "data-slot": "toast-default-icon"
152
+ });
153
+ }
154
+ }, [variant]);
155
+ return /*#__PURE__*/jsx("div", {
156
+ className: composeSlotClassName(slots?.indicator, className),
157
+ "data-slot": "toast-indicator",
158
+ ...rest,
159
+ children: children ?? getDefaultIcon()
160
+ });
161
+ };
162
+ ToastIndicator.displayName = "MasaraxUI.ToastIndicator";
163
+
164
+ /* ------------------------------------------------------------------------------------------------
165
+ * Toast Title
166
+ * --------------------------------------------------------------------------------------------- */
167
+
168
+ const ToastTitle = ({
169
+ children,
170
+ className,
171
+ ...rest
172
+ }) => {
173
+ const {
174
+ slots
175
+ } = useContext(ToastContext);
176
+ return /*#__PURE__*/jsx(Text, {
177
+ className: composeSlotClassName(slots?.title, className),
178
+ "data-slot": "toast-title",
179
+ slot: "title",
180
+ ...rest,
181
+ children: children
182
+ });
183
+ };
184
+ ToastTitle.displayName = "MasaraxUI.ToastTitle";
185
+
186
+ /* ------------------------------------------------------------------------------------------------
187
+ * Toast Description
188
+ * --------------------------------------------------------------------------------------------- */
189
+
190
+ const ToastDescription = ({
191
+ children,
192
+ className,
193
+ ...rest
194
+ }) => {
195
+ const {
196
+ slots
197
+ } = useContext(ToastContext);
198
+ return /*#__PURE__*/jsx(Text, {
199
+ className: composeSlotClassName(slots?.description, className),
200
+ "data-slot": "toast-description",
201
+ slot: "description",
202
+ ...rest,
203
+ children: children
204
+ });
205
+ };
206
+ ToastDescription.displayName = "MasaraxUI.ToastDescription";
207
+
208
+ /* ------------------------------------------------------------------------------------------------
209
+ * Toast Close Button
210
+ * --------------------------------------------------------------------------------------------- */
211
+
212
+ const ToastCloseButton = ({
213
+ className,
214
+ ...rest
215
+ }) => {
216
+ const {
217
+ slots
218
+ } = useContext(ToastContext);
219
+ return /*#__PURE__*/jsx(CloseButton, {
220
+ className: composeTwRenderProps(className, slots?.close()),
221
+ "data-slot": "toast-close",
222
+ slot: "close",
223
+ ...rest
224
+ });
225
+ };
226
+ ToastCloseButton.displayName = "MasaraxUI.ToastCloseButton";
227
+
228
+ /* ------------------------------------------------------------------------------------------------
229
+ * Toast Action Button
230
+ * --------------------------------------------------------------------------------------------- */
231
+
232
+ const ToastActionButton = ({
233
+ children,
234
+ className,
235
+ ...rest
236
+ }) => {
237
+ const {
238
+ slots
239
+ } = useContext(ToastContext);
240
+ return /*#__PURE__*/jsx(Button, {
241
+ className: composeTwRenderProps(className, slots?.action?.()),
242
+ "data-slot": "toast-action-button",
243
+ ...rest,
244
+ children: children
245
+ });
246
+ };
247
+ ToastActionButton.displayName = "MasaraxUI.ToastActionButton";
248
+
249
+ /* ------------------------------------------------------------------------------------------------
250
+ * Toast Region
251
+ * --------------------------------------------------------------------------------------------- */
252
+
253
+ const ToastProvider = ({
254
+ children,
255
+ className,
256
+ gap = DEFAULT_GAP,
257
+ maxVisibleToasts,
258
+ placement = "bottom",
259
+ queue: queueProp,
260
+ scaleFactor = DEFAULT_SCALE_FACTOR,
261
+ width = DEFAULT_TOAST_WIDTH,
262
+ ...rest
263
+ }) => {
264
+ const slots = useMemo(() => toastVariants({
265
+ placement
266
+ }), [placement]);
267
+ const isMobile = useMediaQuery("(max-width: 768px)");
268
+ const [toastHeights, setToastHeights] = React__default.useState({});
269
+ const toastQueue = useMemo(() => {
270
+ if (queueProp) {
271
+ // Custom toast prop provided - use it (it already has its own maxVisibleToasts limit)
272
+ return "getQueue" in queueProp ? queueProp.getQueue() : queueProp;
273
+ }
274
+ return toast.getQueue();
275
+ }, [queueProp]);
276
+ const resolvedMaxVisibleToasts = useMemo(() => {
277
+ const queueLimit = queueProp && "maxVisibleToasts" in queueProp ? queueProp.maxVisibleToasts : undefined;
278
+ return maxVisibleToasts ?? queueLimit ?? DEFAULT_MAX_VISIBLE_TOAST;
279
+ }, [maxVisibleToasts, queueProp]);
280
+ const handleToastHeightChange = useCallback((key, height) => {
281
+ setToastHeights(prev => {
282
+ if (prev[key] === height) {
283
+ return prev;
284
+ }
285
+ return {
286
+ ...prev,
287
+ [key]: height
288
+ };
289
+ });
290
+ }, []);
291
+ const getDefaultChildren = useCallback(renderProps => {
292
+ const {
293
+ actionProps,
294
+ description,
295
+ indicator,
296
+ isLoading,
297
+ title,
298
+ variant
299
+ } = renderProps.toast.content ?? {};
300
+ return /*#__PURE__*/jsxs(Toast, {
301
+ placement: placement,
302
+ scaleFactor: scaleFactor,
303
+ toast: renderProps.toast,
304
+ variant: variant,
305
+ children: [indicator === null ? null : isLoading ? /*#__PURE__*/jsx(ToastIndicator, {
306
+ variant: variant,
307
+ children: /*#__PURE__*/jsx(Spinner, {
308
+ color: "current",
309
+ size: "sm"
310
+ })
311
+ }) : /*#__PURE__*/jsx(ToastIndicator, {
312
+ variant: variant,
313
+ children: indicator
314
+ }), /*#__PURE__*/jsxs(ToastContent, {
315
+ children: [!!title && /*#__PURE__*/jsx(ToastTitle, {
316
+ children: title
317
+ }), !!description && /*#__PURE__*/jsx(ToastDescription, {
318
+ children: description
319
+ }), isMobile && actionProps?.children ? /*#__PURE__*/jsx(ToastActionButton, {
320
+ ...actionProps,
321
+ children: actionProps.children
322
+ }) : null]
323
+ }), !isMobile && actionProps?.children ? /*#__PURE__*/jsx(ToastActionButton, {
324
+ ...actionProps,
325
+ children: actionProps.children
326
+ }) : null, /*#__PURE__*/jsx(ToastCloseButton, {})]
327
+ });
328
+ }, [isMobile, placement, scaleFactor]);
329
+ return /*#__PURE__*/jsx(UNSTABLE_ToastRegion, {
330
+ className: composeTwRenderProps(className, slots?.region()),
331
+ "data-slot": "toast-region",
332
+ queue: toastQueue,
333
+ style: {
334
+ // @ts-expect-error - CSS variables
335
+ "--gap": `${gap}px`,
336
+ "--scale-factor": scaleFactor,
337
+ "--placement": placement,
338
+ "--toast-width": typeof width === "number" ? `${width}px` : width
339
+ },
340
+ ...rest,
341
+ children: renderProps => {
342
+ const content = renderProps.toast.content;
343
+ const renderPropsWithIsLoading = {
344
+ ...renderProps,
345
+ isLoading: content?.isLoading ?? false
346
+ };
347
+ return /*#__PURE__*/jsx(ToastContext, {
348
+ value: {
349
+ slots,
350
+ placement,
351
+ scaleFactor,
352
+ gap,
353
+ maxVisibleToasts: resolvedMaxVisibleToasts,
354
+ heightsByKey: toastHeights,
355
+ onToastHeightChange: handleToastHeightChange,
356
+ width
357
+ },
358
+ children: typeof children === "undefined" ? getDefaultChildren(renderProps) : typeof children === "function" ? children(renderPropsWithIsLoading) : children
359
+ });
360
+ }
361
+ });
362
+ };
363
+ ToastProvider.displayName = "MasaraxUI.ToastProvider";
364
+
365
+ export { Toast, ToastActionButton, ToastCloseButton, ToastContent, ToastDescription, ToastIndicator, ToastProvider, ToastTitle };
@@ -0,0 +1,13 @@
1
+ import type { ComponentProps } from "react";
2
+ import { ToggleButtonRoot } from "./toggle-button";
3
+ export declare const ToggleButton: (({ children, className, isIconOnly, size, style, variant, ...rest }: import("./toggle-button").ToggleButtonRootProps) => import("react/jsx-runtime").JSX.Element) & {
4
+ Root: ({ children, className, isIconOnly, size, style, variant, ...rest }: import("./toggle-button").ToggleButtonRootProps) => import("react/jsx-runtime").JSX.Element;
5
+ };
6
+ export type ToggleButton = {
7
+ Props: ComponentProps<typeof ToggleButtonRoot>;
8
+ RootProps: ComponentProps<typeof ToggleButtonRoot>;
9
+ };
10
+ export { ToggleButtonRoot };
11
+ export type { ToggleButtonRootProps, ToggleButtonRootProps as ToggleButtonProps, } from "./toggle-button";
12
+ export { toggleButtonVariants } from "@masaraxui/styles";
13
+ export type { ToggleButtonVariants } from "@masaraxui/styles";
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ import { ToggleButtonRoot } from './toggle-button.js';
3
+ export { toggleButtonVariants } from '@masaraxui/styles';
4
+
5
+ /* -------------------------------------------------------------------------------------------------
6
+ * Compound Component
7
+ * -----------------------------------------------------------------------------------------------*/
8
+ const ToggleButton = Object.assign(ToggleButtonRoot, {
9
+ Root: ToggleButtonRoot
10
+ });
11
+
12
+ export { ToggleButton, ToggleButtonRoot };
@@ -0,0 +1,8 @@
1
+ import type { ToggleButtonVariants } from "@masaraxui/styles";
2
+ import type { ComponentPropsWithRef } from "react";
3
+ import { ToggleButton as ToggleButtonPrimitive } from "react-aria-components";
4
+ interface ToggleButtonRootProps extends ComponentPropsWithRef<typeof ToggleButtonPrimitive>, ToggleButtonVariants {
5
+ }
6
+ declare const ToggleButtonRoot: ({ children, className, isIconOnly, size, style, variant, ...rest }: ToggleButtonRootProps) => import("react/jsx-runtime").JSX.Element;
7
+ export { ToggleButtonRoot };
8
+ export type { ToggleButtonRootProps };