@mdigital_ui/ui 0.4.0 → 0.4.1

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 (576) hide show
  1. package/dist/accordion/index.d.ts +6 -0
  2. package/dist/accordion/index.d.ts.map +1 -0
  3. package/dist/accordion/index.js +5 -0
  4. package/dist/accordion/index.js.map +1 -0
  5. package/dist/accordion/types.d.ts +125 -0
  6. package/dist/accordion/types.d.ts.map +1 -0
  7. package/dist/avatar/index.d.ts +14 -0
  8. package/dist/avatar/index.d.ts.map +1 -0
  9. package/dist/avatar/index.js +4 -0
  10. package/dist/avatar/index.js.map +1 -0
  11. package/dist/avatar/types.d.ts +147 -0
  12. package/dist/avatar/types.d.ts.map +1 -0
  13. package/dist/badge/index.d.ts +28 -0
  14. package/dist/badge/index.d.ts.map +1 -0
  15. package/dist/badge/index.js +5 -0
  16. package/dist/badge/index.js.map +1 -0
  17. package/dist/badge/types.d.ts +97 -0
  18. package/dist/badge/types.d.ts.map +1 -0
  19. package/dist/breadcrumbs/index.d.ts +13 -0
  20. package/dist/breadcrumbs/index.d.ts.map +1 -0
  21. package/dist/breadcrumbs/index.js +8 -0
  22. package/dist/breadcrumbs/index.js.map +1 -0
  23. package/dist/breadcrumbs/types.d.ts +118 -0
  24. package/dist/breadcrumbs/types.d.ts.map +1 -0
  25. package/dist/button/index.d.ts +15 -0
  26. package/dist/button/index.d.ts.map +1 -0
  27. package/dist/button/index.js +7 -0
  28. package/dist/button/index.js.map +1 -0
  29. package/dist/button/types.d.ts +103 -0
  30. package/dist/button/types.d.ts.map +1 -0
  31. package/dist/button-group/index.d.ts +34 -0
  32. package/dist/button-group/index.d.ts.map +1 -0
  33. package/dist/button-group/index.js +4 -0
  34. package/dist/button-group/index.js.map +1 -0
  35. package/dist/button-group/types.d.ts +75 -0
  36. package/dist/button-group/types.d.ts.map +1 -0
  37. package/dist/card/index.d.ts +71 -0
  38. package/dist/card/index.d.ts.map +1 -0
  39. package/dist/card/index.js +5 -0
  40. package/dist/card/index.js.map +1 -0
  41. package/dist/card/types.d.ts +136 -0
  42. package/dist/card/types.d.ts.map +1 -0
  43. package/dist/carousel/carousel-navigation.d.ts +9 -0
  44. package/dist/carousel/carousel-navigation.d.ts.map +1 -0
  45. package/dist/carousel/index.d.ts +50 -0
  46. package/dist/carousel/index.d.ts.map +1 -0
  47. package/dist/carousel/index.js +4 -0
  48. package/dist/carousel/index.js.map +1 -0
  49. package/dist/cascader/index.d.ts +27 -0
  50. package/dist/cascader/index.d.ts.map +1 -0
  51. package/dist/cascader/index.js +5 -0
  52. package/dist/cascader/index.js.map +1 -0
  53. package/dist/cascader/types.d.ts +220 -0
  54. package/dist/cascader/types.d.ts.map +1 -0
  55. package/dist/checkbox/index.d.ts +6 -0
  56. package/dist/checkbox/index.d.ts.map +1 -0
  57. package/dist/checkbox/index.js +5 -0
  58. package/dist/checkbox/index.js.map +1 -0
  59. package/dist/checkbox/types.d.ts +21 -0
  60. package/dist/checkbox/types.d.ts.map +1 -0
  61. package/dist/checkbox-group/index.d.ts +6 -0
  62. package/dist/checkbox-group/index.d.ts.map +1 -0
  63. package/dist/checkbox-group/index.js +4 -0
  64. package/dist/checkbox-group/index.js.map +1 -0
  65. package/dist/checkbox-group/types.d.ts +43 -0
  66. package/dist/checkbox-group/types.d.ts.map +1 -0
  67. package/dist/chunk-2PNLIQYM.js +76 -0
  68. package/dist/chunk-2PNLIQYM.js.map +1 -0
  69. package/dist/chunk-2TLOWZE4.js +689 -0
  70. package/dist/chunk-2TLOWZE4.js.map +1 -0
  71. package/dist/chunk-2WZVD7P3.js +145 -0
  72. package/dist/chunk-2WZVD7P3.js.map +1 -0
  73. package/dist/chunk-3BIV3QE2.js +353 -0
  74. package/dist/chunk-3BIV3QE2.js.map +1 -0
  75. package/dist/chunk-3BZE6BBJ.js +758 -0
  76. package/dist/chunk-3BZE6BBJ.js.map +1 -0
  77. package/dist/chunk-3PWILVOE.js +182 -0
  78. package/dist/chunk-3PWILVOE.js.map +1 -0
  79. package/dist/chunk-4FFVNUTK.js +35 -0
  80. package/dist/chunk-4FFVNUTK.js.map +1 -0
  81. package/dist/chunk-5PUATOLR.js +127 -0
  82. package/dist/chunk-5PUATOLR.js.map +1 -0
  83. package/dist/chunk-64NHVOZS.js +272 -0
  84. package/dist/chunk-64NHVOZS.js.map +1 -0
  85. package/dist/chunk-674JC24S.js +414 -0
  86. package/dist/chunk-674JC24S.js.map +1 -0
  87. package/dist/chunk-6BAP6QUT.js +72 -0
  88. package/dist/chunk-6BAP6QUT.js.map +1 -0
  89. package/dist/chunk-6G3BMY4N.js +349 -0
  90. package/dist/chunk-6G3BMY4N.js.map +1 -0
  91. package/dist/chunk-6HGUDHHE.js +86 -0
  92. package/dist/chunk-6HGUDHHE.js.map +1 -0
  93. package/dist/chunk-6JGNJI5T.js +174 -0
  94. package/dist/chunk-6JGNJI5T.js.map +1 -0
  95. package/dist/chunk-6LYRMQOI.js +328 -0
  96. package/dist/chunk-6LYRMQOI.js.map +1 -0
  97. package/dist/chunk-6YOOKE6C.js +138 -0
  98. package/dist/chunk-6YOOKE6C.js.map +1 -0
  99. package/dist/chunk-764UKE6X.js +359 -0
  100. package/dist/chunk-764UKE6X.js.map +1 -0
  101. package/dist/chunk-7UCNBMCV.js +261 -0
  102. package/dist/chunk-7UCNBMCV.js.map +1 -0
  103. package/dist/chunk-BVO2BNFG.js +437 -0
  104. package/dist/chunk-BVO2BNFG.js.map +1 -0
  105. package/dist/chunk-C5IGZLIT.js +107 -0
  106. package/dist/chunk-C5IGZLIT.js.map +1 -0
  107. package/dist/chunk-CN74CNAN.js +75 -0
  108. package/dist/chunk-CN74CNAN.js.map +1 -0
  109. package/dist/chunk-D4SUSZDN.js +360 -0
  110. package/dist/chunk-D4SUSZDN.js.map +1 -0
  111. package/dist/chunk-DUIL5BYS.js +293 -0
  112. package/dist/chunk-DUIL5BYS.js.map +1 -0
  113. package/dist/chunk-EHWXPH76.js +42 -0
  114. package/dist/chunk-EHWXPH76.js.map +1 -0
  115. package/dist/chunk-ERRZ2CSG.js +192 -0
  116. package/dist/chunk-ERRZ2CSG.js.map +1 -0
  117. package/dist/chunk-FZSCLZF6.js +552 -0
  118. package/dist/chunk-FZSCLZF6.js.map +1 -0
  119. package/dist/chunk-G6NVGBYZ.js +334 -0
  120. package/dist/chunk-G6NVGBYZ.js.map +1 -0
  121. package/dist/chunk-GJPZOMFE.js +407 -0
  122. package/dist/chunk-GJPZOMFE.js.map +1 -0
  123. package/dist/chunk-GOLARX5K.js +310 -0
  124. package/dist/chunk-GOLARX5K.js.map +1 -0
  125. package/dist/chunk-GVVP5TZM.js +506 -0
  126. package/dist/chunk-GVVP5TZM.js.map +1 -0
  127. package/dist/chunk-H6G4BUPA.js +586 -0
  128. package/dist/chunk-H6G4BUPA.js.map +1 -0
  129. package/dist/chunk-HCOTO5WX.js +77 -0
  130. package/dist/chunk-HCOTO5WX.js.map +1 -0
  131. package/dist/chunk-HECAAILV.js +94 -0
  132. package/dist/chunk-HECAAILV.js.map +1 -0
  133. package/dist/chunk-HK3NJMSY.js +383 -0
  134. package/dist/chunk-HK3NJMSY.js.map +1 -0
  135. package/dist/chunk-HUXODBIO.js +424 -0
  136. package/dist/chunk-HUXODBIO.js.map +1 -0
  137. package/dist/chunk-I32ZQUYY.js +184 -0
  138. package/dist/chunk-I32ZQUYY.js.map +1 -0
  139. package/dist/chunk-JWTWPZ32.js +355 -0
  140. package/dist/chunk-JWTWPZ32.js.map +1 -0
  141. package/dist/chunk-KH577UDI.js +218 -0
  142. package/dist/chunk-KH577UDI.js.map +1 -0
  143. package/dist/chunk-KJTMZJ7V.js +239 -0
  144. package/dist/chunk-KJTMZJ7V.js.map +1 -0
  145. package/dist/chunk-L5UYN5LX.js +787 -0
  146. package/dist/chunk-L5UYN5LX.js.map +1 -0
  147. package/dist/chunk-LOYLJRCF.js +485 -0
  148. package/dist/chunk-LOYLJRCF.js.map +1 -0
  149. package/dist/chunk-LX4FDH4J.js +299 -0
  150. package/dist/chunk-LX4FDH4J.js.map +1 -0
  151. package/dist/chunk-N2WHJ3FI.js +130 -0
  152. package/dist/chunk-N2WHJ3FI.js.map +1 -0
  153. package/dist/chunk-NGYLRX6F.js +42 -0
  154. package/dist/chunk-NGYLRX6F.js.map +1 -0
  155. package/dist/chunk-O3V3BTIJ.js +419 -0
  156. package/dist/chunk-O3V3BTIJ.js.map +1 -0
  157. package/dist/chunk-OFUPJH35.js +74 -0
  158. package/dist/chunk-OFUPJH35.js.map +1 -0
  159. package/dist/chunk-OLTQAMV2.js +210 -0
  160. package/dist/chunk-OLTQAMV2.js.map +1 -0
  161. package/dist/chunk-ON2CMF6J.js +503 -0
  162. package/dist/chunk-ON2CMF6J.js.map +1 -0
  163. package/dist/chunk-ONGJXAYQ.js +144 -0
  164. package/dist/chunk-ONGJXAYQ.js.map +1 -0
  165. package/dist/chunk-OQFYIKWR.js +1264 -0
  166. package/dist/chunk-OQFYIKWR.js.map +1 -0
  167. package/dist/chunk-PMA4VCAH.js +253 -0
  168. package/dist/chunk-PMA4VCAH.js.map +1 -0
  169. package/dist/chunk-POLVJ36Y.js +210 -0
  170. package/dist/chunk-POLVJ36Y.js.map +1 -0
  171. package/dist/chunk-POXI7JJ4.js +351 -0
  172. package/dist/chunk-POXI7JJ4.js.map +1 -0
  173. package/dist/chunk-R3TLU26W.js +110 -0
  174. package/dist/chunk-R3TLU26W.js.map +1 -0
  175. package/dist/chunk-RFHTC6AH.js +250 -0
  176. package/dist/chunk-RFHTC6AH.js.map +1 -0
  177. package/dist/chunk-ROA7BYGB.js +123 -0
  178. package/dist/chunk-ROA7BYGB.js.map +1 -0
  179. package/dist/chunk-SGRACNBP.js +60 -0
  180. package/dist/chunk-SGRACNBP.js.map +1 -0
  181. package/dist/chunk-TLNHWOQQ.js +1026 -0
  182. package/dist/chunk-TLNHWOQQ.js.map +1 -0
  183. package/dist/chunk-UTWQ2FZK.js +337 -0
  184. package/dist/chunk-UTWQ2FZK.js.map +1 -0
  185. package/dist/chunk-VOODO2ZE.js +180 -0
  186. package/dist/chunk-VOODO2ZE.js.map +1 -0
  187. package/dist/chunk-WRSG7WU5.js +278 -0
  188. package/dist/chunk-WRSG7WU5.js.map +1 -0
  189. package/dist/chunk-X3YNHX77.js +109 -0
  190. package/dist/chunk-X3YNHX77.js.map +1 -0
  191. package/dist/chunk-Y4XAXZHB.js +42 -0
  192. package/dist/chunk-Y4XAXZHB.js.map +1 -0
  193. package/dist/chunk-YJOLLSHH.js +132 -0
  194. package/dist/chunk-YJOLLSHH.js.map +1 -0
  195. package/dist/chunk-YS5AIY4A.js +43 -0
  196. package/dist/chunk-YS5AIY4A.js.map +1 -0
  197. package/dist/chunk-YXLIGJTN.js +336 -0
  198. package/dist/chunk-YXLIGJTN.js.map +1 -0
  199. package/dist/chunk-ZIYA7TGX.js +141 -0
  200. package/dist/chunk-ZIYA7TGX.js.map +1 -0
  201. package/dist/chunk-ZJNGZCRB.js +440 -0
  202. package/dist/chunk-ZJNGZCRB.js.map +1 -0
  203. package/dist/clipboard/index.d.ts +6 -0
  204. package/dist/clipboard/index.d.ts.map +1 -0
  205. package/dist/clipboard/index.js +6 -0
  206. package/dist/clipboard/index.js.map +1 -0
  207. package/dist/clipboard/types.d.ts +65 -0
  208. package/dist/clipboard/types.d.ts.map +1 -0
  209. package/dist/collapse/index.d.ts +6 -0
  210. package/dist/collapse/index.d.ts.map +1 -0
  211. package/dist/collapse/index.js +5 -0
  212. package/dist/collapse/index.js.map +1 -0
  213. package/dist/collapse/types.d.ts +60 -0
  214. package/dist/collapse/types.d.ts.map +1 -0
  215. package/dist/command/index.d.ts +74 -0
  216. package/dist/command/index.d.ts.map +1 -0
  217. package/dist/command/index.js +5 -0
  218. package/dist/command/index.js.map +1 -0
  219. package/dist/command/types.d.ts +24 -0
  220. package/dist/command/types.d.ts.map +1 -0
  221. package/dist/context-menu/index.d.ts +63 -0
  222. package/dist/context-menu/index.d.ts.map +1 -0
  223. package/dist/context-menu/index.js +5 -0
  224. package/dist/context-menu/index.js.map +1 -0
  225. package/dist/context-menu/types.d.ts +109 -0
  226. package/dist/context-menu/types.d.ts.map +1 -0
  227. package/dist/date-picker/index.d.ts +12 -0
  228. package/dist/date-picker/index.d.ts.map +1 -0
  229. package/dist/date-picker/index.js +6 -0
  230. package/dist/date-picker/index.js.map +1 -0
  231. package/dist/date-picker/types.d.ts +64 -0
  232. package/dist/date-picker/types.d.ts.map +1 -0
  233. package/dist/date-picker/utils.d.ts +10 -0
  234. package/dist/date-picker/utils.d.ts.map +1 -0
  235. package/dist/descriptions/index.d.ts +6 -0
  236. package/dist/descriptions/index.d.ts.map +1 -0
  237. package/dist/descriptions/index.js +4 -0
  238. package/dist/descriptions/index.js.map +1 -0
  239. package/dist/descriptions/types.d.ts +34 -0
  240. package/dist/descriptions/types.d.ts.map +1 -0
  241. package/dist/divider/index.d.ts +39 -0
  242. package/dist/divider/index.d.ts.map +1 -0
  243. package/dist/divider/index.js +4 -0
  244. package/dist/divider/index.js.map +1 -0
  245. package/dist/divider/types.d.ts +63 -0
  246. package/dist/divider/types.d.ts.map +1 -0
  247. package/dist/drawer/index.d.ts +23 -0
  248. package/dist/drawer/index.d.ts.map +1 -0
  249. package/dist/drawer/index.js +4 -0
  250. package/dist/drawer/index.js.map +1 -0
  251. package/dist/drawer/types.d.ts +309 -0
  252. package/dist/drawer/types.d.ts.map +1 -0
  253. package/dist/dropdown/index.d.ts +6 -0
  254. package/dist/dropdown/index.d.ts.map +1 -0
  255. package/dist/dropdown/index.js +7 -0
  256. package/dist/dropdown/index.js.map +1 -0
  257. package/dist/dropdown/types.d.ts +116 -0
  258. package/dist/dropdown/types.d.ts.map +1 -0
  259. package/dist/empty/index.d.ts +6 -0
  260. package/dist/empty/index.d.ts.map +1 -0
  261. package/dist/empty/index.js +4 -0
  262. package/dist/empty/index.js.map +1 -0
  263. package/dist/empty/types.d.ts +62 -0
  264. package/dist/empty/types.d.ts.map +1 -0
  265. package/dist/fetching-overlay/index.d.ts +10 -0
  266. package/dist/fetching-overlay/index.d.ts.map +1 -0
  267. package/dist/fetching-overlay/index.js +6 -0
  268. package/dist/fetching-overlay/index.js.map +1 -0
  269. package/dist/float-input/index.d.ts +6 -0
  270. package/dist/float-input/index.d.ts.map +1 -0
  271. package/dist/float-input/index.js +6 -0
  272. package/dist/float-input/index.js.map +1 -0
  273. package/dist/float-input/types.d.ts +23 -0
  274. package/dist/float-input/types.d.ts.map +1 -0
  275. package/dist/grid/index.d.ts +6 -0
  276. package/dist/grid/index.d.ts.map +1 -0
  277. package/dist/grid/index.js +4 -0
  278. package/dist/grid/index.js.map +1 -0
  279. package/dist/grid/types.d.ts +21 -0
  280. package/dist/grid/types.d.ts.map +1 -0
  281. package/dist/hooks/index.d.ts +6 -0
  282. package/dist/hooks/index.d.ts.map +1 -0
  283. package/dist/hooks/useControllable.d.ts +6 -0
  284. package/dist/hooks/useControllable.d.ts.map +1 -0
  285. package/dist/hooks/useDebounce.d.ts +2 -0
  286. package/dist/hooks/useDebounce.d.ts.map +1 -0
  287. package/dist/hooks/useMediaQuery.d.ts +2 -0
  288. package/dist/hooks/useMediaQuery.d.ts.map +1 -0
  289. package/dist/hooks/useRipple.d.ts +29 -0
  290. package/dist/hooks/useRipple.d.ts.map +1 -0
  291. package/dist/hooks/useThrottle.d.ts +2 -0
  292. package/dist/hooks/useThrottle.d.ts.map +1 -0
  293. package/dist/image/index.d.ts +6 -0
  294. package/dist/image/index.d.ts.map +1 -0
  295. package/dist/image/index.js +4 -0
  296. package/dist/image/index.js.map +1 -0
  297. package/dist/image/types.d.ts +57 -0
  298. package/dist/image/types.d.ts.map +1 -0
  299. package/dist/index.d.ts +142 -0
  300. package/dist/index.d.ts.map +1 -0
  301. package/dist/index.js +133 -0
  302. package/dist/index.js.map +1 -0
  303. package/dist/input/index.d.ts +6 -0
  304. package/dist/input/index.d.ts.map +1 -0
  305. package/dist/input/index.js +6 -0
  306. package/dist/input/index.js.map +1 -0
  307. package/dist/input/types.d.ts +28 -0
  308. package/dist/input/types.d.ts.map +1 -0
  309. package/dist/input-group/index.d.ts +9 -0
  310. package/dist/input-group/index.d.ts.map +1 -0
  311. package/dist/input-group/index.js +4 -0
  312. package/dist/input-group/index.js.map +1 -0
  313. package/dist/input-group/types.d.ts +68 -0
  314. package/dist/input-group/types.d.ts.map +1 -0
  315. package/dist/input-otp/index.d.ts +7 -0
  316. package/dist/input-otp/index.d.ts.map +1 -0
  317. package/dist/input-otp/index.js +4 -0
  318. package/dist/input-otp/index.js.map +1 -0
  319. package/dist/input-otp/types.d.ts +111 -0
  320. package/dist/input-otp/types.d.ts.map +1 -0
  321. package/dist/input-password/index.d.ts +6 -0
  322. package/dist/input-password/index.d.ts.map +1 -0
  323. package/dist/input-password/index.js +7 -0
  324. package/dist/input-password/index.js.map +1 -0
  325. package/dist/input-password/types.d.ts +16 -0
  326. package/dist/input-password/types.d.ts.map +1 -0
  327. package/dist/kbd/index.d.ts +6 -0
  328. package/dist/kbd/index.d.ts.map +1 -0
  329. package/dist/kbd/index.js +5 -0
  330. package/dist/kbd/index.js.map +1 -0
  331. package/dist/kbd/types.d.ts +26 -0
  332. package/dist/kbd/types.d.ts.map +1 -0
  333. package/dist/link/index.d.ts +9 -0
  334. package/dist/link/index.d.ts.map +1 -0
  335. package/dist/link/index.js +4 -0
  336. package/dist/link/index.js.map +1 -0
  337. package/dist/link/types.d.ts +30 -0
  338. package/dist/link/types.d.ts.map +1 -0
  339. package/dist/menubar/index.d.ts +6 -0
  340. package/dist/menubar/index.d.ts.map +1 -0
  341. package/dist/menubar/index.js +6 -0
  342. package/dist/menubar/index.js.map +1 -0
  343. package/dist/menubar/types.d.ts +40 -0
  344. package/dist/menubar/types.d.ts.map +1 -0
  345. package/dist/modal/index.d.ts +39 -0
  346. package/dist/modal/index.d.ts.map +1 -0
  347. package/dist/modal/index.js +4 -0
  348. package/dist/modal/index.js.map +1 -0
  349. package/dist/modal/types.d.ts +77 -0
  350. package/dist/modal/types.d.ts.map +1 -0
  351. package/dist/multi-select/index.d.ts +6 -0
  352. package/dist/multi-select/index.d.ts.map +1 -0
  353. package/dist/multi-select/index.js +8 -0
  354. package/dist/multi-select/index.js.map +1 -0
  355. package/dist/multi-select/types.d.ts +81 -0
  356. package/dist/multi-select/types.d.ts.map +1 -0
  357. package/dist/multi-select/utils.d.ts +12 -0
  358. package/dist/multi-select/utils.d.ts.map +1 -0
  359. package/dist/navigation-menu/index.d.ts +5 -0
  360. package/dist/navigation-menu/index.d.ts.map +1 -0
  361. package/dist/navigation-menu/index.js +4 -0
  362. package/dist/navigation-menu/index.js.map +1 -0
  363. package/dist/navigation-menu/types.d.ts +37 -0
  364. package/dist/navigation-menu/types.d.ts.map +1 -0
  365. package/dist/notification/index.d.ts +6 -0
  366. package/dist/notification/index.d.ts.map +1 -0
  367. package/dist/notification/index.js +5 -0
  368. package/dist/notification/index.js.map +1 -0
  369. package/dist/notification/types.d.ts +90 -0
  370. package/dist/notification/types.d.ts.map +1 -0
  371. package/dist/number-input/index.d.ts +6 -0
  372. package/dist/number-input/index.d.ts.map +1 -0
  373. package/dist/number-input/index.js +7 -0
  374. package/dist/number-input/index.js.map +1 -0
  375. package/dist/number-input/types.d.ts +28 -0
  376. package/dist/number-input/types.d.ts.map +1 -0
  377. package/dist/pagination/index.d.ts +6 -0
  378. package/dist/pagination/index.d.ts.map +1 -0
  379. package/dist/pagination/index.js +5 -0
  380. package/dist/pagination/index.js.map +1 -0
  381. package/dist/pagination/types.d.ts +87 -0
  382. package/dist/pagination/types.d.ts.map +1 -0
  383. package/dist/popover/index.d.ts +19 -0
  384. package/dist/popover/index.d.ts.map +1 -0
  385. package/dist/popover/index.js +5 -0
  386. package/dist/popover/index.js.map +1 -0
  387. package/dist/popover/types.d.ts +31 -0
  388. package/dist/popover/types.d.ts.map +1 -0
  389. package/dist/progress/index.d.ts +6 -0
  390. package/dist/progress/index.d.ts.map +1 -0
  391. package/dist/progress/index.js +4 -0
  392. package/dist/progress/index.js.map +1 -0
  393. package/dist/progress/styles.d.ts +39 -0
  394. package/dist/progress/styles.d.ts.map +1 -0
  395. package/dist/progress/types.d.ts +100 -0
  396. package/dist/progress/types.d.ts.map +1 -0
  397. package/dist/radio/index.d.ts +6 -0
  398. package/dist/radio/index.d.ts.map +1 -0
  399. package/dist/radio/index.js +5 -0
  400. package/dist/radio/index.js.map +1 -0
  401. package/dist/radio/types.d.ts +20 -0
  402. package/dist/radio/types.d.ts.map +1 -0
  403. package/dist/radio-group/index.d.ts +6 -0
  404. package/dist/radio-group/index.d.ts.map +1 -0
  405. package/dist/radio-group/index.js +4 -0
  406. package/dist/radio-group/index.js.map +1 -0
  407. package/dist/radio-group/types.d.ts +43 -0
  408. package/dist/radio-group/types.d.ts.map +1 -0
  409. package/dist/rating/index.d.ts +6 -0
  410. package/dist/rating/index.d.ts.map +1 -0
  411. package/dist/rating/index.js +4 -0
  412. package/dist/rating/index.js.map +1 -0
  413. package/dist/rating/types.d.ts +64 -0
  414. package/dist/rating/types.d.ts.map +1 -0
  415. package/dist/scroll-area/index.d.ts +10 -0
  416. package/dist/scroll-area/index.d.ts.map +1 -0
  417. package/dist/scroll-area/index.js +4 -0
  418. package/dist/scroll-area/index.js.map +1 -0
  419. package/dist/scroll-area/types.d.ts +24 -0
  420. package/dist/scroll-area/types.d.ts.map +1 -0
  421. package/dist/select/index.d.ts +6 -0
  422. package/dist/select/index.d.ts.map +1 -0
  423. package/dist/select/index.js +8 -0
  424. package/dist/select/index.js.map +1 -0
  425. package/dist/select/types.d.ts +34 -0
  426. package/dist/select/types.d.ts.map +1 -0
  427. package/dist/shared/useSelectBase.d.ts +56 -0
  428. package/dist/shared/useSelectBase.d.ts.map +1 -0
  429. package/dist/skeleton/index.d.ts +6 -0
  430. package/dist/skeleton/index.d.ts.map +1 -0
  431. package/dist/skeleton/index.js +5 -0
  432. package/dist/skeleton/index.js.map +1 -0
  433. package/dist/skeleton/types.d.ts +10 -0
  434. package/dist/skeleton/types.d.ts.map +1 -0
  435. package/dist/slider/index.d.ts +6 -0
  436. package/dist/slider/index.d.ts.map +1 -0
  437. package/dist/slider/index.js +4 -0
  438. package/dist/slider/index.js.map +1 -0
  439. package/dist/slider/types.d.ts +76 -0
  440. package/dist/slider/types.d.ts.map +1 -0
  441. package/dist/spinner/index.d.ts +6 -0
  442. package/dist/spinner/index.d.ts.map +1 -0
  443. package/dist/spinner/index.js +5 -0
  444. package/dist/spinner/index.js.map +1 -0
  445. package/dist/spinner/types.d.ts +10 -0
  446. package/dist/spinner/types.d.ts.map +1 -0
  447. package/dist/stepper/index.d.ts +6 -0
  448. package/dist/stepper/index.d.ts.map +1 -0
  449. package/dist/stepper/index.js +4 -0
  450. package/dist/stepper/index.js.map +1 -0
  451. package/dist/stepper/types.d.ts +86 -0
  452. package/dist/stepper/types.d.ts.map +1 -0
  453. package/dist/styles/themes/index.d.ts +9 -0
  454. package/dist/styles/themes/index.d.ts.map +1 -0
  455. package/dist/styles/themes/presets/index.d.ts +21 -0
  456. package/dist/styles/themes/presets/index.d.ts.map +1 -0
  457. package/dist/styles/tokens.d.ts +428 -0
  458. package/dist/styles/tokens.d.ts.map +1 -0
  459. package/dist/switch/index.d.ts +6 -0
  460. package/dist/switch/index.d.ts.map +1 -0
  461. package/dist/switch/index.js +5 -0
  462. package/dist/switch/index.js.map +1 -0
  463. package/dist/switch/types.d.ts +80 -0
  464. package/dist/switch/types.d.ts.map +1 -0
  465. package/dist/table/EditableCell.d.ts +13 -0
  466. package/dist/table/EditableCell.d.ts.map +1 -0
  467. package/dist/table/TableActions.d.ts +21 -0
  468. package/dist/table/TableActions.d.ts.map +1 -0
  469. package/dist/table/TableCell.d.ts +12 -0
  470. package/dist/table/TableCell.d.ts.map +1 -0
  471. package/dist/table/TableHeaderCell.d.ts +16 -0
  472. package/dist/table/TableHeaderCell.d.ts.map +1 -0
  473. package/dist/table/TableRow.d.ts +16 -0
  474. package/dist/table/TableRow.d.ts.map +1 -0
  475. package/dist/table/TableSkeleton.d.ts +13 -0
  476. package/dist/table/TableSkeleton.d.ts.map +1 -0
  477. package/dist/table/index.d.ts +15 -0
  478. package/dist/table/index.d.ts.map +1 -0
  479. package/dist/table/index.js +13 -0
  480. package/dist/table/index.js.map +1 -0
  481. package/dist/table/types.d.ts +110 -0
  482. package/dist/table/types.d.ts.map +1 -0
  483. package/dist/table/variants.d.ts +4 -0
  484. package/dist/table/variants.d.ts.map +1 -0
  485. package/dist/tabs/index.d.ts +7 -0
  486. package/dist/tabs/index.d.ts.map +1 -0
  487. package/dist/tabs/index.js +5 -0
  488. package/dist/tabs/index.js.map +1 -0
  489. package/dist/tabs/types.d.ts +90 -0
  490. package/dist/tabs/types.d.ts.map +1 -0
  491. package/dist/tag/index.d.ts +49 -0
  492. package/dist/tag/index.d.ts.map +1 -0
  493. package/dist/tag/index.js +5 -0
  494. package/dist/tag/index.js.map +1 -0
  495. package/dist/tag/types.d.ts +23 -0
  496. package/dist/tag/types.d.ts.map +1 -0
  497. package/dist/textarea/index.d.ts +6 -0
  498. package/dist/textarea/index.d.ts.map +1 -0
  499. package/dist/textarea/index.js +4 -0
  500. package/dist/textarea/index.js.map +1 -0
  501. package/dist/textarea/types.d.ts +84 -0
  502. package/dist/textarea/types.d.ts.map +1 -0
  503. package/dist/theme/ThemeProvider.d.ts +44 -0
  504. package/dist/theme/ThemeProvider.d.ts.map +1 -0
  505. package/dist/theme/index.d.ts +7 -0
  506. package/dist/theme/index.d.ts.map +1 -0
  507. package/dist/theme/index.js +3 -0
  508. package/dist/theme/index.js.map +1 -0
  509. package/dist/theme/types.d.ts +47 -0
  510. package/dist/theme/types.d.ts.map +1 -0
  511. package/dist/timeline/index.d.ts +6 -0
  512. package/dist/timeline/index.d.ts.map +1 -0
  513. package/dist/timeline/index.js +4 -0
  514. package/dist/timeline/index.js.map +1 -0
  515. package/dist/timeline/types.d.ts +27 -0
  516. package/dist/timeline/types.d.ts.map +1 -0
  517. package/dist/toast/index.d.ts +12 -0
  518. package/dist/toast/index.d.ts.map +1 -0
  519. package/dist/toast/index.js +5 -0
  520. package/dist/toast/index.js.map +1 -0
  521. package/dist/toast/types.d.ts +49 -0
  522. package/dist/toast/types.d.ts.map +1 -0
  523. package/dist/toggle/index.d.ts +6 -0
  524. package/dist/toggle/index.d.ts.map +1 -0
  525. package/dist/toggle/index.js +5 -0
  526. package/dist/toggle/index.js.map +1 -0
  527. package/dist/toggle/types.d.ts +57 -0
  528. package/dist/toggle/types.d.ts.map +1 -0
  529. package/dist/toggle-group/index.d.ts +6 -0
  530. package/dist/toggle-group/index.d.ts.map +1 -0
  531. package/dist/toggle-group/index.js +5 -0
  532. package/dist/toggle-group/index.js.map +1 -0
  533. package/dist/toggle-group/types.d.ts +80 -0
  534. package/dist/toggle-group/types.d.ts.map +1 -0
  535. package/dist/tooltip/index.d.ts +9 -0
  536. package/dist/tooltip/index.d.ts.map +1 -0
  537. package/dist/tooltip/index.js +5 -0
  538. package/dist/tooltip/index.js.map +1 -0
  539. package/dist/tooltip/types.d.ts +72 -0
  540. package/dist/tooltip/types.d.ts.map +1 -0
  541. package/dist/transfer/index.d.ts +5 -0
  542. package/dist/transfer/index.d.ts.map +1 -0
  543. package/dist/transfer/index.js +6 -0
  544. package/dist/transfer/index.js.map +1 -0
  545. package/dist/transfer/types.d.ts +83 -0
  546. package/dist/transfer/types.d.ts.map +1 -0
  547. package/dist/transfer/utils.d.ts +13 -0
  548. package/dist/transfer/utils.d.ts.map +1 -0
  549. package/dist/tree/index.d.ts +6 -0
  550. package/dist/tree/index.d.ts.map +1 -0
  551. package/dist/tree/index.js +4 -0
  552. package/dist/tree/index.js.map +1 -0
  553. package/dist/tree/types.d.ts +143 -0
  554. package/dist/tree/types.d.ts.map +1 -0
  555. package/dist/tree-select/index.d.ts +6 -0
  556. package/dist/tree-select/index.d.ts.map +1 -0
  557. package/dist/tree-select/index.js +7 -0
  558. package/dist/tree-select/index.js.map +1 -0
  559. package/dist/tree-select/types.d.ts +147 -0
  560. package/dist/tree-select/types.d.ts.map +1 -0
  561. package/dist/types.d.ts +53 -0
  562. package/dist/types.d.ts.map +1 -0
  563. package/dist/upload/index.d.ts +7 -0
  564. package/dist/upload/index.d.ts.map +1 -0
  565. package/dist/upload/index.js +5 -0
  566. package/dist/upload/index.js.map +1 -0
  567. package/dist/upload/types.d.ts +94 -0
  568. package/dist/upload/types.d.ts.map +1 -0
  569. package/dist/upload/utils.d.ts +26 -0
  570. package/dist/upload/utils.d.ts.map +1 -0
  571. package/dist/utils.d.ts +63 -0
  572. package/dist/utils.d.ts.map +1 -0
  573. package/dist/variants.d.ts +315 -0
  574. package/dist/variants.d.ts.map +1 -0
  575. package/package.json +1 -1
  576. package/styles/global.css +176 -245
@@ -0,0 +1,180 @@
1
+ import { cn } from './chunk-NGYLRX6F.js';
2
+ import { cva } from 'class-variance-authority';
3
+ import React from 'react';
4
+ import { jsxs, jsx } from 'react/jsx-runtime';
5
+
6
+ var dividerVariants = cva("", {
7
+ variants: {
8
+ orientation: {
9
+ horizontal: "w-full",
10
+ vertical: "h-full"
11
+ },
12
+ variant: {
13
+ solid: "border-solid",
14
+ dashed: "border-dashed",
15
+ dotted: "border-dotted"
16
+ }
17
+ },
18
+ defaultVariants: {
19
+ orientation: "horizontal",
20
+ variant: "solid"
21
+ }
22
+ });
23
+ var dividerBorderColorClasses = {
24
+ default: "border-border",
25
+ primary: "border-primary",
26
+ secondary: "border-secondary",
27
+ accent: "border-accent",
28
+ success: "border-success",
29
+ error: "border-error",
30
+ warning: "border-warning",
31
+ info: "border-info"
32
+ };
33
+ var dividerLabelColorClasses = {
34
+ default: "text-text-secondary",
35
+ primary: "text-primary",
36
+ secondary: "text-secondary",
37
+ accent: "text-accent",
38
+ success: "text-success",
39
+ error: "text-error",
40
+ warning: "text-warning",
41
+ info: "text-info"
42
+ };
43
+ var textAlignClasses = {
44
+ left: {
45
+ before: "w-(--divider-left-before-width)",
46
+ after: "w-(--divider-left-after-width)"
47
+ },
48
+ center: {
49
+ before: "w-(--divider-center-before-width)",
50
+ after: "w-(--divider-center-after-width)"
51
+ },
52
+ right: {
53
+ before: "w-(--divider-right-before-width)",
54
+ after: "w-(--divider-right-after-width)"
55
+ }
56
+ };
57
+ var Divider = React.memo(
58
+ ({
59
+ orientation = "horizontal",
60
+ variant = "solid",
61
+ color = "default",
62
+ children,
63
+ textAlign = "center",
64
+ spacing,
65
+ className,
66
+ classNames,
67
+ ref,
68
+ ...props
69
+ }) => {
70
+ const hasText = Boolean(children);
71
+ if (orientation === "horizontal") {
72
+ if (hasText) {
73
+ return /* @__PURE__ */ jsxs(
74
+ "div",
75
+ {
76
+ ref,
77
+ role: "separator",
78
+ "aria-orientation": "horizontal",
79
+ "data-slot": "root",
80
+ className: cn(
81
+ "divider_root",
82
+ "flex items-center gap-(--divider-gap) text-sm",
83
+ dividerLabelColorClasses[color],
84
+ className,
85
+ classNames?.root
86
+ ),
87
+ style: spacing ? { margin: spacing } : void 0,
88
+ ...props,
89
+ children: [
90
+ /* @__PURE__ */ jsx(
91
+ "div",
92
+ {
93
+ "data-slot": "line",
94
+ className: cn(
95
+ "divider_line",
96
+ "border-t",
97
+ dividerVariants({ variant }),
98
+ dividerBorderColorClasses[color],
99
+ textAlignClasses[textAlign].before,
100
+ classNames?.line
101
+ )
102
+ }
103
+ ),
104
+ /* @__PURE__ */ jsx(
105
+ "span",
106
+ {
107
+ "data-slot": "label",
108
+ className: cn(
109
+ "divider_label",
110
+ "whitespace-nowrap flex-shrink-0",
111
+ classNames?.label
112
+ ),
113
+ children
114
+ }
115
+ ),
116
+ /* @__PURE__ */ jsx(
117
+ "div",
118
+ {
119
+ "data-slot": "line",
120
+ className: cn(
121
+ "divider_line",
122
+ "border-t",
123
+ dividerVariants({ variant }),
124
+ dividerBorderColorClasses[color],
125
+ textAlignClasses[textAlign].after,
126
+ classNames?.line
127
+ )
128
+ }
129
+ )
130
+ ]
131
+ }
132
+ );
133
+ }
134
+ return /* @__PURE__ */ jsx(
135
+ "hr",
136
+ {
137
+ ref,
138
+ role: "separator",
139
+ "aria-orientation": "horizontal",
140
+ "data-slot": "root",
141
+ className: cn(
142
+ "divider_root",
143
+ "border-t",
144
+ dividerVariants({ orientation, variant }),
145
+ dividerBorderColorClasses[color],
146
+ className,
147
+ classNames?.root
148
+ ),
149
+ style: spacing ? { margin: spacing } : void 0,
150
+ ...props
151
+ }
152
+ );
153
+ }
154
+ return /* @__PURE__ */ jsx(
155
+ "div",
156
+ {
157
+ ref,
158
+ role: "separator",
159
+ "aria-orientation": "vertical",
160
+ "data-slot": "root",
161
+ className: cn(
162
+ "divider_root",
163
+ "inline-block w-px border-l self-stretch",
164
+ dividerVariants({ variant }),
165
+ dividerBorderColorClasses[color],
166
+ className,
167
+ classNames?.root
168
+ ),
169
+ style: spacing ? { margin: spacing } : void 0,
170
+ ...props
171
+ }
172
+ );
173
+ }
174
+ );
175
+ Divider.displayName = "Divider";
176
+ var divider_default = Divider;
177
+
178
+ export { divider_default };
179
+ //# sourceMappingURL=chunk-VOODO2ZE.js.map
180
+ //# sourceMappingURL=chunk-VOODO2ZE.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/divider/index.tsx"],"names":[],"mappings":"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","file":"chunk-VOODO2ZE.js","sourcesContent":["import { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport type { ComponentColor } from '../types'\nimport { cn } from '../utils'\nimport type { DividerProps } from './types'\n\n/**\n * Class variance authority configuration for the Divider component\n * Defines style variants for orientation, line style, and text alignment\n */\nconst dividerVariants = cva('', {\n variants: {\n orientation: {\n horizontal: 'w-full',\n vertical: 'h-full',\n },\n variant: {\n solid: 'border-solid',\n dashed: 'border-dashed',\n dotted: 'border-dotted',\n },\n },\n defaultVariants: {\n orientation: 'horizontal',\n variant: 'solid',\n },\n})\n\n/**\n * Border color classes for the divider line\n */\nconst dividerBorderColorClasses: Record<ComponentColor, string> = {\n default: 'border-border',\n primary: 'border-primary',\n secondary: 'border-secondary',\n accent: 'border-accent',\n success: 'border-success',\n error: 'border-error',\n warning: 'border-warning',\n info: 'border-info',\n}\n\n/**\n * Text color classes for the divider label\n */\nconst dividerLabelColorClasses: Record<ComponentColor, string> = {\n default: 'text-text-secondary',\n primary: 'text-primary',\n secondary: 'text-secondary',\n accent: 'text-accent',\n success: 'text-success',\n error: 'text-error',\n warning: 'text-warning',\n info: 'text-info',\n}\n\n/**\n * Text alignment styles for the label within the divider\n * Defines the width distribution of divider lines before and after the label\n * Uses design tokens for customizability\n */\nconst textAlignClasses = {\n left: {\n before: 'w-(--divider-left-before-width)',\n after: 'w-(--divider-left-after-width)',\n },\n center: {\n before: 'w-(--divider-center-before-width)',\n after: 'w-(--divider-center-after-width)',\n },\n right: {\n before: 'w-(--divider-right-before-width)',\n after: 'w-(--divider-right-after-width)',\n },\n}\n\n/**\n * Divider Component\n *\n * A visual separator that can be used to divide content sections.\n * Supports horizontal and vertical orientations, different line styles,\n * color variants, and optional label text.\n *\n * @component\n * @example\n * // Basic horizontal divider\n * <Divider />\n *\n * @example\n * // Divider with text label\n * <Divider>Section Title</Divider>\n *\n * @example\n * // Colored divider\n * <Divider color=\"primary\" />\n *\n * @example\n * // Vertical divider\n * <Divider orientation=\"vertical\" />\n *\n * @example\n * // Dashed divider with left-aligned text\n * <Divider variant=\"dashed\" textAlign=\"left\" color=\"accent\">\n * Options\n * </Divider>\n *\n * @param {DividerProps} props - Component props\n * @returns {JSX.Element} Rendered divider component\n */\nconst Divider = React.memo<DividerProps>(\n ({\n orientation = 'horizontal',\n variant = 'solid',\n color = 'default',\n children,\n textAlign = 'center',\n spacing,\n className,\n classNames,\n ref,\n ...props\n }) => {\n const hasText = Boolean(children)\n\n /**\n * Render horizontal divider\n * Supports optional text label with configurable alignment\n */\n if (orientation === 'horizontal') {\n if (hasText) {\n return (\n <div\n ref={ref as React.Ref<HTMLDivElement>}\n role=\"separator\"\n aria-orientation=\"horizontal\"\n data-slot=\"root\"\n className={cn(\n 'divider_root',\n 'flex items-center gap-(--divider-gap) text-sm',\n dividerLabelColorClasses[color],\n className,\n classNames?.root,\n )}\n style={spacing ? { margin: spacing } : undefined}\n {...props}\n >\n <div\n data-slot=\"line\"\n className={cn(\n 'divider_line',\n 'border-t',\n dividerVariants({ variant }),\n dividerBorderColorClasses[color],\n textAlignClasses[textAlign].before,\n classNames?.line,\n )}\n />\n <span\n data-slot=\"label\"\n className={cn(\n 'divider_label',\n 'whitespace-nowrap flex-shrink-0',\n classNames?.label,\n )}\n >\n {children}\n </span>\n <div\n data-slot=\"line\"\n className={cn(\n 'divider_line',\n 'border-t',\n dividerVariants({ variant }),\n dividerBorderColorClasses[color],\n textAlignClasses[textAlign].after,\n classNames?.line,\n )}\n />\n </div>\n )\n }\n\n return (\n <hr\n ref={ref as React.Ref<HTMLHRElement>}\n role=\"separator\"\n aria-orientation=\"horizontal\"\n data-slot=\"root\"\n className={cn(\n 'divider_root',\n 'border-t',\n dividerVariants({ orientation, variant }),\n dividerBorderColorClasses[color],\n className,\n classNames?.root,\n )}\n style={spacing ? { margin: spacing } : undefined}\n {...props}\n />\n )\n }\n\n /**\n * Render vertical divider\n * Text labels are not supported in vertical orientation\n */\n\n return (\n <div\n ref={ref as React.Ref<HTMLDivElement>}\n role=\"separator\"\n aria-orientation=\"vertical\"\n data-slot=\"root\"\n className={cn(\n 'divider_root',\n 'inline-block w-px border-l self-stretch',\n dividerVariants({ variant }),\n dividerBorderColorClasses[color],\n className,\n classNames?.root,\n )}\n style={spacing ? { margin: spacing } : undefined}\n {...props}\n />\n )\n },\n)\n\nDivider.displayName = 'Divider'\n\nexport type * from './types'\nexport default Divider\n"]}
@@ -0,0 +1,278 @@
1
+ import { getValidationStatus } from './chunk-NGYLRX6F.js';
2
+ import { useVirtualizer } from '@tanstack/react-virtual';
3
+ import React, { useId, useCallback } from 'react';
4
+
5
+ function useSelectBase(config) {
6
+ const {
7
+ options,
8
+ virtualizeThreshold = 50,
9
+ maxDropdownHeight = 300,
10
+ label,
11
+ idPrefix,
12
+ error,
13
+ warning,
14
+ info,
15
+ success,
16
+ helperText
17
+ } = config;
18
+ const uniqueId = useId();
19
+ const labelId = `${idPrefix}-label-${uniqueId}`;
20
+ const listboxId = `${idPrefix}-listbox-${uniqueId}`;
21
+ const helperId = `${idPrefix}-helper-${uniqueId}`;
22
+ const { status, message: helperMessage } = getValidationStatus({
23
+ error,
24
+ warning,
25
+ info,
26
+ success,
27
+ helperText
28
+ });
29
+ const [isOpen, setIsOpen] = React.useState(false);
30
+ const [parentNode, setParentNode] = React.useState(
31
+ null
32
+ );
33
+ const [searchQuery, setSearchQuery] = React.useState("");
34
+ const [highlightedIndex, setHighlightedIndex] = React.useState(-1);
35
+ const [showTopArrow, setShowTopArrow] = React.useState(false);
36
+ const [showBottomArrow, setShowBottomArrow] = React.useState(false);
37
+ const triggerRef = React.useRef(null);
38
+ const inputRef = React.useRef(null);
39
+ const scrollContainerRef = React.useRef(null);
40
+ const onSelectRef = React.useRef(config.onSelectOption);
41
+ React.useEffect(() => {
42
+ onSelectRef.current = config.onSelectOption;
43
+ }, [config.onSelectOption]);
44
+ const groupedOptions = React.useMemo(() => {
45
+ const groups = {};
46
+ const ungrouped = [];
47
+ options.forEach((option) => {
48
+ if (option.group) {
49
+ if (!groups[option.group]) {
50
+ groups[option.group] = [];
51
+ }
52
+ groups[option.group].push(option);
53
+ } else {
54
+ ungrouped.push(option);
55
+ }
56
+ });
57
+ return { groups, ungrouped };
58
+ }, [options]);
59
+ const flattenedOptions = React.useMemo(() => {
60
+ const items = [];
61
+ groupedOptions.ungrouped.forEach((option) => {
62
+ items.push({ type: "option", data: option });
63
+ });
64
+ Object.entries(groupedOptions.groups).forEach(
65
+ ([groupName, groupOptions]) => {
66
+ items.push({ type: "group", data: groupName });
67
+ groupOptions.forEach((option) => {
68
+ items.push({ type: "option", data: option });
69
+ });
70
+ }
71
+ );
72
+ return items;
73
+ }, [groupedOptions]);
74
+ const filteredOptions = React.useMemo(() => {
75
+ if (!searchQuery) return flattenedOptions;
76
+ const query = searchQuery.toLowerCase();
77
+ const matchingOptions = new Set(
78
+ flattenedOptions.filter(
79
+ (item) => item.type === "option" && item.data.label.toLowerCase().includes(query)
80
+ )
81
+ );
82
+ return flattenedOptions.filter((item) => {
83
+ if (item.type === "group") {
84
+ const groupName = item.data;
85
+ return flattenedOptions.some(
86
+ (other) => other.type === "option" && other.data.group === groupName && matchingOptions.has(other)
87
+ );
88
+ }
89
+ return matchingOptions.has(item);
90
+ });
91
+ }, [flattenedOptions, searchQuery]);
92
+ const selectableOptions = React.useMemo(
93
+ () => filteredOptions.filter(
94
+ (item) => item.type === "option" && !item.data.disabled
95
+ ),
96
+ [filteredOptions]
97
+ );
98
+ const shouldVirtualize = filteredOptions.length > virtualizeThreshold;
99
+ const virtualizer = useVirtualizer({
100
+ count: filteredOptions.length,
101
+ getScrollElement: () => parentNode,
102
+ estimateSize: () => 40,
103
+ enabled: shouldVirtualize,
104
+ overscan: 10
105
+ });
106
+ const virtualizerRef = React.useRef(virtualizer);
107
+ React.useEffect(() => {
108
+ virtualizerRef.current = virtualizer;
109
+ }, [virtualizer]);
110
+ const refCallback = useCallback((node) => {
111
+ if (node) {
112
+ setParentNode(node);
113
+ scrollContainerRef.current = node;
114
+ }
115
+ }, []);
116
+ const handleInputChange = React.useCallback(
117
+ (e) => {
118
+ setSearchQuery(e.target.value);
119
+ if (!isOpen) setIsOpen(true);
120
+ },
121
+ [isOpen]
122
+ );
123
+ const handleInputClick = React.useCallback(
124
+ (e) => {
125
+ e.stopPropagation();
126
+ if (!isOpen) setIsOpen(true);
127
+ },
128
+ [isOpen]
129
+ );
130
+ const handleScroll = React.useCallback(
131
+ (e) => {
132
+ const element = e.currentTarget;
133
+ const { scrollTop, scrollHeight, clientHeight } = element;
134
+ setShowTopArrow(scrollTop > 0);
135
+ setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
136
+ },
137
+ []
138
+ );
139
+ const handleKeyDown = React.useCallback(
140
+ (e) => {
141
+ if (!isOpen && e.key !== "Tab") {
142
+ if (e.key === "Enter" || e.key === " " || e.key === "ArrowDown") {
143
+ e.preventDefault();
144
+ setIsOpen(true);
145
+ }
146
+ return;
147
+ }
148
+ const currentSelectableOptions = filteredOptions.filter(
149
+ (item) => item.type === "option" && !item.data.disabled
150
+ );
151
+ switch (e.key) {
152
+ case "Escape":
153
+ e.preventDefault();
154
+ setIsOpen(false);
155
+ setSearchQuery("");
156
+ setHighlightedIndex(-1);
157
+ inputRef.current?.blur();
158
+ break;
159
+ case "ArrowDown":
160
+ e.preventDefault();
161
+ setHighlightedIndex((prev) => {
162
+ const nextIndex = Math.min(
163
+ prev + 1,
164
+ currentSelectableOptions.length - 1
165
+ );
166
+ const option = currentSelectableOptions[nextIndex];
167
+ if (option) {
168
+ const optionIndex = filteredOptions.indexOf(option);
169
+ if (shouldVirtualize && virtualizerRef.current) {
170
+ virtualizerRef.current.scrollToIndex(optionIndex, {
171
+ align: "auto"
172
+ });
173
+ }
174
+ }
175
+ return nextIndex;
176
+ });
177
+ break;
178
+ case "ArrowUp":
179
+ e.preventDefault();
180
+ setHighlightedIndex((prev) => {
181
+ const nextIndex = Math.max(prev - 1, 0);
182
+ const option = currentSelectableOptions[nextIndex];
183
+ if (option) {
184
+ const optionIndex = filteredOptions.indexOf(option);
185
+ if (shouldVirtualize && virtualizerRef.current) {
186
+ virtualizerRef.current.scrollToIndex(optionIndex, {
187
+ align: "auto"
188
+ });
189
+ }
190
+ }
191
+ return nextIndex;
192
+ });
193
+ break;
194
+ case "Enter":
195
+ e.preventDefault();
196
+ if (highlightedIndex >= 0 && highlightedIndex < currentSelectableOptions.length) {
197
+ const item = currentSelectableOptions[highlightedIndex];
198
+ if (item) {
199
+ const option = item.data;
200
+ onSelectRef.current(option);
201
+ }
202
+ }
203
+ break;
204
+ case "Home":
205
+ e.preventDefault();
206
+ setHighlightedIndex(0);
207
+ if (shouldVirtualize && virtualizerRef.current) {
208
+ virtualizerRef.current.scrollToIndex(0);
209
+ }
210
+ break;
211
+ case "End":
212
+ e.preventDefault();
213
+ setHighlightedIndex(currentSelectableOptions.length - 1);
214
+ if (shouldVirtualize && virtualizerRef.current) {
215
+ virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);
216
+ }
217
+ break;
218
+ }
219
+ },
220
+ [isOpen, filteredOptions, highlightedIndex, shouldVirtualize]
221
+ );
222
+ React.useEffect(() => {
223
+ if (isOpen) {
224
+ const timeoutId = setTimeout(() => {
225
+ const element = scrollContainerRef.current;
226
+ if (element) {
227
+ const { scrollTop, scrollHeight, clientHeight } = element;
228
+ setShowTopArrow(scrollTop > 0);
229
+ setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);
230
+ }
231
+ }, 50);
232
+ return () => clearTimeout(timeoutId);
233
+ } else {
234
+ setShowTopArrow(false);
235
+ setShowBottomArrow(false);
236
+ return void 0;
237
+ }
238
+ }, [isOpen, filteredOptions, shouldVirtualize]);
239
+ return {
240
+ // State
241
+ isOpen,
242
+ setIsOpen,
243
+ searchQuery,
244
+ setSearchQuery,
245
+ highlightedIndex,
246
+ setHighlightedIndex,
247
+ showTopArrow,
248
+ showBottomArrow,
249
+ // Refs
250
+ triggerRef,
251
+ inputRef,
252
+ scrollContainerRef,
253
+ // Computed
254
+ filteredOptions,
255
+ selectableOptions,
256
+ shouldVirtualize,
257
+ virtualizer,
258
+ maxDropdownHeight,
259
+ label,
260
+ // IDs & validation
261
+ uniqueId,
262
+ labelId,
263
+ listboxId,
264
+ helperId,
265
+ status,
266
+ helperMessage,
267
+ // Handlers
268
+ handleInputChange,
269
+ handleInputClick,
270
+ handleScroll,
271
+ handleKeyDown,
272
+ refCallback
273
+ };
274
+ }
275
+
276
+ export { useSelectBase };
277
+ //# sourceMappingURL=chunk-WRSG7WU5.js.map
278
+ //# sourceMappingURL=chunk-WRSG7WU5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/shared/useSelectBase.ts"],"names":[],"mappings":"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","file":"chunk-WRSG7WU5.js","sourcesContent":["import { useVirtualizer } from \"@tanstack/react-virtual\";\nimport React, { useCallback, useId } from \"react\";\n\nimport { getValidationStatus } from \"../utils\";\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\nexport interface SelectBaseOption {\n value: string | number;\n label: string;\n disabled?: boolean;\n group?: string;\n}\n\nexport interface UseSelectBaseConfig<O extends SelectBaseOption> {\n options: O[];\n /** Called when the user presses Enter on a highlighted option (or clicks one via the hook's helpers). */\n onSelectOption: (option: O) => void;\n virtualizeThreshold?: number;\n maxDropdownHeight?: number;\n label?: string;\n idPrefix: string; // 'select' or 'multiselect'\n error?: string | boolean;\n warning?: string | boolean;\n info?: string | boolean;\n success?: string | boolean;\n helperText?: string;\n}\n\nexport interface FlattenedItem<O extends SelectBaseOption> {\n type: \"option\" | \"group\";\n data: O | string;\n}\n\n// ---------------------------------------------------------------------------\n// Hook\n// ---------------------------------------------------------------------------\n\nexport function useSelectBase<O extends SelectBaseOption>(\n config: UseSelectBaseConfig<O>,\n) {\n const {\n options,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n label,\n idPrefix,\n error,\n warning,\n info,\n success,\n helperText,\n } = config;\n\n // -- IDs / validation -------------------------------------------------------\n const uniqueId = useId();\n const labelId = `${idPrefix}-label-${uniqueId}`;\n const listboxId = `${idPrefix}-listbox-${uniqueId}`;\n const helperId = `${idPrefix}-helper-${uniqueId}`;\n\n const { status, message: helperMessage } = getValidationStatus({\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n // -- State ------------------------------------------------------------------\n const [isOpen, setIsOpen] = React.useState(false);\n const [parentNode, setParentNode] = React.useState<HTMLDivElement | null>(\n null,\n );\n const [searchQuery, setSearchQuery] = React.useState(\"\");\n const [highlightedIndex, setHighlightedIndex] = React.useState(-1);\n const [showTopArrow, setShowTopArrow] = React.useState(false);\n const [showBottomArrow, setShowBottomArrow] = React.useState(false);\n\n // -- Refs -------------------------------------------------------------------\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const scrollContainerRef = React.useRef<HTMLDivElement>(null);\n\n // Store onSelectOption in a ref so handleKeyDown doesn't depend on it\n const onSelectRef = React.useRef(config.onSelectOption);\n React.useEffect(() => {\n onSelectRef.current = config.onSelectOption;\n }, [config.onSelectOption]);\n\n // -- Memos ------------------------------------------------------------------\n const groupedOptions = React.useMemo(() => {\n const groups: Record<string, O[]> = {};\n const ungrouped: O[] = [];\n\n options.forEach((option) => {\n if (option.group) {\n if (!groups[option.group]) {\n groups[option.group] = [];\n }\n groups[option.group]!.push(option);\n } else {\n ungrouped.push(option);\n }\n });\n\n return { groups, ungrouped };\n }, [options]);\n\n const flattenedOptions = React.useMemo(() => {\n const items: Array<FlattenedItem<O>> = [];\n\n groupedOptions.ungrouped.forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n\n Object.entries(groupedOptions.groups).forEach(\n ([groupName, groupOptions]) => {\n items.push({ type: \"group\", data: groupName });\n (groupOptions as O[]).forEach((option) => {\n items.push({ type: \"option\", data: option });\n });\n },\n );\n\n return items;\n }, [groupedOptions]);\n\n const filteredOptions = React.useMemo(() => {\n if (!searchQuery) return flattenedOptions;\n\n const query = searchQuery.toLowerCase();\n const matchingOptions = new Set(\n flattenedOptions.filter(\n (item) =>\n item.type === \"option\" &&\n (item.data as O).label.toLowerCase().includes(query),\n ),\n );\n\n return flattenedOptions.filter((item) => {\n if (item.type === \"group\") {\n const groupName = item.data as string;\n return flattenedOptions.some(\n (other) =>\n other.type === \"option\" &&\n (other.data as O).group === groupName &&\n matchingOptions.has(other),\n );\n }\n return matchingOptions.has(item);\n });\n }, [flattenedOptions, searchQuery]);\n\n const selectableOptions = React.useMemo(\n () =>\n filteredOptions.filter(\n (item) => item.type === \"option\" && !(item.data as O).disabled,\n ),\n [filteredOptions],\n );\n\n const shouldVirtualize = filteredOptions.length > virtualizeThreshold;\n\n // -- Virtualizer ------------------------------------------------------------\n const virtualizer = useVirtualizer({\n count: filteredOptions.length,\n getScrollElement: () => parentNode,\n estimateSize: () => 40,\n enabled: shouldVirtualize,\n overscan: 10,\n });\n\n const virtualizerRef = React.useRef(virtualizer);\n React.useEffect(() => {\n virtualizerRef.current = virtualizer;\n }, [virtualizer]);\n\n const refCallback = useCallback((node: HTMLDivElement) => {\n if (node) {\n setParentNode(node);\n scrollContainerRef.current = node;\n }\n }, []);\n\n // -- Handlers ---------------------------------------------------------------\n const handleInputChange = React.useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setSearchQuery(e.target.value);\n if (!isOpen) setIsOpen(true);\n },\n [isOpen],\n );\n\n const handleInputClick = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n if (!isOpen) setIsOpen(true);\n },\n [isOpen],\n );\n\n const handleScroll = React.useCallback(\n (e: React.UIEvent<HTMLDivElement>) => {\n const element = e.currentTarget;\n const { scrollTop, scrollHeight, clientHeight } = element;\n\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n },\n [],\n );\n\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent) => {\n if (!isOpen && e.key !== \"Tab\") {\n if (e.key === \"Enter\" || e.key === \" \" || e.key === \"ArrowDown\") {\n e.preventDefault();\n setIsOpen(true);\n }\n return;\n }\n\n const currentSelectableOptions = filteredOptions.filter(\n (item) => item.type === \"option\" && !(item.data as O).disabled,\n );\n\n switch (e.key) {\n case \"Escape\":\n e.preventDefault();\n setIsOpen(false);\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n inputRef.current?.blur();\n break;\n\n case \"ArrowDown\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.min(\n prev + 1,\n currentSelectableOptions.length - 1,\n );\n const option = currentSelectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"ArrowUp\":\n e.preventDefault();\n setHighlightedIndex((prev) => {\n const nextIndex = Math.max(prev - 1, 0);\n const option = currentSelectableOptions[nextIndex];\n if (option) {\n const optionIndex = filteredOptions.indexOf(option);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(optionIndex, {\n align: \"auto\",\n });\n }\n }\n return nextIndex;\n });\n break;\n\n case \"Enter\":\n e.preventDefault();\n if (\n highlightedIndex >= 0 &&\n highlightedIndex < currentSelectableOptions.length\n ) {\n const item = currentSelectableOptions[highlightedIndex];\n if (item) {\n const option = item.data as O;\n onSelectRef.current(option);\n }\n }\n break;\n\n case \"Home\":\n e.preventDefault();\n setHighlightedIndex(0);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(0);\n }\n break;\n\n case \"End\":\n e.preventDefault();\n setHighlightedIndex(currentSelectableOptions.length - 1);\n if (shouldVirtualize && virtualizerRef.current) {\n virtualizerRef.current.scrollToIndex(filteredOptions.length - 1);\n }\n break;\n\n default:\n break;\n }\n },\n [isOpen, filteredOptions, highlightedIndex, shouldVirtualize],\n );\n\n // -- Effects ----------------------------------------------------------------\n // Check initial scroll state when dropdown opens\n React.useEffect(() => {\n if (isOpen) {\n const timeoutId = setTimeout(() => {\n const element = scrollContainerRef.current;\n if (element) {\n const { scrollTop, scrollHeight, clientHeight } = element;\n setShowTopArrow(scrollTop > 0);\n setShowBottomArrow(scrollTop + clientHeight < scrollHeight - 1);\n }\n }, 50);\n\n return () => clearTimeout(timeoutId);\n } else {\n setShowTopArrow(false);\n setShowBottomArrow(false);\n return undefined;\n }\n }, [isOpen, filteredOptions, shouldVirtualize]);\n\n // -- Return -----------------------------------------------------------------\n return {\n // State\n isOpen,\n setIsOpen,\n searchQuery,\n setSearchQuery,\n highlightedIndex,\n setHighlightedIndex,\n showTopArrow,\n showBottomArrow,\n\n // Refs\n triggerRef,\n inputRef,\n scrollContainerRef,\n\n // Computed\n filteredOptions,\n selectableOptions,\n shouldVirtualize,\n virtualizer,\n maxDropdownHeight,\n label,\n\n // IDs & validation\n uniqueId,\n labelId,\n listboxId,\n helperId,\n status,\n helperMessage,\n\n // Handlers\n handleInputChange,\n handleInputClick,\n handleScroll,\n handleKeyDown,\n refCallback,\n };\n}\n"]}
@@ -0,0 +1,109 @@
1
+ import { createNotificationColorVariants, componentColors } from './chunk-POXI7JJ4.js';
2
+ import { cn, iconSizes } from './chunk-NGYLRX6F.js';
3
+ import { cva } from 'class-variance-authority';
4
+ import { X } from 'lucide-react';
5
+ import React from 'react';
6
+ import { jsxs, jsx } from 'react/jsx-runtime';
7
+
8
+ var notificationVariants = cva(
9
+ "relative flex gap-3 rounded-md transition-colors",
10
+ {
11
+ variants: {
12
+ variant: {
13
+ default: "",
14
+ solid: "",
15
+ outline: "border-2 border-l-6",
16
+ soft: "border-l-6"
17
+ },
18
+ color: {
19
+ default: "",
20
+ primary: "",
21
+ secondary: "",
22
+ accent: "",
23
+ success: "",
24
+ error: "",
25
+ warning: "",
26
+ info: ""
27
+ },
28
+ size: {
29
+ xs: "p-2 text-xs gap-2",
30
+ sm: "p-3 text-sm gap-2.5",
31
+ md: "p-4 text-base gap-3",
32
+ lg: "p-5 text-lg gap-3.5"
33
+ }
34
+ },
35
+ compoundVariants: createNotificationColorVariants(componentColors, [
36
+ "default",
37
+ "solid",
38
+ "outline",
39
+ "soft"
40
+ ]),
41
+ defaultVariants: {
42
+ variant: "default",
43
+ color: "default",
44
+ size: "md"
45
+ }
46
+ }
47
+ );
48
+ var Notification = React.memo(
49
+ ({
50
+ title,
51
+ description,
52
+ variant = "default",
53
+ color = "default",
54
+ size = "md",
55
+ closable = true,
56
+ onClose,
57
+ action,
58
+ className,
59
+ classNames,
60
+ children
61
+ }) => {
62
+ return /* @__PURE__ */ jsxs(
63
+ "div",
64
+ {
65
+ role: "alert",
66
+ "aria-live": "polite",
67
+ "aria-atomic": "true",
68
+ className: cn(
69
+ "notification_root",
70
+ notificationVariants({ variant, color, size }),
71
+ className,
72
+ classNames?.root
73
+ ),
74
+ children: [
75
+ /* @__PURE__ */ jsxs("div", { className: cn("flex-1 min-w-0", "notification_content", classNames?.content), children: [
76
+ title && /* @__PURE__ */ jsx("div", { className: cn("font-semibold mb-1 text-sm", "notification_title", classNames?.title), children: title }),
77
+ description && /* @__PURE__ */ jsx("div", { className: cn("text-sm opacity-90", "notification_description", classNames?.description), children: description }),
78
+ children && /* @__PURE__ */ jsx("div", { className: "mt-2", children }),
79
+ action && /* @__PURE__ */ jsx(
80
+ "button",
81
+ {
82
+ type: "button",
83
+ onClick: action.onClick,
84
+ className: cn("mt-2 text-sm font-medium underline hover:no-underline", "notification_action", classNames?.action),
85
+ children: action.label
86
+ }
87
+ )
88
+ ] }),
89
+ closable && /* @__PURE__ */ jsx(
90
+ "button",
91
+ {
92
+ type: "button",
93
+ onClick: onClose,
94
+ className: cn("shrink-0 rounded-sm opacity-70 hover:opacity-100 transition-opacity", "notification_closeButton", classNames?.closeButton),
95
+ "aria-label": "Close notification",
96
+ children: /* @__PURE__ */ jsx(X, { className: cn(iconSizes[size], "notification_icon", classNames?.icon), "aria-hidden": "true" })
97
+ }
98
+ )
99
+ ]
100
+ }
101
+ );
102
+ }
103
+ );
104
+ Notification.displayName = "Notification";
105
+ var notification_default = Notification;
106
+
107
+ export { notification_default };
108
+ //# sourceMappingURL=chunk-X3YNHX77.js.map
109
+ //# sourceMappingURL=chunk-X3YNHX77.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/notification/index.tsx"],"names":[],"mappings":"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","file":"chunk-X3YNHX77.js","sourcesContent":["'use client'\n\nimport { cva } from 'class-variance-authority'\nimport { X } from 'lucide-react'\nimport React from 'react'\n\nimport { cn, iconSizes } from '../utils'\nimport { componentColors, createNotificationColorVariants } from '../variants'\nimport type { NotificationProps } from './types'\n\nconst notificationVariants = cva(\n 'relative flex gap-3 rounded-md transition-colors',\n {\n variants: {\n variant: {\n default: '',\n solid: '',\n outline: 'border-2 border-l-6',\n soft: 'border-l-6',\n },\n color: {\n default: '',\n primary: '',\n secondary: '',\n accent: '',\n success: '',\n error: '',\n warning: '',\n info: '',\n },\n size: {\n xs: 'p-2 text-xs gap-2',\n sm: 'p-3 text-sm gap-2.5',\n md: 'p-4 text-base gap-3',\n lg: 'p-5 text-lg gap-3.5',\n },\n },\n compoundVariants: createNotificationColorVariants(componentColors, [\n 'default',\n 'solid',\n 'outline',\n 'soft',\n ]),\n defaultVariants: {\n variant: 'default',\n color: 'default',\n size: 'md',\n },\n },\n)\n\nconst Notification = React.memo<NotificationProps>(\n ({\n title,\n description,\n variant = 'default',\n color = 'default',\n size = 'md',\n closable = true,\n onClose,\n action,\n className,\n classNames,\n children,\n }) => {\n return (\n <div\n role=\"alert\"\n aria-live=\"polite\"\n aria-atomic=\"true\"\n className={cn(\n 'notification_root',\n notificationVariants({ variant, color, size }),\n className,\n classNames?.root,\n )}\n >\n <div className={cn('flex-1 min-w-0', 'notification_content', classNames?.content)}>\n {title && <div className={cn('font-semibold mb-1 text-sm', 'notification_title', classNames?.title)}>{title}</div>}\n {description && (\n <div className={cn('text-sm opacity-90', 'notification_description', classNames?.description)}>{description}</div>\n )}\n {children && <div className=\"mt-2\">{children}</div>}\n {action && (\n <button\n type=\"button\"\n onClick={action.onClick}\n className={cn('mt-2 text-sm font-medium underline hover:no-underline', 'notification_action', classNames?.action)}\n >\n {action.label}\n </button>\n )}\n </div>\n\n {closable && (\n <button\n type=\"button\"\n onClick={onClose}\n className={cn('shrink-0 rounded-sm opacity-70 hover:opacity-100 transition-opacity', 'notification_closeButton', classNames?.closeButton)}\n aria-label=\"Close notification\"\n >\n <X className={cn(iconSizes[size], 'notification_icon', classNames?.icon)} aria-hidden=\"true\" />\n </button>\n )}\n </div>\n )\n },\n)\n\nNotification.displayName = 'Notification'\n\nexport type * from './types'\nexport default Notification\n"]}