@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,309 @@
1
+ "use client";
2
+ import { alertDialogVariants } from '@masaraxui/styles';
3
+ import { useMemo, createContext, useContext } from 'react';
4
+ import { DialogTrigger, Heading, Dialog, Modal, ModalOverlay, Pressable } from 'react-aria-components';
5
+ import { composeTwRenderProps, composeSlotClassName } from '../../utils/compose.js';
6
+ import { CloseButton } from '../close-button/index.js';
7
+ import { DangerIcon, WarningIcon, SuccessIcon, InfoIcon } from '../icons.js';
8
+ import { jsx, jsxs } from 'react/jsx-runtime';
9
+
10
+ const AlertDialogContext = /*#__PURE__*/createContext({});
11
+
12
+ /* -------------------------------------------------------------------------------------------------
13
+ * AlertDialog Root
14
+ * -----------------------------------------------------------------------------------------------*/
15
+
16
+ const AlertDialogRoot = ({
17
+ children,
18
+ ...props
19
+ }) => {
20
+ const alertDialogContext = useMemo(() => ({
21
+ slots: alertDialogVariants(),
22
+ placement: undefined
23
+ }), []);
24
+ return /*#__PURE__*/jsx(AlertDialogContext, {
25
+ value: alertDialogContext,
26
+ children: /*#__PURE__*/jsx(DialogTrigger, {
27
+ "data-slot": "alert-dialog-root",
28
+ ...props,
29
+ children: children
30
+ })
31
+ });
32
+ };
33
+
34
+ /* -------------------------------------------------------------------------------------------------
35
+ * AlertDialog Trigger
36
+ * -----------------------------------------------------------------------------------------------*/
37
+
38
+ const AlertDialogTrigger = ({
39
+ children,
40
+ className,
41
+ ...props
42
+ }) => {
43
+ const {
44
+ slots
45
+ } = useContext(AlertDialogContext);
46
+ return /*#__PURE__*/jsx(Pressable, {
47
+ children: /*#__PURE__*/jsx("div", {
48
+ className: composeSlotClassName(slots?.trigger, className),
49
+ "data-slot": "alert-dialog-trigger",
50
+ role: "button",
51
+ ...props,
52
+ children: children
53
+ })
54
+ });
55
+ };
56
+
57
+ /* -------------------------------------------------------------------------------------------------
58
+ * AlertDialog Backdrop
59
+ * -----------------------------------------------------------------------------------------------*/
60
+
61
+ const AlertDialogBackdrop = ({
62
+ children,
63
+ className,
64
+ isDismissable = false,
65
+ isKeyboardDismissDisabled = true,
66
+ onClick,
67
+ variant,
68
+ ...props
69
+ }) => {
70
+ const {
71
+ slots: contextSlots
72
+ } = useContext(AlertDialogContext);
73
+ const updatedSlots = useMemo(() => alertDialogVariants({
74
+ variant
75
+ }), [variant]);
76
+ const updatedModalContext = useMemo(() => ({
77
+ slots: {
78
+ ...contextSlots,
79
+ ...updatedSlots
80
+ }
81
+ }), [contextSlots, updatedSlots]);
82
+ return /*#__PURE__*/jsx(ModalOverlay, {
83
+ className: composeTwRenderProps(className, updatedSlots?.backdrop()),
84
+ "data-slot": "alert-dialog-backdrop",
85
+ isDismissable: isDismissable,
86
+ isKeyboardDismissDisabled: isKeyboardDismissDisabled,
87
+ onClick: e => {
88
+ e.stopPropagation();
89
+ onClick?.(e);
90
+ },
91
+ ...props,
92
+ children: renderProps => /*#__PURE__*/jsxs(AlertDialogContext, {
93
+ value: updatedModalContext,
94
+ children: [typeof children === "function" ? children(renderProps) : children, " "]
95
+ })
96
+ });
97
+ };
98
+
99
+ /* -------------------------------------------------------------------------------------------------
100
+ * AlertDialog Container
101
+ * -----------------------------------------------------------------------------------------------*/
102
+
103
+ const AlertDialogContainer = ({
104
+ children,
105
+ className,
106
+ placement = "auto",
107
+ size,
108
+ ...props
109
+ }) => {
110
+ const {
111
+ slots: contextSlots
112
+ } = useContext(AlertDialogContext);
113
+ const updatedSlots = useMemo(() => alertDialogVariants({
114
+ size
115
+ }), [size]);
116
+ const updatedContext = useMemo(() => ({
117
+ placement,
118
+ slots: {
119
+ ...contextSlots,
120
+ ...updatedSlots
121
+ }
122
+ }), [placement, contextSlots, updatedSlots]);
123
+ return /*#__PURE__*/jsx(Modal, {
124
+ className: composeTwRenderProps(className, updatedSlots?.container()),
125
+ "data-placement": placement,
126
+ "data-slot": "alert-dialog-container",
127
+ ...props,
128
+ children: renderProps => /*#__PURE__*/jsx(AlertDialogContext, {
129
+ value: updatedContext,
130
+ children: typeof children === "function" ? children(renderProps) : children
131
+ })
132
+ });
133
+ };
134
+
135
+ /* -------------------------------------------------------------------------------------------------
136
+ * AlertDialog Dialog
137
+ * -----------------------------------------------------------------------------------------------*/
138
+
139
+ const AlertDialogDialog = ({
140
+ children,
141
+ className,
142
+ ...props
143
+ }) => {
144
+ const {
145
+ placement,
146
+ slots
147
+ } = useContext(AlertDialogContext);
148
+ return /*#__PURE__*/jsx(Dialog, {
149
+ className: composeSlotClassName(slots?.dialog, className),
150
+ "data-placement": placement,
151
+ "data-slot": "alert-dialog-dialog",
152
+ role: "alertdialog",
153
+ ...props,
154
+ children: children
155
+ });
156
+ };
157
+
158
+ /* -------------------------------------------------------------------------------------------------
159
+ * AlertDialog Header
160
+ * -----------------------------------------------------------------------------------------------*/
161
+
162
+ const AlertDialogHeader = ({
163
+ children,
164
+ className,
165
+ ...props
166
+ }) => {
167
+ const {
168
+ slots
169
+ } = useContext(AlertDialogContext);
170
+ return /*#__PURE__*/jsx("div", {
171
+ className: composeSlotClassName(slots?.header, className),
172
+ "data-slot": "alert-dialog-header",
173
+ ...props,
174
+ children: children
175
+ });
176
+ };
177
+
178
+ /* -------------------------------------------------------------------------------------------------
179
+ * AlertDialog Heading
180
+ * -----------------------------------------------------------------------------------------------*/
181
+
182
+ const AlertDialogHeading = ({
183
+ children,
184
+ className,
185
+ ...props
186
+ }) => {
187
+ const {
188
+ slots
189
+ } = useContext(AlertDialogContext);
190
+ return /*#__PURE__*/jsx(Heading, {
191
+ className: composeSlotClassName(slots?.heading, className),
192
+ "data-slot": "alert-dialog-heading",
193
+ slot: "title",
194
+ ...props,
195
+ children: children
196
+ });
197
+ };
198
+
199
+ /* -------------------------------------------------------------------------------------------------
200
+ * AlertDialog Body
201
+ * -----------------------------------------------------------------------------------------------*/
202
+
203
+ const AlertDialogBody = ({
204
+ children,
205
+ className,
206
+ ...props
207
+ }) => {
208
+ const {
209
+ slots
210
+ } = useContext(AlertDialogContext);
211
+ return /*#__PURE__*/jsx("div", {
212
+ className: composeSlotClassName(slots?.body, className),
213
+ "data-slot": "alert-dialog-body",
214
+ ...props,
215
+ children: children
216
+ });
217
+ };
218
+
219
+ /* -------------------------------------------------------------------------------------------------
220
+ * AlertDialog Footer
221
+ * -----------------------------------------------------------------------------------------------*/
222
+
223
+ const AlertDialogFooter = ({
224
+ children,
225
+ className,
226
+ ...props
227
+ }) => {
228
+ const {
229
+ slots
230
+ } = useContext(AlertDialogContext);
231
+ return /*#__PURE__*/jsx("div", {
232
+ className: composeSlotClassName(slots?.footer, className),
233
+ "data-slot": "alert-dialog-footer",
234
+ ...props,
235
+ children: children
236
+ });
237
+ };
238
+
239
+ /* -------------------------------------------------------------------------------------------------
240
+ * AlertDialog Icon
241
+ * -----------------------------------------------------------------------------------------------*/
242
+
243
+ const AlertDialogIcon = ({
244
+ children,
245
+ className,
246
+ status = "danger",
247
+ ...props
248
+ }) => {
249
+ const slots = useMemo(() => alertDialogVariants({
250
+ status
251
+ }), [status]);
252
+ const getDefaultIcon = () => {
253
+ switch (status) {
254
+ case "default":
255
+ return /*#__PURE__*/jsx(InfoIcon, {
256
+ "data-slot": "alert-dialog-default-icon"
257
+ });
258
+ case "accent":
259
+ return /*#__PURE__*/jsx(InfoIcon, {
260
+ "data-slot": "alert-dialog-default-icon"
261
+ });
262
+ case "success":
263
+ return /*#__PURE__*/jsx(SuccessIcon, {
264
+ "data-slot": "alert-dialog-default-icon"
265
+ });
266
+ case "warning":
267
+ return /*#__PURE__*/jsx(WarningIcon, {
268
+ "data-slot": "alert-dialog-default-icon"
269
+ });
270
+ case "danger":
271
+ return /*#__PURE__*/jsx(DangerIcon, {
272
+ "data-slot": "alert-dialog-default-icon"
273
+ });
274
+ default:
275
+ return /*#__PURE__*/jsx(DangerIcon, {
276
+ "data-slot": "alert-dialog-default-icon"
277
+ });
278
+ }
279
+ };
280
+ return /*#__PURE__*/jsx("div", {
281
+ className: slots?.icon({
282
+ className
283
+ }),
284
+ "data-slot": "alert-dialog-icon",
285
+ ...props,
286
+ children: children ?? getDefaultIcon()
287
+ });
288
+ };
289
+
290
+ /* -------------------------------------------------------------------------------------------------
291
+ * AlertDialog Close Trigger
292
+ * -----------------------------------------------------------------------------------------------*/
293
+
294
+ const AlertDialogCloseTrigger = ({
295
+ className,
296
+ ...rest
297
+ }) => {
298
+ const {
299
+ slots
300
+ } = useContext(AlertDialogContext);
301
+ return /*#__PURE__*/jsx(CloseButton, {
302
+ className: composeTwRenderProps(className, slots?.closeTrigger()),
303
+ "data-slot": "alert-dialog-close-trigger",
304
+ slot: "close",
305
+ ...rest
306
+ });
307
+ };
308
+
309
+ export { AlertDialogBackdrop, AlertDialogBody, AlertDialogCloseTrigger, AlertDialogContainer, AlertDialogDialog, AlertDialogFooter, AlertDialogHeader, AlertDialogHeading, AlertDialogIcon, AlertDialogRoot, AlertDialogTrigger };
@@ -0,0 +1,33 @@
1
+ import type { ComponentProps } from "react";
2
+ import { AlertDialogBackdrop, AlertDialogBody, AlertDialogCloseTrigger, AlertDialogContainer, AlertDialogDialog, AlertDialogFooter, AlertDialogHeader, AlertDialogHeading, AlertDialogIcon, AlertDialogRoot, AlertDialogTrigger } from "./alert-dialog";
3
+ export declare const AlertDialog: (({ children, ...props }: import("./alert-dialog").AlertDialogRootProps) => import("react/jsx-runtime").JSX.Element) & {
4
+ Root: ({ children, ...props }: import("./alert-dialog").AlertDialogRootProps) => import("react/jsx-runtime").JSX.Element;
5
+ Trigger: ({ children, className, ...props }: import("./alert-dialog").AlertDialogTriggerProps) => import("react/jsx-runtime").JSX.Element;
6
+ Backdrop: ({ children, className, isDismissable, isKeyboardDismissDisabled, onClick, variant, ...props }: import("./alert-dialog").AlertDialogBackdropProps) => import("react/jsx-runtime").JSX.Element;
7
+ Container: ({ children, className, placement, size, ...props }: import("./alert-dialog").AlertDialogContainerProps) => import("react/jsx-runtime").JSX.Element;
8
+ Dialog: ({ children, className, ...props }: import("./alert-dialog").AlertDialogDialogProps) => import("react/jsx-runtime").JSX.Element;
9
+ Header: ({ children, className, ...props }: import("./alert-dialog").AlertDialogHeaderProps) => import("react/jsx-runtime").JSX.Element;
10
+ Heading: ({ children, className, ...props }: import("./alert-dialog").AlertDialogHeadingProps) => import("react/jsx-runtime").JSX.Element;
11
+ Body: ({ children, className, ...props }: import("./alert-dialog").AlertDialogBodyProps) => import("react/jsx-runtime").JSX.Element;
12
+ Footer: ({ children, className, ...props }: import("./alert-dialog").AlertDialogFooterProps) => import("react/jsx-runtime").JSX.Element;
13
+ Icon: ({ children, className, status, ...props }: import("./alert-dialog").AlertDialogIconProps) => import("react/jsx-runtime").JSX.Element;
14
+ CloseTrigger: ({ className, ...rest }: import("./alert-dialog").AlertDialogCloseTriggerProps) => import("react/jsx-runtime").JSX.Element;
15
+ };
16
+ export type AlertDialog = {
17
+ Props: ComponentProps<typeof AlertDialogRoot>;
18
+ RootProps: ComponentProps<typeof AlertDialogRoot>;
19
+ TriggerProps: ComponentProps<typeof AlertDialogTrigger>;
20
+ BackdropProps: ComponentProps<typeof AlertDialogBackdrop>;
21
+ ContainerProps: ComponentProps<typeof AlertDialogContainer>;
22
+ DialogProps: ComponentProps<typeof AlertDialogDialog>;
23
+ HeaderProps: ComponentProps<typeof AlertDialogHeader>;
24
+ HeadingProps: ComponentProps<typeof AlertDialogHeading>;
25
+ BodyProps: ComponentProps<typeof AlertDialogBody>;
26
+ FooterProps: ComponentProps<typeof AlertDialogFooter>;
27
+ IconProps: ComponentProps<typeof AlertDialogIcon>;
28
+ CloseTriggerProps: ComponentProps<typeof AlertDialogCloseTrigger>;
29
+ };
30
+ export { AlertDialogRoot, AlertDialogTrigger, AlertDialogBackdrop, AlertDialogContainer, AlertDialogDialog, AlertDialogHeader, AlertDialogHeading, AlertDialogBody, AlertDialogFooter, AlertDialogIcon, AlertDialogCloseTrigger, };
31
+ export type { AlertDialogRootProps, AlertDialogRootProps as AlertDialogProps, AlertDialogTriggerProps, AlertDialogBackdropProps, AlertDialogContainerProps, AlertDialogDialogProps, AlertDialogHeaderProps, AlertDialogHeadingProps, AlertDialogBodyProps, AlertDialogFooterProps, AlertDialogIconProps, AlertDialogCloseTriggerProps, } from "./alert-dialog";
32
+ export { alertDialogVariants } from "@masaraxui/styles";
33
+ export type { AlertDialogVariants } from "@masaraxui/styles";
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ import { AlertDialogRoot, AlertDialogCloseTrigger, AlertDialogIcon, AlertDialogFooter, AlertDialogBody, AlertDialogHeading, AlertDialogHeader, AlertDialogDialog, AlertDialogContainer, AlertDialogBackdrop, AlertDialogTrigger } from './alert-dialog.js';
3
+ export { alertDialogVariants } from '@masaraxui/styles';
4
+
5
+ /* -------------------------------------------------------------------------------------------------
6
+ * Compound Component
7
+ * -----------------------------------------------------------------------------------------------*/
8
+ const AlertDialog = Object.assign(AlertDialogRoot, {
9
+ Root: AlertDialogRoot,
10
+ Trigger: AlertDialogTrigger,
11
+ Backdrop: AlertDialogBackdrop,
12
+ Container: AlertDialogContainer,
13
+ Dialog: AlertDialogDialog,
14
+ Header: AlertDialogHeader,
15
+ Heading: AlertDialogHeading,
16
+ Body: AlertDialogBody,
17
+ Footer: AlertDialogFooter,
18
+ Icon: AlertDialogIcon,
19
+ CloseTrigger: AlertDialogCloseTrigger
20
+ });
21
+
22
+ export { AlertDialog, AlertDialogBackdrop, AlertDialogBody, AlertDialogCloseTrigger, AlertDialogContainer, AlertDialogDialog, AlertDialogFooter, AlertDialogHeader, AlertDialogHeading, AlertDialogIcon, AlertDialogRoot, AlertDialogTrigger };
@@ -0,0 +1,31 @@
1
+ import type { AutocompleteVariants } from "@masaraxui/styles";
2
+ import type { ComponentPropsWithRef } from "react";
3
+ import React from "react";
4
+ import { Autocomplete as AutocompletePrimitive, Group as GroupPrimitive, Popover as PopoverPrimitive, Select as SelectPrimitive, SelectValue as SelectValuePrimitive } from "react-aria-components";
5
+ interface AutocompleteRootProps<T extends object, M extends "single" | "multiple" = "single"> extends ComponentPropsWithRef<typeof SelectPrimitive<T, M>>, AutocompleteVariants {
6
+ items?: Iterable<T, M>;
7
+ onClear?: () => void;
8
+ }
9
+ declare const AutocompleteRoot: <T extends object = object, M extends "single" | "multiple" = "single">({ children, className, fullWidth, onClear, variant, ...props }: AutocompleteRootProps<T, M>) => import("react/jsx-runtime").JSX.Element;
10
+ interface AutocompleteTriggerProps extends ComponentPropsWithRef<typeof GroupPrimitive> {
11
+ }
12
+ declare const AutocompleteTrigger: React.ForwardRefExoticComponent<Omit<AutocompleteTriggerProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
13
+ interface AutocompleteValueProps extends ComponentPropsWithRef<typeof SelectValuePrimitive> {
14
+ }
15
+ declare const AutocompleteValue: ({ children, className, ...props }: AutocompleteValueProps) => import("react/jsx-runtime").JSX.Element;
16
+ interface AutocompleteIndicatorProps extends ComponentPropsWithRef<"svg"> {
17
+ className?: string;
18
+ }
19
+ declare const AutocompleteIndicator: ({ children, className, ...props }: AutocompleteIndicatorProps) => import("react/jsx-runtime").JSX.Element;
20
+ interface AutocompletePopoverProps extends Omit<ComponentPropsWithRef<typeof PopoverPrimitive>, "children"> {
21
+ children: React.ReactNode;
22
+ }
23
+ declare const AutocompletePopover: ({ children, className, placement, ...props }: AutocompletePopoverProps) => import("react/jsx-runtime").JSX.Element;
24
+ interface AutocompleteFilterProps extends ComponentPropsWithRef<typeof AutocompletePrimitive> {
25
+ }
26
+ declare const AutocompleteFilter: ({ children, ...props }: AutocompleteFilterProps) => import("react/jsx-runtime").JSX.Element;
27
+ interface AutocompleteClearButtonProps extends ComponentPropsWithRef<"button"> {
28
+ }
29
+ declare const AutocompleteClearButton: ({ className, onClick, ref, ...props }: AutocompleteClearButtonProps) => import("react/jsx-runtime").JSX.Element;
30
+ export { AutocompleteRoot, AutocompleteTrigger, AutocompleteValue, AutocompleteIndicator, AutocompletePopover, AutocompleteFilter, AutocompleteClearButton, };
31
+ export type { AutocompleteRootProps, AutocompleteTriggerProps, AutocompleteValueProps, AutocompleteIndicatorProps, AutocompletePopoverProps, AutocompleteFilterProps, AutocompleteClearButtonProps, };
@@ -0,0 +1,241 @@
1
+ "use client";
2
+ import { autocompleteVariants } from '@masaraxui/styles';
3
+ import { mergeRefs } from '@react-aria/utils';
4
+ import React__default, { useRef, createContext, useContext } from 'react';
5
+ import { Select, SelectStateContext, Autocomplete, Popover, Button, SelectValue, Group } from 'react-aria-components';
6
+ import { dataAttr } from '../../utils/assertion.js';
7
+ import { composeTwRenderProps, composeSlotClassName } from '../../utils/compose.js';
8
+ import { CloseIcon, IconChevronDown } from '../icons.js';
9
+ import { jsx, Fragment } from 'react/jsx-runtime';
10
+ import { SurfaceContext } from '../surface/surface.js';
11
+
12
+ const AutocompleteContext = /*#__PURE__*/createContext({
13
+ triggerRef: {
14
+ current: null
15
+ },
16
+ clearButtonRef: {
17
+ current: null
18
+ }
19
+ });
20
+
21
+ /* -------------------------------------------------------------------------------------------------
22
+ * Autocomplete Root
23
+ * -----------------------------------------------------------------------------------------------*/
24
+
25
+ const AutocompleteRoot = ({
26
+ children,
27
+ className,
28
+ fullWidth,
29
+ onClear,
30
+ variant,
31
+ ...props
32
+ }) => {
33
+ const slots = React__default.useMemo(() => autocompleteVariants({
34
+ fullWidth,
35
+ variant
36
+ }), [fullWidth, variant]);
37
+ const triggerRef = useRef(null);
38
+ const clearButtonRef = useRef(null);
39
+ return /*#__PURE__*/jsx(AutocompleteContext, {
40
+ value: {
41
+ slots,
42
+ triggerRef,
43
+ clearButtonRef,
44
+ onClear
45
+ },
46
+ children: /*#__PURE__*/jsx(Select, {
47
+ "data-slot": "autocomplete",
48
+ ...props,
49
+ className: composeTwRenderProps(className, slots?.base()),
50
+ children: values => /*#__PURE__*/jsx(Fragment, {
51
+ children: typeof children === "function" ? children(values) : children
52
+ })
53
+ })
54
+ });
55
+ };
56
+
57
+ /* -------------------------------------------------------------------------------------------------
58
+ * Autocomplete Trigger
59
+ * -----------------------------------------------------------------------------------------------*/
60
+
61
+ const AutocompleteTrigger = /*#__PURE__*/React__default.forwardRef(({
62
+ children,
63
+ className,
64
+ onClick,
65
+ ...props
66
+ }, ref) => {
67
+ const {
68
+ clearButtonRef,
69
+ slots,
70
+ triggerRef
71
+ } = useContext(AutocompleteContext);
72
+ const state = useContext(SelectStateContext);
73
+
74
+ // Callback ref to update context ref
75
+ const contextRefCallback = React__default.useCallback(node => {
76
+ triggerRef.current = node;
77
+ }, [triggerRef]);
78
+
79
+ // Merge context ref callback with user-provided ref
80
+ const mergedRef = mergeRefs(contextRefCallback, ref);
81
+ const handleClick = e => {
82
+ // Don't toggle if clicking the clear button
83
+ if (clearButtonRef.current?.contains(e.target)) {
84
+ return;
85
+ }
86
+ onClick?.(e);
87
+ state?.toggle();
88
+ };
89
+ return /*#__PURE__*/jsx(Group, {
90
+ ref: mergedRef,
91
+ className: composeTwRenderProps(className, slots?.trigger()),
92
+ "data-slot": "autocomplete-trigger",
93
+ onClick: handleClick,
94
+ ...props,
95
+ children: values => /*#__PURE__*/jsx(Fragment, {
96
+ children: typeof children === "function" ? children(values) : children
97
+ })
98
+ });
99
+ });
100
+ AutocompleteTrigger.displayName = "AutocompleteTrigger";
101
+
102
+ /* -------------------------------------------------------------------------------------------------
103
+ * Autocomplete Value
104
+ * -----------------------------------------------------------------------------------------------*/
105
+
106
+ const AutocompleteValue = ({
107
+ children,
108
+ className,
109
+ ...props
110
+ }) => {
111
+ const {
112
+ slots
113
+ } = useContext(AutocompleteContext);
114
+ return /*#__PURE__*/jsx(SelectValue, {
115
+ className: composeTwRenderProps(className, slots?.value()),
116
+ "data-slot": "autocomplete-value",
117
+ ...props,
118
+ children: children
119
+ });
120
+ };
121
+
122
+ /* -------------------------------------------------------------------------------------------------
123
+ * Autocomplete Indicator
124
+ * -----------------------------------------------------------------------------------------------*/
125
+
126
+ const AutocompleteIndicator = ({
127
+ children,
128
+ className,
129
+ ...props
130
+ }) => {
131
+ const {
132
+ slots
133
+ } = useContext(AutocompleteContext);
134
+ const state = useContext(SelectStateContext);
135
+ if (children && /*#__PURE__*/React__default.isValidElement(children)) {
136
+ return /*#__PURE__*/React__default.cloneElement(children, {
137
+ ...props,
138
+ className: composeSlotClassName(slots?.indicator, className),
139
+ "data-slot": "autocomplete-indicator",
140
+ "data-open": dataAttr(state?.isOpen)
141
+ });
142
+ }
143
+ return /*#__PURE__*/jsx(Button, {
144
+ children: /*#__PURE__*/jsx(IconChevronDown, {
145
+ className: composeSlotClassName(slots?.indicator, className),
146
+ "data-open": dataAttr(state?.isOpen),
147
+ "data-slot": "autocomplete-default-indicator",
148
+ ...props
149
+ })
150
+ });
151
+ };
152
+
153
+ /* -------------------------------------------------------------------------------------------------
154
+ * Autocomplete Popover
155
+ * -----------------------------------------------------------------------------------------------*/
156
+
157
+ const AutocompletePopover = ({
158
+ children,
159
+ className,
160
+ placement = "bottom",
161
+ ...props
162
+ }) => {
163
+ const {
164
+ slots,
165
+ triggerRef
166
+ } = useContext(AutocompleteContext);
167
+ return /*#__PURE__*/jsx(SurfaceContext, {
168
+ value: {
169
+ variant: "default"
170
+ },
171
+ children: /*#__PURE__*/jsx(Popover, {
172
+ ...props,
173
+ className: composeTwRenderProps(className, slots?.popover()),
174
+ "data-slot": "autocomplete-popover",
175
+ placement: placement,
176
+ triggerRef: triggerRef,
177
+ children: children
178
+ })
179
+ });
180
+ };
181
+
182
+ /* -------------------------------------------------------------------------------------------------
183
+ * Autocomplete Filter
184
+ * -----------------------------------------------------------------------------------------------*/
185
+
186
+ const AutocompleteFilter = ({
187
+ children,
188
+ ...props
189
+ }) => {
190
+ return /*#__PURE__*/jsx(Autocomplete, {
191
+ "data-slot": "autocomplete-filter",
192
+ ...props,
193
+ children: children
194
+ });
195
+ };
196
+
197
+ /* -------------------------------------------------------------------------------------------------
198
+ * Autocomplete Clear Button
199
+ * -----------------------------------------------------------------------------------------------*/
200
+
201
+ const AutocompleteClearButton = ({
202
+ className,
203
+ onClick,
204
+ ref,
205
+ ...props
206
+ }) => {
207
+ const {
208
+ slots
209
+ } = useContext(AutocompleteContext);
210
+ const state = useContext(SelectStateContext);
211
+ const {
212
+ clearButtonRef,
213
+ onClear
214
+ } = useContext(AutocompleteContext);
215
+ const clearButtonRefCallback = React__default.useCallback(node => {
216
+ clearButtonRef.current = node;
217
+ }, [clearButtonRef]);
218
+
219
+ // Merge context ref callback with user-provided ref
220
+ const mergedRef = mergeRefs(clearButtonRefCallback, ref);
221
+ const handleClick = e => {
222
+ state?.selectionManager.setSelectedKeys(new Set());
223
+ onClear?.();
224
+ onClick?.(e);
225
+ };
226
+ return /*#__PURE__*/jsx("button", {
227
+ ref: mergedRef,
228
+ className: slots?.clearButton({
229
+ className
230
+ }),
231
+ "data-empty": dataAttr(state?.selectionManager.selectedKeys.size === 0),
232
+ "data-slot": "autocomplete-clear-button",
233
+ onClick: handleClick,
234
+ ...props,
235
+ children: /*#__PURE__*/jsx(CloseIcon, {
236
+ "data-slot": "autocomplete-clear-button-icon"
237
+ })
238
+ });
239
+ };
240
+
241
+ export { AutocompleteClearButton, AutocompleteFilter, AutocompleteIndicator, AutocompletePopover, AutocompleteRoot, AutocompleteTrigger, AutocompleteValue };
@@ -0,0 +1,25 @@
1
+ import type { ComponentProps } from "react";
2
+ import { AutocompleteClearButton, AutocompleteFilter, AutocompleteIndicator, AutocompletePopover, AutocompleteRoot, AutocompleteTrigger, AutocompleteValue } from "./autocomplete";
3
+ export declare const Autocomplete: (<T extends object = object, M extends "single" | "multiple" = "single">({ children, className, fullWidth, onClear, variant, ...props }: import("./autocomplete").AutocompleteRootProps<T, M>) => import("react/jsx-runtime").JSX.Element) & {
4
+ Root: <T extends object = object, M extends "single" | "multiple" = "single">({ children, className, fullWidth, onClear, variant, ...props }: import("./autocomplete").AutocompleteRootProps<T, M>) => import("react/jsx-runtime").JSX.Element;
5
+ Trigger: import("react").ForwardRefExoticComponent<Omit<import("./autocomplete").AutocompleteTriggerProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
6
+ Value: ({ children, className, ...props }: import("./autocomplete").AutocompleteValueProps) => import("react/jsx-runtime").JSX.Element;
7
+ Indicator: ({ children, className, ...props }: import("./autocomplete").AutocompleteIndicatorProps) => import("react/jsx-runtime").JSX.Element;
8
+ Popover: ({ children, className, placement, ...props }: import("./autocomplete").AutocompletePopoverProps) => import("react/jsx-runtime").JSX.Element;
9
+ Filter: ({ children, ...props }: import("./autocomplete").AutocompleteFilterProps) => import("react/jsx-runtime").JSX.Element;
10
+ ClearButton: ({ className, onClick, ref, ...props }: import("./autocomplete").AutocompleteClearButtonProps) => import("react/jsx-runtime").JSX.Element;
11
+ };
12
+ export type Autocomplete<T extends object = object, M extends "single" | "multiple" = "single"> = {
13
+ Props: ComponentProps<typeof AutocompleteRoot<T, M>>;
14
+ RootProps: ComponentProps<typeof AutocompleteRoot<T, M>>;
15
+ TriggerProps: ComponentProps<typeof AutocompleteTrigger>;
16
+ ValueProps: ComponentProps<typeof AutocompleteValue>;
17
+ IndicatorProps: ComponentProps<typeof AutocompleteIndicator>;
18
+ PopoverProps: ComponentProps<typeof AutocompletePopover>;
19
+ FilterProps: ComponentProps<typeof AutocompleteFilter>;
20
+ ClearButtonProps: ComponentProps<typeof AutocompleteClearButton>;
21
+ };
22
+ export { AutocompleteClearButton, AutocompleteFilter, AutocompleteTrigger, AutocompleteIndicator, AutocompletePopover, AutocompleteRoot, AutocompleteValue, };
23
+ export type { AutocompleteRootProps, AutocompleteRootProps as AutocompleteProps, AutocompleteTriggerProps, AutocompleteValueProps, AutocompleteIndicatorProps, AutocompletePopoverProps, AutocompleteFilterProps, AutocompleteClearButtonProps, } from "./autocomplete";
24
+ export { autocompleteVariants } from "@masaraxui/styles";
25
+ export type { AutocompleteVariants } from "@masaraxui/styles";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ import { AutocompleteRoot, AutocompleteClearButton, AutocompleteFilter, AutocompletePopover, AutocompleteIndicator, AutocompleteValue, AutocompleteTrigger } from './autocomplete.js';
3
+ export { autocompleteVariants } from '@masaraxui/styles';
4
+
5
+ /* -------------------------------------------------------------------------------------------------
6
+ * Compound Component
7
+ * -----------------------------------------------------------------------------------------------*/
8
+ const Autocomplete = Object.assign(AutocompleteRoot, {
9
+ Root: AutocompleteRoot,
10
+ Trigger: AutocompleteTrigger,
11
+ Value: AutocompleteValue,
12
+ Indicator: AutocompleteIndicator,
13
+ Popover: AutocompletePopover,
14
+ Filter: AutocompleteFilter,
15
+ ClearButton: AutocompleteClearButton
16
+ });
17
+
18
+ export { Autocomplete, AutocompleteClearButton, AutocompleteFilter, AutocompleteIndicator, AutocompletePopover, AutocompleteRoot, AutocompleteTrigger, AutocompleteValue };