@hyddenlabs/hydn-ui 0.3.0-alpha.99 → 0.3.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 (649) hide show
  1. package/README.md +46 -29
  2. package/dist/components/branding/google-logo.d.ts +14 -0
  3. package/dist/components/branding/google-logo.d.ts.map +1 -0
  4. package/dist/components/branding/google-logo.js +49 -0
  5. package/dist/components/branding/google-logo.js.map +1 -0
  6. package/dist/components/branding/hydden-logo.d.ts +14 -0
  7. package/dist/components/branding/hydden-logo.d.ts.map +1 -0
  8. package/dist/components/branding/hydden-logo.js +8 -0
  9. package/dist/components/branding/hydden-logo.js.map +1 -0
  10. package/dist/components/branding/microsoft-logo.d.ts +14 -0
  11. package/dist/components/branding/microsoft-logo.d.ts.map +1 -0
  12. package/dist/components/branding/microsoft-logo.js +25 -0
  13. package/dist/components/branding/microsoft-logo.js.map +1 -0
  14. package/dist/components/data-display/avatar/avatar.d.ts +24 -0
  15. package/dist/components/data-display/avatar/avatar.d.ts.map +1 -0
  16. package/dist/components/data-display/avatar/avatar.js +25 -0
  17. package/dist/components/data-display/avatar/avatar.js.map +1 -0
  18. package/dist/components/data-display/avatar/index.d.ts +3 -0
  19. package/dist/components/data-display/avatar/index.d.ts.map +1 -0
  20. package/dist/components/data-display/badge/badge.d.ts +24 -0
  21. package/dist/components/data-display/badge/badge.d.ts.map +1 -0
  22. package/dist/components/data-display/badge/badge.js +27 -0
  23. package/dist/components/data-display/badge/badge.js.map +1 -0
  24. package/dist/components/data-display/badge/index.d.ts +5 -0
  25. package/dist/components/data-display/badge/index.d.ts.map +1 -0
  26. package/dist/components/data-display/badge/status-label.d.ts +25 -0
  27. package/dist/components/data-display/badge/status-label.d.ts.map +1 -0
  28. package/dist/components/data-display/badge/status-label.js +63 -0
  29. package/dist/components/data-display/badge/status-label.js.map +1 -0
  30. package/dist/components/data-display/chip/chip.d.ts +42 -0
  31. package/dist/components/data-display/chip/chip.d.ts.map +1 -0
  32. package/dist/components/data-display/chip/chip.js +79 -0
  33. package/dist/components/data-display/chip/chip.js.map +1 -0
  34. package/dist/components/data-display/chip/index.d.ts +3 -0
  35. package/dist/components/data-display/chip/index.d.ts.map +1 -0
  36. package/dist/components/data-display/code-block/code-block.d.ts +17 -0
  37. package/dist/components/data-display/code-block/code-block.d.ts.map +1 -0
  38. package/dist/components/data-display/code-block/code-block.js +34 -0
  39. package/dist/components/data-display/code-block/code-block.js.map +1 -0
  40. package/dist/components/data-display/data-table/data-table.d.ts +226 -0
  41. package/dist/components/data-display/data-table/data-table.d.ts.map +1 -0
  42. package/dist/components/data-display/data-table/data-table.js +404 -0
  43. package/dist/components/data-display/data-table/data-table.js.map +1 -0
  44. package/dist/components/data-display/data-table/index.d.ts +5 -0
  45. package/dist/components/data-display/data-table/index.d.ts.map +1 -0
  46. package/dist/components/data-display/data-table/use-table.d.ts +42 -0
  47. package/dist/components/data-display/data-table/use-table.d.ts.map +1 -0
  48. package/dist/components/data-display/data-table/use-table.js +120 -0
  49. package/dist/components/data-display/data-table/use-table.js.map +1 -0
  50. package/dist/components/data-display/empty-state/empty-state.d.ts +8 -0
  51. package/dist/components/data-display/empty-state/empty-state.d.ts.map +1 -0
  52. package/dist/components/data-display/empty-state/empty-state.js +17 -0
  53. package/dist/components/data-display/empty-state/empty-state.js.map +1 -0
  54. package/dist/components/data-display/empty-state/index.d.ts +3 -0
  55. package/dist/components/data-display/empty-state/index.d.ts.map +1 -0
  56. package/dist/components/data-display/list/index.d.ts +3 -0
  57. package/dist/components/data-display/list/index.d.ts.map +1 -0
  58. package/dist/components/data-display/list/list.d.ts +31 -0
  59. package/dist/components/data-display/list/list.d.ts.map +1 -0
  60. package/dist/components/data-display/list/list.js +16 -0
  61. package/dist/components/data-display/list/list.js.map +1 -0
  62. package/dist/components/data-display/table/index.d.ts +3 -0
  63. package/dist/components/data-display/table/index.d.ts.map +1 -0
  64. package/dist/components/data-display/table/table.d.ts +101 -0
  65. package/dist/components/data-display/table/table.d.ts.map +1 -0
  66. package/dist/components/data-display/table/table.js +98 -0
  67. package/dist/components/data-display/table/table.js.map +1 -0
  68. package/dist/components/data-display/timeline/index.d.ts +3 -0
  69. package/dist/components/data-display/timeline/index.d.ts.map +1 -0
  70. package/dist/components/data-display/timeline/timeline.d.ts +57 -0
  71. package/dist/components/data-display/timeline/timeline.d.ts.map +1 -0
  72. package/dist/components/data-display/timeline/timeline.js +52 -0
  73. package/dist/components/data-display/timeline/timeline.js.map +1 -0
  74. package/dist/components/feedback/alert/alert.d.ts +27 -0
  75. package/dist/components/feedback/alert/alert.d.ts.map +1 -0
  76. package/dist/components/feedback/alert/alert.js +86 -0
  77. package/dist/components/feedback/alert/alert.js.map +1 -0
  78. package/dist/components/feedback/alert/index.d.ts +3 -0
  79. package/dist/components/feedback/alert/index.d.ts.map +1 -0
  80. package/dist/components/feedback/dialog/delete-dialog.d.ts +41 -0
  81. package/dist/components/feedback/dialog/delete-dialog.d.ts.map +1 -0
  82. package/dist/components/feedback/dialog/delete-dialog.js +52 -0
  83. package/dist/components/feedback/dialog/delete-dialog.js.map +1 -0
  84. package/dist/components/feedback/dialog/dialog.d.ts +24 -0
  85. package/dist/components/feedback/dialog/dialog.d.ts.map +1 -0
  86. package/dist/components/feedback/dialog/dialog.js +15 -0
  87. package/dist/components/feedback/dialog/dialog.js.map +1 -0
  88. package/dist/components/feedback/dialog/index.d.ts +5 -0
  89. package/dist/components/feedback/dialog/index.d.ts.map +1 -0
  90. package/dist/components/feedback/error-page/error-400.d.ts +22 -0
  91. package/dist/components/feedback/error-page/error-400.d.ts.map +1 -0
  92. package/dist/components/feedback/error-page/error-400.js +28 -0
  93. package/dist/components/feedback/error-page/error-400.js.map +1 -0
  94. package/dist/components/feedback/error-page/error-401.d.ts +26 -0
  95. package/dist/components/feedback/error-page/error-401.d.ts.map +1 -0
  96. package/dist/components/feedback/error-page/error-401.js +33 -0
  97. package/dist/components/feedback/error-page/error-401.js.map +1 -0
  98. package/dist/components/feedback/error-page/error-403.d.ts +26 -0
  99. package/dist/components/feedback/error-page/error-403.d.ts.map +1 -0
  100. package/dist/components/feedback/error-page/error-403.js +33 -0
  101. package/dist/components/feedback/error-page/error-403.js.map +1 -0
  102. package/dist/components/feedback/error-page/error-404.d.ts +26 -0
  103. package/dist/components/feedback/error-page/error-404.d.ts.map +1 -0
  104. package/dist/components/feedback/error-page/error-404.js +33 -0
  105. package/dist/components/feedback/error-page/error-404.js.map +1 -0
  106. package/dist/components/feedback/error-page/index.d.ts +9 -0
  107. package/dist/components/feedback/error-page/index.d.ts.map +1 -0
  108. package/dist/components/feedback/loading-container/index.d.ts +3 -0
  109. package/dist/components/feedback/loading-container/index.d.ts.map +1 -0
  110. package/dist/components/feedback/loading-container/loading-container.d.ts +16 -0
  111. package/dist/components/feedback/loading-container/loading-container.d.ts.map +1 -0
  112. package/dist/components/feedback/loading-container/loading-container.js +28 -0
  113. package/dist/components/feedback/loading-container/loading-container.js.map +1 -0
  114. package/dist/components/feedback/modal/index.d.ts +3 -0
  115. package/dist/components/feedback/modal/index.d.ts.map +1 -0
  116. package/dist/components/feedback/modal/modal.d.ts +33 -0
  117. package/dist/components/feedback/modal/modal.d.ts.map +1 -0
  118. package/dist/components/feedback/modal/modal.js +88 -0
  119. package/dist/components/feedback/modal/modal.js.map +1 -0
  120. package/dist/components/feedback/overlay/useOverlay.d.ts +24 -0
  121. package/dist/components/feedback/overlay/useOverlay.d.ts.map +1 -0
  122. package/dist/components/feedback/overlay/useOverlay.js +119 -0
  123. package/dist/components/feedback/overlay/useOverlay.js.map +1 -0
  124. package/dist/components/feedback/popover/index.d.ts +3 -0
  125. package/dist/components/feedback/popover/index.d.ts.map +1 -0
  126. package/dist/components/feedback/popover/popover.d.ts +25 -0
  127. package/dist/components/feedback/popover/popover.d.ts.map +1 -0
  128. package/dist/components/feedback/popover/popover.js +118 -0
  129. package/dist/components/feedback/popover/popover.js.map +1 -0
  130. package/dist/components/feedback/progress-bar/index.d.ts +3 -0
  131. package/dist/components/feedback/progress-bar/index.d.ts.map +1 -0
  132. package/dist/components/feedback/progress-bar/progress-bar.d.ts +22 -0
  133. package/dist/components/feedback/progress-bar/progress-bar.d.ts.map +1 -0
  134. package/dist/components/feedback/progress-bar/progress-bar.js +27 -0
  135. package/dist/components/feedback/progress-bar/progress-bar.js.map +1 -0
  136. package/dist/components/feedback/skeleton/index.d.ts +3 -0
  137. package/dist/components/feedback/skeleton/index.d.ts.map +1 -0
  138. package/dist/components/feedback/skeleton/skeleton.d.ts +19 -0
  139. package/dist/components/feedback/skeleton/skeleton.d.ts.map +1 -0
  140. package/dist/components/feedback/skeleton/skeleton.js +28 -0
  141. package/dist/components/feedback/skeleton/skeleton.js.map +1 -0
  142. package/dist/components/feedback/smooth-transition/index.d.ts +3 -0
  143. package/dist/components/feedback/smooth-transition/index.d.ts.map +1 -0
  144. package/dist/components/feedback/smooth-transition/smooth-transition.d.ts +68 -0
  145. package/dist/components/feedback/smooth-transition/smooth-transition.d.ts.map +1 -0
  146. package/dist/components/feedback/smooth-transition/smooth-transition.js +89 -0
  147. package/dist/components/feedback/smooth-transition/smooth-transition.js.map +1 -0
  148. package/dist/components/feedback/spinner/index.d.ts +3 -0
  149. package/dist/components/feedback/spinner/index.d.ts.map +1 -0
  150. package/dist/components/feedback/spinner/spinner.d.ts +21 -0
  151. package/dist/components/feedback/spinner/spinner.d.ts.map +1 -0
  152. package/dist/components/feedback/spinner/spinner.js +27 -0
  153. package/dist/components/feedback/spinner/spinner.js.map +1 -0
  154. package/dist/components/feedback/toast/index.d.ts +3 -0
  155. package/dist/components/feedback/toast/index.d.ts.map +1 -0
  156. package/dist/components/feedback/toast/toast.d.ts +23 -0
  157. package/dist/components/feedback/toast/toast.d.ts.map +1 -0
  158. package/dist/components/feedback/toast/toast.js +45 -0
  159. package/dist/components/feedback/toast/toast.js.map +1 -0
  160. package/dist/components/feedback/tooltip/index.d.ts +3 -0
  161. package/dist/components/feedback/tooltip/index.d.ts.map +1 -0
  162. package/dist/components/feedback/tooltip/tooltip.d.ts +39 -0
  163. package/dist/components/feedback/tooltip/tooltip.d.ts.map +1 -0
  164. package/dist/components/feedback/tooltip/tooltip.js +129 -0
  165. package/dist/components/feedback/tooltip/tooltip.js.map +1 -0
  166. package/dist/components/forms/button/button-with-icon.d.ts +18 -0
  167. package/dist/components/forms/button/button-with-icon.d.ts.map +1 -0
  168. package/dist/components/forms/button/button-with-icon.js +15 -0
  169. package/dist/components/forms/button/button-with-icon.js.map +1 -0
  170. package/dist/components/forms/button/button.d.ts +66 -0
  171. package/dist/components/forms/button/button.d.ts.map +1 -0
  172. package/dist/components/forms/button/button.examples.d.ts +73 -0
  173. package/dist/components/forms/button/button.examples.d.ts.map +1 -0
  174. package/dist/components/forms/button/button.js +118 -0
  175. package/dist/components/forms/button/button.js.map +1 -0
  176. package/dist/components/forms/button/icon-button.d.ts +23 -0
  177. package/dist/components/forms/button/icon-button.d.ts.map +1 -0
  178. package/dist/components/forms/button/icon-button.js +85 -0
  179. package/dist/components/forms/button/icon-button.js.map +1 -0
  180. package/dist/components/forms/button/index.d.ts +10 -0
  181. package/dist/components/forms/button/index.d.ts.map +1 -0
  182. package/dist/components/forms/button/inline-button.d.ts +45 -0
  183. package/dist/components/forms/button/inline-button.d.ts.map +1 -0
  184. package/dist/components/forms/button/inline-button.js +59 -0
  185. package/dist/components/forms/button/inline-button.js.map +1 -0
  186. package/dist/components/forms/button-group/button-group.d.ts +20 -0
  187. package/dist/components/forms/button-group/button-group.d.ts.map +1 -0
  188. package/dist/components/forms/button-group/button-group.js +24 -0
  189. package/dist/components/forms/button-group/button-group.js.map +1 -0
  190. package/dist/components/forms/button-group/index.d.ts +3 -0
  191. package/dist/components/forms/button-group/index.d.ts.map +1 -0
  192. package/dist/components/forms/calendar/calendar.d.ts +37 -0
  193. package/dist/components/forms/calendar/calendar.d.ts.map +1 -0
  194. package/dist/components/forms/calendar/calendar.js +131 -0
  195. package/dist/components/forms/calendar/calendar.js.map +1 -0
  196. package/dist/components/forms/calendar/index.d.ts +3 -0
  197. package/dist/components/forms/calendar/index.d.ts.map +1 -0
  198. package/dist/components/forms/checkbox/checkbox.d.ts +31 -0
  199. package/dist/components/forms/checkbox/checkbox.d.ts.map +1 -0
  200. package/dist/components/forms/checkbox/checkbox.js +39 -0
  201. package/dist/components/forms/checkbox/checkbox.js.map +1 -0
  202. package/dist/components/forms/checkbox/index.d.ts +3 -0
  203. package/dist/components/forms/checkbox/index.d.ts.map +1 -0
  204. package/dist/components/forms/code/code.d.ts +32 -0
  205. package/dist/components/forms/code/code.d.ts.map +1 -0
  206. package/dist/components/forms/code/code.js +31 -0
  207. package/dist/components/forms/code/code.js.map +1 -0
  208. package/dist/components/forms/code/index.d.ts +1 -0
  209. package/dist/components/forms/code/index.d.ts.map +1 -0
  210. package/dist/components/forms/date-picker/date-picker.d.ts +72 -0
  211. package/dist/components/forms/date-picker/date-picker.d.ts.map +1 -0
  212. package/dist/components/forms/date-picker/date-picker.js +173 -0
  213. package/dist/components/forms/date-picker/date-picker.js.map +1 -0
  214. package/dist/components/forms/date-picker/index.d.ts +3 -0
  215. package/dist/components/forms/date-picker/index.d.ts.map +1 -0
  216. package/dist/components/forms/editable-text/editable-text.d.ts +59 -0
  217. package/dist/components/forms/editable-text/editable-text.d.ts.map +1 -0
  218. package/dist/components/forms/editable-text/editable-text.js +188 -0
  219. package/dist/components/forms/editable-text/editable-text.js.map +1 -0
  220. package/dist/components/forms/editable-text/index.d.ts +3 -0
  221. package/dist/components/forms/editable-text/index.d.ts.map +1 -0
  222. package/dist/components/forms/fieldset/fieldset.d.ts +46 -0
  223. package/dist/components/forms/fieldset/fieldset.d.ts.map +1 -0
  224. package/dist/components/forms/fieldset/fieldset.js +40 -0
  225. package/dist/components/forms/fieldset/fieldset.js.map +1 -0
  226. package/dist/components/forms/fieldset/index.d.ts +3 -0
  227. package/dist/components/forms/fieldset/index.d.ts.map +1 -0
  228. package/dist/components/forms/form/form-example.d.ts +11 -0
  229. package/dist/components/forms/form/form-example.d.ts.map +1 -0
  230. package/dist/components/forms/form/form.d.ts +44 -0
  231. package/dist/components/forms/form/form.d.ts.map +1 -0
  232. package/dist/components/forms/form/form.js +39 -0
  233. package/dist/components/forms/form/form.js.map +1 -0
  234. package/dist/components/forms/form/index.d.ts +3 -0
  235. package/dist/components/forms/form/index.d.ts.map +1 -0
  236. package/dist/components/forms/form-checkbox/form-checkbox.d.ts +27 -0
  237. package/dist/components/forms/form-checkbox/form-checkbox.d.ts.map +1 -0
  238. package/dist/components/forms/form-checkbox/form-checkbox.js +58 -0
  239. package/dist/components/forms/form-checkbox/form-checkbox.js.map +1 -0
  240. package/dist/components/forms/form-checkbox/index.d.ts +3 -0
  241. package/dist/components/forms/form-checkbox/index.d.ts.map +1 -0
  242. package/dist/components/forms/form-checkbox-group/form-checkbox-group.d.ts +40 -0
  243. package/dist/components/forms/form-checkbox-group/form-checkbox-group.d.ts.map +1 -0
  244. package/dist/components/forms/form-checkbox-group/form-checkbox-group.js +74 -0
  245. package/dist/components/forms/form-checkbox-group/form-checkbox-group.js.map +1 -0
  246. package/dist/components/forms/form-field/form-field.d.ts +53 -0
  247. package/dist/components/forms/form-field/form-field.d.ts.map +1 -0
  248. package/dist/components/forms/form-field/form-field.js +56 -0
  249. package/dist/components/forms/form-field/form-field.js.map +1 -0
  250. package/dist/components/forms/form-field/index.d.ts +3 -0
  251. package/dist/components/forms/form-field/index.d.ts.map +1 -0
  252. package/dist/components/forms/form-input/form-input.d.ts +60 -0
  253. package/dist/components/forms/form-input/form-input.d.ts.map +1 -0
  254. package/dist/components/forms/form-input/form-input.js +53 -0
  255. package/dist/components/forms/form-input/form-input.js.map +1 -0
  256. package/dist/components/forms/form-select/form-select.d.ts +32 -0
  257. package/dist/components/forms/form-select/form-select.d.ts.map +1 -0
  258. package/dist/components/forms/form-select/form-select.js +34 -0
  259. package/dist/components/forms/form-select/form-select.js.map +1 -0
  260. package/dist/components/forms/form-textarea/form-textarea.d.ts +31 -0
  261. package/dist/components/forms/form-textarea/form-textarea.d.ts.map +1 -0
  262. package/dist/components/forms/form-textarea/form-textarea.js +34 -0
  263. package/dist/components/forms/form-textarea/form-textarea.js.map +1 -0
  264. package/dist/components/forms/input/index.d.ts +3 -0
  265. package/dist/components/forms/input/index.d.ts.map +1 -0
  266. package/dist/components/forms/input/input.d.ts +71 -0
  267. package/dist/components/forms/input/input.d.ts.map +1 -0
  268. package/dist/components/forms/input/input.js +64 -0
  269. package/dist/components/forms/input/input.js.map +1 -0
  270. package/dist/components/forms/input-group/index.d.ts +3 -0
  271. package/dist/components/forms/input-group/index.d.ts.map +1 -0
  272. package/dist/components/forms/input-group/input-group.d.ts +43 -0
  273. package/dist/components/forms/input-group/input-group.d.ts.map +1 -0
  274. package/dist/components/forms/input-group/input-group.js +55 -0
  275. package/dist/components/forms/input-group/input-group.js.map +1 -0
  276. package/dist/components/forms/multi-select/index.d.ts +3 -0
  277. package/dist/components/forms/multi-select/index.d.ts.map +1 -0
  278. package/dist/components/forms/multi-select/multi-select.d.ts +75 -0
  279. package/dist/components/forms/multi-select/multi-select.d.ts.map +1 -0
  280. package/dist/components/forms/multi-select/multi-select.js +259 -0
  281. package/dist/components/forms/multi-select/multi-select.js.map +1 -0
  282. package/dist/components/forms/radio/index.d.ts +3 -0
  283. package/dist/components/forms/radio/index.d.ts.map +1 -0
  284. package/dist/components/forms/radio/radio.d.ts +31 -0
  285. package/dist/components/forms/radio/radio.d.ts.map +1 -0
  286. package/dist/components/forms/radio/radio.js +74 -0
  287. package/dist/components/forms/radio/radio.js.map +1 -0
  288. package/dist/components/forms/radio-group/index.d.ts +3 -0
  289. package/dist/components/forms/radio-group/index.d.ts.map +1 -0
  290. package/dist/components/forms/radio-group/radio-group.d.ts +32 -0
  291. package/dist/components/forms/radio-group/radio-group.d.ts.map +1 -0
  292. package/dist/components/forms/radio-group/radio-group.js +28 -0
  293. package/dist/components/forms/radio-group/radio-group.js.map +1 -0
  294. package/dist/components/forms/select/index.d.ts +5 -0
  295. package/dist/components/forms/select/index.d.ts.map +1 -0
  296. package/dist/components/forms/select/select-item.d.ts +16 -0
  297. package/dist/components/forms/select/select-item.d.ts.map +1 -0
  298. package/dist/components/forms/select/select-item.js +9 -0
  299. package/dist/components/forms/select/select-item.js.map +1 -0
  300. package/dist/components/forms/select/select.d.ts +52 -0
  301. package/dist/components/forms/select/select.d.ts.map +1 -0
  302. package/dist/components/forms/select/select.js +51 -0
  303. package/dist/components/forms/select/select.js.map +1 -0
  304. package/dist/components/forms/slider/index.d.ts +3 -0
  305. package/dist/components/forms/slider/index.d.ts.map +1 -0
  306. package/dist/components/forms/slider/slider.d.ts +21 -0
  307. package/dist/components/forms/slider/slider.d.ts.map +1 -0
  308. package/dist/components/forms/slider/slider.js +65 -0
  309. package/dist/components/forms/slider/slider.js.map +1 -0
  310. package/dist/components/forms/switch/index.d.ts +3 -0
  311. package/dist/components/forms/switch/index.d.ts.map +1 -0
  312. package/dist/components/forms/switch/switch.d.ts +30 -0
  313. package/dist/components/forms/switch/switch.d.ts.map +1 -0
  314. package/dist/components/forms/switch/switch.js +104 -0
  315. package/dist/components/forms/switch/switch.js.map +1 -0
  316. package/dist/components/forms/textarea/index.d.ts +3 -0
  317. package/dist/components/forms/textarea/index.d.ts.map +1 -0
  318. package/dist/components/forms/textarea/textarea.d.ts +54 -0
  319. package/dist/components/forms/textarea/textarea.d.ts.map +1 -0
  320. package/dist/components/forms/textarea/textarea.js +55 -0
  321. package/dist/components/forms/textarea/textarea.js.map +1 -0
  322. package/dist/components/index.d.ts +124 -0
  323. package/dist/components/index.d.ts.map +1 -0
  324. package/dist/components/layout/accordion/accordion.d.ts +30 -0
  325. package/dist/components/layout/accordion/accordion.d.ts.map +1 -0
  326. package/dist/components/layout/accordion/accordion.js +38 -0
  327. package/dist/components/layout/accordion/accordion.js.map +1 -0
  328. package/dist/components/layout/accordion/index.d.ts +3 -0
  329. package/dist/components/layout/accordion/index.d.ts.map +1 -0
  330. package/dist/components/layout/action-card/action-card.d.ts +37 -0
  331. package/dist/components/layout/action-card/action-card.d.ts.map +1 -0
  332. package/dist/components/layout/action-card/action-card.js +104 -0
  333. package/dist/components/layout/action-card/action-card.js.map +1 -0
  334. package/dist/components/layout/action-card/index.d.ts +3 -0
  335. package/dist/components/layout/action-card/index.d.ts.map +1 -0
  336. package/dist/components/layout/card/card-actions.d.ts +47 -0
  337. package/dist/components/layout/card/card-actions.d.ts.map +1 -0
  338. package/dist/components/layout/card/card-actions.js +30 -0
  339. package/dist/components/layout/card/card-actions.js.map +1 -0
  340. package/dist/components/layout/card/card-body.d.ts +26 -0
  341. package/dist/components/layout/card/card-body.d.ts.map +1 -0
  342. package/dist/components/layout/card/card-body.js +22 -0
  343. package/dist/components/layout/card/card-body.js.map +1 -0
  344. package/dist/components/layout/card/card-figure.d.ts +50 -0
  345. package/dist/components/layout/card/card-figure.d.ts.map +1 -0
  346. package/dist/components/layout/card/card-figure.js +27 -0
  347. package/dist/components/layout/card/card-figure.js.map +1 -0
  348. package/dist/components/layout/card/card-footer.d.ts +46 -0
  349. package/dist/components/layout/card/card-footer.d.ts.map +1 -0
  350. package/dist/components/layout/card/card-footer.js +39 -0
  351. package/dist/components/layout/card/card-footer.js.map +1 -0
  352. package/dist/components/layout/card/card-header.d.ts +41 -0
  353. package/dist/components/layout/card/card-header.d.ts.map +1 -0
  354. package/dist/components/layout/card/card-header.js +27 -0
  355. package/dist/components/layout/card/card-header.js.map +1 -0
  356. package/dist/components/layout/card/card-title.d.ts +43 -0
  357. package/dist/components/layout/card/card-title.d.ts.map +1 -0
  358. package/dist/components/layout/card/card-title.js +21 -0
  359. package/dist/components/layout/card/card-title.js.map +1 -0
  360. package/dist/components/layout/card/card.d.ts +74 -0
  361. package/dist/components/layout/card/card.d.ts.map +1 -0
  362. package/dist/components/layout/card/card.js +64 -0
  363. package/dist/components/layout/card/card.js.map +1 -0
  364. package/dist/components/layout/card/index.d.ts +15 -0
  365. package/dist/components/layout/card/index.d.ts.map +1 -0
  366. package/dist/components/layout/container/container.d.ts +33 -0
  367. package/dist/components/layout/container/container.d.ts.map +1 -0
  368. package/dist/components/layout/container/container.js +36 -0
  369. package/dist/components/layout/container/container.js.map +1 -0
  370. package/dist/components/layout/container/index.d.ts +3 -0
  371. package/dist/components/layout/container/index.d.ts.map +1 -0
  372. package/dist/components/layout/divider/divider.d.ts +15 -0
  373. package/dist/components/layout/divider/divider.d.ts.map +1 -0
  374. package/dist/components/layout/divider/divider.js +10 -0
  375. package/dist/components/layout/divider/divider.js.map +1 -0
  376. package/dist/components/layout/divider/index.d.ts +3 -0
  377. package/dist/components/layout/divider/index.d.ts.map +1 -0
  378. package/dist/components/layout/drawer/drawer.d.ts +35 -0
  379. package/dist/components/layout/drawer/drawer.d.ts.map +1 -0
  380. package/dist/components/layout/drawer/drawer.js +108 -0
  381. package/dist/components/layout/drawer/drawer.js.map +1 -0
  382. package/dist/components/layout/drawer/index.d.ts +3 -0
  383. package/dist/components/layout/drawer/index.d.ts.map +1 -0
  384. package/dist/components/layout/feature-section/feature-section.d.ts +36 -0
  385. package/dist/components/layout/feature-section/feature-section.d.ts.map +1 -0
  386. package/dist/components/layout/feature-section/feature-section.js +37 -0
  387. package/dist/components/layout/feature-section/feature-section.js.map +1 -0
  388. package/dist/components/layout/feature-section/index.d.ts +3 -0
  389. package/dist/components/layout/feature-section/index.d.ts.map +1 -0
  390. package/dist/components/layout/footer/footer.d.ts +37 -0
  391. package/dist/components/layout/footer/footer.d.ts.map +1 -0
  392. package/dist/components/layout/footer/footer.js +36 -0
  393. package/dist/components/layout/footer/footer.js.map +1 -0
  394. package/dist/components/layout/footer/index.d.ts +3 -0
  395. package/dist/components/layout/footer/index.d.ts.map +1 -0
  396. package/dist/components/layout/grid/grid.d.ts +66 -0
  397. package/dist/components/layout/grid/grid.d.ts.map +1 -0
  398. package/dist/components/layout/grid/grid.js +62 -0
  399. package/dist/components/layout/grid/grid.js.map +1 -0
  400. package/dist/components/layout/grid/index.d.ts +3 -0
  401. package/dist/components/layout/grid/index.d.ts.map +1 -0
  402. package/dist/components/layout/hero/hero.d.ts +61 -0
  403. package/dist/components/layout/hero/hero.d.ts.map +1 -0
  404. package/dist/components/layout/hero/hero.js +79 -0
  405. package/dist/components/layout/hero/hero.js.map +1 -0
  406. package/dist/components/layout/hero/index.d.ts +3 -0
  407. package/dist/components/layout/hero/index.d.ts.map +1 -0
  408. package/dist/components/layout/left-nav-layout/index.d.ts +7 -0
  409. package/dist/components/layout/left-nav-layout/index.d.ts.map +1 -0
  410. package/dist/components/layout/left-nav-layout/left-nav-item.d.ts +56 -0
  411. package/dist/components/layout/left-nav-layout/left-nav-item.d.ts.map +1 -0
  412. package/dist/components/layout/left-nav-layout/left-nav-item.js +105 -0
  413. package/dist/components/layout/left-nav-layout/left-nav-item.js.map +1 -0
  414. package/dist/components/layout/left-nav-layout/left-nav-layout.d.ts +67 -0
  415. package/dist/components/layout/left-nav-layout/left-nav-layout.d.ts.map +1 -0
  416. package/dist/components/layout/left-nav-layout/left-nav-layout.js +182 -0
  417. package/dist/components/layout/left-nav-layout/left-nav-layout.js.map +1 -0
  418. package/dist/components/layout/left-nav-layout/left-nav-section.d.ts +40 -0
  419. package/dist/components/layout/left-nav-layout/left-nav-section.d.ts.map +1 -0
  420. package/dist/components/layout/left-nav-layout/left-nav-section.js +119 -0
  421. package/dist/components/layout/left-nav-layout/left-nav-section.js.map +1 -0
  422. package/dist/components/layout/page/index.d.ts +3 -0
  423. package/dist/components/layout/page/index.d.ts.map +1 -0
  424. package/dist/components/layout/page/page.d.ts +17 -0
  425. package/dist/components/layout/page/page.d.ts.map +1 -0
  426. package/dist/components/layout/page/page.js +9 -0
  427. package/dist/components/layout/page/page.js.map +1 -0
  428. package/dist/components/layout/page-header/index.d.ts +3 -0
  429. package/dist/components/layout/page-header/index.d.ts.map +1 -0
  430. package/dist/components/layout/page-header/page-header.d.ts +21 -0
  431. package/dist/components/layout/page-header/page-header.d.ts.map +1 -0
  432. package/dist/components/layout/page-header/page-header.js +18 -0
  433. package/dist/components/layout/page-header/page-header.js.map +1 -0
  434. package/dist/components/layout/page-transition/index.d.ts +3 -0
  435. package/dist/components/layout/page-transition/index.d.ts.map +1 -0
  436. package/dist/components/layout/page-transition/page-transition.d.ts +52 -0
  437. package/dist/components/layout/page-transition/page-transition.d.ts.map +1 -0
  438. package/dist/components/layout/page-transition/page-transition.js +43 -0
  439. package/dist/components/layout/page-transition/page-transition.js.map +1 -0
  440. package/dist/components/layout/section/index.d.ts +3 -0
  441. package/dist/components/layout/section/index.d.ts.map +1 -0
  442. package/dist/components/layout/section/section.d.ts +35 -0
  443. package/dist/components/layout/section/section.d.ts.map +1 -0
  444. package/dist/components/layout/section/section.js +18 -0
  445. package/dist/components/layout/section/section.js.map +1 -0
  446. package/dist/components/layout/section-header/index.d.ts +3 -0
  447. package/dist/components/layout/section-header/index.d.ts.map +1 -0
  448. package/dist/components/layout/section-header/section-header.d.ts +23 -0
  449. package/dist/components/layout/section-header/section-header.d.ts.map +1 -0
  450. package/dist/components/layout/section-header/section-header.js +18 -0
  451. package/dist/components/layout/section-header/section-header.js.map +1 -0
  452. package/dist/components/layout/settings-page/index.d.ts +4 -0
  453. package/dist/components/layout/settings-page/index.d.ts.map +1 -0
  454. package/dist/components/layout/settings-page/setting-item.d.ts +52 -0
  455. package/dist/components/layout/settings-page/setting-item.d.ts.map +1 -0
  456. package/dist/components/layout/settings-page/setting-item.js +31 -0
  457. package/dist/components/layout/settings-page/setting-item.js.map +1 -0
  458. package/dist/components/layout/settings-page/settings-page.d.ts +37 -0
  459. package/dist/components/layout/settings-page/settings-page.d.ts.map +1 -0
  460. package/dist/components/layout/settings-page/settings-page.js +18 -0
  461. package/dist/components/layout/settings-page/settings-page.js.map +1 -0
  462. package/dist/components/layout/settings-page/settings-section.d.ts +35 -0
  463. package/dist/components/layout/settings-page/settings-section.d.ts.map +1 -0
  464. package/dist/components/layout/settings-page/settings-section.js +17 -0
  465. package/dist/components/layout/settings-page/settings-section.js.map +1 -0
  466. package/dist/components/layout/stack/index.d.ts +3 -0
  467. package/dist/components/layout/stack/index.d.ts.map +1 -0
  468. package/dist/components/layout/stack/stack.d.ts +33 -0
  469. package/dist/components/layout/stack/stack.d.ts.map +1 -0
  470. package/dist/components/layout/stack/stack.js +44 -0
  471. package/dist/components/layout/stack/stack.js.map +1 -0
  472. package/dist/components/navigation/breadcrumbs/breadcrumbs.d.ts +61 -0
  473. package/dist/components/navigation/breadcrumbs/breadcrumbs.d.ts.map +1 -0
  474. package/dist/components/navigation/breadcrumbs/breadcrumbs.js +30 -0
  475. package/dist/components/navigation/breadcrumbs/breadcrumbs.js.map +1 -0
  476. package/dist/components/navigation/breadcrumbs/index.d.ts +3 -0
  477. package/dist/components/navigation/breadcrumbs/index.d.ts.map +1 -0
  478. package/dist/components/navigation/dropdown/dropdown.d.ts +83 -0
  479. package/dist/components/navigation/dropdown/dropdown.d.ts.map +1 -0
  480. package/dist/components/navigation/dropdown/dropdown.js +295 -0
  481. package/dist/components/navigation/dropdown/dropdown.js.map +1 -0
  482. package/dist/components/navigation/dropdown/index.d.ts +5 -0
  483. package/dist/components/navigation/dropdown/index.d.ts.map +1 -0
  484. package/dist/components/navigation/nav/index.d.ts +3 -0
  485. package/dist/components/navigation/nav/index.d.ts.map +1 -0
  486. package/dist/components/navigation/nav/nav.d.ts +24 -0
  487. package/dist/components/navigation/nav/nav.d.ts.map +1 -0
  488. package/dist/components/navigation/nav/nav.js +32 -0
  489. package/dist/components/navigation/nav/nav.js.map +1 -0
  490. package/dist/components/navigation/nav-dropdown/index.d.ts +5 -0
  491. package/dist/components/navigation/nav-dropdown/index.d.ts.map +1 -0
  492. package/dist/components/navigation/nav-dropdown/nav-dropdown-item.d.ts +17 -0
  493. package/dist/components/navigation/nav-dropdown/nav-dropdown-item.d.ts.map +1 -0
  494. package/dist/components/navigation/nav-dropdown/nav-dropdown-item.js +17 -0
  495. package/dist/components/navigation/nav-dropdown/nav-dropdown-item.js.map +1 -0
  496. package/dist/components/navigation/nav-dropdown/nav-dropdown.d.ts +20 -0
  497. package/dist/components/navigation/nav-dropdown/nav-dropdown.d.ts.map +1 -0
  498. package/dist/components/navigation/nav-dropdown/nav-dropdown.js +24 -0
  499. package/dist/components/navigation/nav-dropdown/nav-dropdown.js.map +1 -0
  500. package/dist/components/navigation/navbar/index.d.ts +9 -0
  501. package/dist/components/navigation/navbar/index.d.ts.map +1 -0
  502. package/dist/components/navigation/navbar/navbar-brand.d.ts +23 -0
  503. package/dist/components/navigation/navbar/navbar-brand.d.ts.map +1 -0
  504. package/dist/components/navigation/navbar/navbar-brand.js +21 -0
  505. package/dist/components/navigation/navbar/navbar-brand.js.map +1 -0
  506. package/dist/components/navigation/navbar/navbar-link.d.ts +23 -0
  507. package/dist/components/navigation/navbar/navbar-link.d.ts.map +1 -0
  508. package/dist/components/navigation/navbar/navbar-link.js +34 -0
  509. package/dist/components/navigation/navbar/navbar-link.js.map +1 -0
  510. package/dist/components/navigation/navbar/navbar-toggle.d.ts +34 -0
  511. package/dist/components/navigation/navbar/navbar-toggle.d.ts.map +1 -0
  512. package/dist/components/navigation/navbar/navbar-toggle.js +37 -0
  513. package/dist/components/navigation/navbar/navbar-toggle.js.map +1 -0
  514. package/dist/components/navigation/navbar/navbar.d.ts +33 -0
  515. package/dist/components/navigation/navbar/navbar.d.ts.map +1 -0
  516. package/dist/components/navigation/navbar/navbar.js +40 -0
  517. package/dist/components/navigation/navbar/navbar.js.map +1 -0
  518. package/dist/components/navigation/notification-dropdown/index.d.ts +3 -0
  519. package/dist/components/navigation/notification-dropdown/index.d.ts.map +1 -0
  520. package/dist/components/navigation/notification-dropdown/notification-dropdown.d.ts +59 -0
  521. package/dist/components/navigation/notification-dropdown/notification-dropdown.d.ts.map +1 -0
  522. package/dist/components/navigation/notification-dropdown/notification-dropdown.js +456 -0
  523. package/dist/components/navigation/notification-dropdown/notification-dropdown.js.map +1 -0
  524. package/dist/components/navigation/pagination/index.d.ts +3 -0
  525. package/dist/components/navigation/pagination/index.d.ts.map +1 -0
  526. package/dist/components/navigation/pagination/pagination.d.ts +21 -0
  527. package/dist/components/navigation/pagination/pagination.d.ts.map +1 -0
  528. package/dist/components/navigation/pagination/pagination.js +72 -0
  529. package/dist/components/navigation/pagination/pagination.js.map +1 -0
  530. package/dist/components/navigation/scroll-nav/index.d.ts +3 -0
  531. package/dist/components/navigation/scroll-nav/index.d.ts.map +1 -0
  532. package/dist/components/navigation/scroll-nav/scroll-nav.d.ts +53 -0
  533. package/dist/components/navigation/scroll-nav/scroll-nav.d.ts.map +1 -0
  534. package/dist/components/navigation/scroll-nav/scroll-nav.js +188 -0
  535. package/dist/components/navigation/scroll-nav/scroll-nav.js.map +1 -0
  536. package/dist/components/navigation/sidebar/index.d.ts +3 -0
  537. package/dist/components/navigation/sidebar/index.d.ts.map +1 -0
  538. package/dist/components/navigation/sidebar/sidebar.d.ts +18 -0
  539. package/dist/components/navigation/sidebar/sidebar.d.ts.map +1 -0
  540. package/dist/components/navigation/sidebar/sidebar.js +41 -0
  541. package/dist/components/navigation/sidebar/sidebar.js.map +1 -0
  542. package/dist/components/navigation/stepper/index.d.ts +3 -0
  543. package/dist/components/navigation/stepper/index.d.ts.map +1 -0
  544. package/dist/components/navigation/stepper/stepper.d.ts +50 -0
  545. package/dist/components/navigation/stepper/stepper.d.ts.map +1 -0
  546. package/dist/components/navigation/stepper/stepper.js +159 -0
  547. package/dist/components/navigation/stepper/stepper.js.map +1 -0
  548. package/dist/components/navigation/tabs/index.d.ts +3 -0
  549. package/dist/components/navigation/tabs/index.d.ts.map +1 -0
  550. package/dist/components/navigation/tabs/tabs.d.ts +32 -0
  551. package/dist/components/navigation/tabs/tabs.d.ts.map +1 -0
  552. package/dist/components/navigation/tabs/tabs.js +61 -0
  553. package/dist/components/navigation/tabs/tabs.js.map +1 -0
  554. package/dist/components/system/auth-provider/auth-provider.d.ts +103 -0
  555. package/dist/components/system/auth-provider/auth-provider.d.ts.map +1 -0
  556. package/dist/components/system/auth-provider/auth-provider.js +118 -0
  557. package/dist/components/system/auth-provider/auth-provider.js.map +1 -0
  558. package/dist/components/system/auth-provider/auth-utils.d.ts +32 -0
  559. package/dist/components/system/auth-provider/auth-utils.d.ts.map +1 -0
  560. package/dist/components/system/auth-provider/auth-utils.js +83 -0
  561. package/dist/components/system/auth-provider/auth-utils.js.map +1 -0
  562. package/dist/components/system/auth-provider/index.d.ts +4 -0
  563. package/dist/components/system/auth-provider/index.d.ts.map +1 -0
  564. package/dist/components/system/color-mode-toggle/color-mode-toggle.d.ts +18 -0
  565. package/dist/components/system/color-mode-toggle/color-mode-toggle.d.ts.map +1 -0
  566. package/dist/components/system/color-mode-toggle/color-mode-toggle.js +27 -0
  567. package/dist/components/system/color-mode-toggle/color-mode-toggle.js.map +1 -0
  568. package/dist/components/system/color-mode-toggle/index.d.ts +3 -0
  569. package/dist/components/system/color-mode-toggle/index.d.ts.map +1 -0
  570. package/dist/components/system/error-boundary/error-boundary.d.ts +21 -0
  571. package/dist/components/system/error-boundary/error-boundary.d.ts.map +1 -0
  572. package/dist/components/system/icon/icon.d.ts +35 -0
  573. package/dist/components/system/icon/icon.d.ts.map +1 -0
  574. package/dist/components/system/icon/icon.js +83 -0
  575. package/dist/components/system/icon/icon.js.map +1 -0
  576. package/dist/components/system/icon/index.d.ts +3 -0
  577. package/dist/components/system/icon/index.d.ts.map +1 -0
  578. package/dist/components/system/theme-provider/index.d.ts +3 -0
  579. package/dist/components/system/theme-provider/index.d.ts.map +1 -0
  580. package/dist/components/system/theme-provider/theme-provider.d.ts +40 -0
  581. package/dist/components/system/theme-provider/theme-provider.d.ts.map +1 -0
  582. package/dist/components/system/theme-provider/theme-provider.js +55 -0
  583. package/dist/components/system/theme-provider/theme-provider.js.map +1 -0
  584. package/dist/components/typography/code/code.d.ts +24 -0
  585. package/dist/components/typography/code/code.d.ts.map +1 -0
  586. package/dist/components/typography/code/code.js +18 -0
  587. package/dist/components/typography/code/code.js.map +1 -0
  588. package/dist/components/typography/code/index.d.ts +3 -0
  589. package/dist/components/typography/code/index.d.ts.map +1 -0
  590. package/dist/components/typography/heading/heading.d.ts +32 -0
  591. package/dist/components/typography/heading/heading.d.ts.map +1 -0
  592. package/dist/components/typography/heading/heading.js +39 -0
  593. package/dist/components/typography/heading/heading.js.map +1 -0
  594. package/dist/components/typography/heading/index.d.ts +3 -0
  595. package/dist/components/typography/heading/index.d.ts.map +1 -0
  596. package/dist/components/typography/link/index.d.ts +3 -0
  597. package/dist/components/typography/link/index.d.ts.map +1 -0
  598. package/dist/components/typography/link/link.d.ts +44 -0
  599. package/dist/components/typography/link/link.d.ts.map +1 -0
  600. package/dist/components/typography/link/link.js +72 -0
  601. package/dist/components/typography/link/link.js.map +1 -0
  602. package/dist/components/typography/text/index.d.ts +3 -0
  603. package/dist/components/typography/text/index.d.ts.map +1 -0
  604. package/dist/components/typography/text/text.d.ts +104 -0
  605. package/dist/components/typography/text/text.d.ts.map +1 -0
  606. package/dist/components/typography/text/text.js +148 -0
  607. package/dist/components/typography/text/text.js.map +1 -0
  608. package/dist/components.d.ts +2 -0
  609. package/dist/components.d.ts.map +1 -0
  610. package/dist/hooks/useDebounce.d.ts +29 -0
  611. package/dist/hooks/useDebounce.d.ts.map +1 -0
  612. package/dist/hooks/useDebounce.js +26 -0
  613. package/dist/hooks/useDebounce.js.map +1 -0
  614. package/dist/hooks/useScrollReset.d.ts +11 -0
  615. package/dist/hooks/useScrollReset.d.ts.map +1 -0
  616. package/dist/hooks/useScrollReset.js +55 -0
  617. package/dist/hooks/useScrollReset.js.map +1 -0
  618. package/dist/humans.txt +8 -0
  619. package/dist/icons/logo.svg +9 -0
  620. package/dist/index.d.ts +7 -1170
  621. package/dist/index.d.ts.map +1 -0
  622. package/dist/index.js +287 -4333
  623. package/dist/index.js.map +1 -1
  624. package/dist/manifest.json +16 -0
  625. package/dist/node_modules/clsx/dist/clsx.js +18 -0
  626. package/dist/node_modules/clsx/dist/clsx.js.map +1 -0
  627. package/dist/robots.txt +5 -0
  628. package/dist/sitemap.xml +8 -0
  629. package/dist/staticwebapp.config.json +23 -0
  630. package/dist/style.css +2 -2
  631. package/dist/styles.d.ts +9 -0
  632. package/dist/theme/hydn-presets.d.ts +4 -0
  633. package/dist/theme/hydn-presets.d.ts.map +1 -0
  634. package/dist/theme/size-tokens.d.ts +686 -0
  635. package/dist/theme/size-tokens.d.ts.map +1 -0
  636. package/dist/theme/size-tokens.js +636 -0
  637. package/dist/theme/size-tokens.js.map +1 -0
  638. package/dist/theme/tokens.d.ts +116 -0
  639. package/dist/theme/tokens.d.ts.map +1 -0
  640. package/dist/theme/tokens.js +164 -0
  641. package/dist/theme/tokens.js.map +1 -0
  642. package/dist/utils/debounce.d.ts +7 -0
  643. package/dist/utils/debounce.d.ts.map +1 -0
  644. package/dist/utils/debounce.js +40 -0
  645. package/dist/utils/debounce.js.map +1 -0
  646. package/package.json +49 -43
  647. package/dist/index.cjs +0 -4425
  648. package/dist/index.cjs.map +0 -1
  649. package/dist/index.d.cts +0 -1170
@@ -0,0 +1,27 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import Text from "../../typography/text/text.js";
3
+ function ProgressBar({ value, max = 100, showLabel, variant = "neutral", className = "" }) {
4
+ const percentage = Math.min(value / max * 100, 100);
5
+ return /* @__PURE__ */ jsxs("div", { className: `flex items-center gap-3 ${className}`, children: [
6
+ /* @__PURE__ */ jsx("div", { className: "flex-1 bg-muted/30 rounded-full h-2.5 overflow-hidden shadow-inner", children: /* @__PURE__ */ jsx(
7
+ "div",
8
+ {
9
+ role: "progressbar",
10
+ "aria-valuenow": value,
11
+ "aria-valuemin": 0,
12
+ "aria-valuemax": max,
13
+ className: `h-full transition-all duration-500 ease-out rounded-full bg-${variant}`,
14
+ style: { width: `${percentage}%` }
15
+ }
16
+ ) }),
17
+ showLabel && /* @__PURE__ */ jsxs(Text, { variant: "muted", weight: "medium", size: "sm", children: [
18
+ Math.round(percentage),
19
+ "%"
20
+ ] })
21
+ ] });
22
+ }
23
+ ProgressBar.displayName = "ProgressBar";
24
+ export {
25
+ ProgressBar as default
26
+ };
27
+ //# sourceMappingURL=progress-bar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-bar.js","sources":["../../../../src/components/feedback/progress-bar/progress-bar.tsx"],"sourcesContent":["import Text from '../../typography/text/text';\nimport { ColorVariant } from '../../../theme/tokens';\n\nexport type ProgressBarProps = {\n /** Current progress value */\n value: number;\n /** Maximum value for the progress bar (defaults to 100) */\n max?: number;\n /** Whether to display the percentage label next to the progress bar */\n showLabel?: boolean;\n /** Visual style variant indicating the progress state */\n variant?: ColorVariant;\n /** Additional CSS classes to apply to the progress bar container */\n className?: string;\n};\n\n/**\n * ProgressBar - Visual representation of completion\n */\nfunction ProgressBar({ value, max = 100, showLabel, variant = 'neutral', className = '' }: Readonly<ProgressBarProps>) {\n const percentage = Math.min((value / max) * 100, 100);\n\n return (\n <div className={`flex items-center gap-3 ${className}`}>\n <div className=\"flex-1 bg-muted/30 rounded-full h-2.5 overflow-hidden shadow-inner\">\n <div\n role=\"progressbar\"\n aria-valuenow={value}\n aria-valuemin={0}\n aria-valuemax={max}\n className={`h-full transition-all duration-500 ease-out rounded-full bg-${variant}`}\n style={{ width: `${percentage}%` }}\n />\n </div>\n {showLabel && (\n <Text variant=\"muted\" weight=\"medium\" size=\"sm\">\n {Math.round(percentage)}%\n </Text>\n )}\n </div>\n );\n}\n\nProgressBar.displayName = 'ProgressBar';\n\nexport default ProgressBar;\n"],"names":[],"mappings":";;AAmBA,SAAS,YAAY,EAAE,OAAO,MAAM,KAAK,WAAW,UAAU,WAAW,YAAY,MAAkC;AACrH,QAAM,aAAa,KAAK,IAAK,QAAQ,MAAO,KAAK,GAAG;AAEpD,SACE,qBAAC,OAAA,EAAI,WAAW,2BAA2B,SAAS,IAClD,UAAA;AAAA,IAAA,oBAAC,OAAA,EAAI,WAAU,sEACb,UAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,iBAAe;AAAA,QACf,iBAAe;AAAA,QACf,iBAAe;AAAA,QACf,WAAW,+DAA+D,OAAO;AAAA,QACjF,OAAO,EAAE,OAAO,GAAG,UAAU,IAAA;AAAA,MAAI;AAAA,IAAA,GAErC;AAAA,IACC,kCACE,MAAA,EAAK,SAAQ,SAAQ,QAAO,UAAS,MAAK,MACxC,UAAA;AAAA,MAAA,KAAK,MAAM,UAAU;AAAA,MAAE;AAAA,IAAA,EAAA,CAC1B;AAAA,EAAA,GAEJ;AAEJ;AAEA,YAAY,cAAc;"}
@@ -0,0 +1,3 @@
1
+ export { default } from './skeleton';
2
+ export type { SkeletonProps } from './skeleton';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/skeleton/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1,19 @@
1
+ export type SkeletonProps = {
2
+ /** Shape variant of the skeleton placeholder */
3
+ variant?: 'text' | 'circular' | 'rectangular';
4
+ /** Width of the skeleton (CSS value, defaults to 100% for text/rectangular, 40px for circular) */
5
+ width?: string;
6
+ /** Height of the skeleton (CSS value, defaults based on variant) */
7
+ height?: string;
8
+ /** Additional CSS classes to apply to the skeleton container */
9
+ className?: string;
10
+ } & React.HTMLAttributes<HTMLDivElement>;
11
+ /**
12
+ * Skeleton - Placeholder for loading state
13
+ */
14
+ declare function Skeleton({ variant, width, height, className, ...props }: Readonly<SkeletonProps>): import("react/jsx-runtime").JSX.Element;
15
+ declare namespace Skeleton {
16
+ var displayName: string;
17
+ }
18
+ export default Skeleton;
19
+ //# sourceMappingURL=skeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/skeleton/skeleton.tsx"],"names":[],"mappings":"AAAA,MAAM,MAAM,aAAa,GAAG;IAC1B,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,aAAa,CAAC;IAC9C,kGAAkG;IAClG,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oEAAoE;IACpE,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,gEAAgE;IAChE,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAEzC;;GAEG;AACH,iBAAS,QAAQ,CAAC,EAAE,OAAgB,EAAE,KAAK,EAAE,MAAM,EAAE,SAAc,EAAE,GAAG,KAAK,EAAE,EAAE,QAAQ,CAAC,aAAa,CAAC,2CAuBvG;kBAvBQ,QAAQ;;;AA2BjB,eAAe,QAAQ,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ function Skeleton({ variant = "text", width, height, className = "", ...props }) {
3
+ const variantClasses = {
4
+ text: "rounded h-4",
5
+ circular: "rounded-full",
6
+ rectangular: "rounded-md"
7
+ };
8
+ const style = {
9
+ width: width || (variant === "circular" ? "40px" : "100%"),
10
+ height: height || (variant === "circular" ? "40px" : void 0)
11
+ };
12
+ return /* @__PURE__ */ jsx(
13
+ "div",
14
+ {
15
+ className: `bg-muted animate-pulse ${variantClasses[variant]} ${className}`,
16
+ style,
17
+ "aria-busy": "true",
18
+ "aria-live": "polite",
19
+ ...props,
20
+ children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Loading..." })
21
+ }
22
+ );
23
+ }
24
+ Skeleton.displayName = "Skeleton";
25
+ export {
26
+ Skeleton as default
27
+ };
28
+ //# sourceMappingURL=skeleton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skeleton.js","sources":["../../../../src/components/feedback/skeleton/skeleton.tsx"],"sourcesContent":["export type SkeletonProps = {\n /** Shape variant of the skeleton placeholder */\n variant?: 'text' | 'circular' | 'rectangular';\n /** Width of the skeleton (CSS value, defaults to 100% for text/rectangular, 40px for circular) */\n width?: string;\n /** Height of the skeleton (CSS value, defaults based on variant) */\n height?: string;\n /** Additional CSS classes to apply to the skeleton container */\n className?: string;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * Skeleton - Placeholder for loading state\n */\nfunction Skeleton({ variant = 'text', width, height, className = '', ...props }: Readonly<SkeletonProps>) {\n const variantClasses = {\n text: 'rounded h-4',\n circular: 'rounded-full',\n rectangular: 'rounded-md'\n };\n\n const style = {\n width: width || (variant === 'circular' ? '40px' : '100%'),\n height: height || (variant === 'circular' ? '40px' : undefined)\n };\n\n return (\n <div\n className={`bg-muted animate-pulse ${variantClasses[variant]} ${className}`}\n style={style}\n aria-busy=\"true\"\n aria-live=\"polite\"\n {...props}\n >\n <span className=\"sr-only\">Loading...</span>\n </div>\n );\n}\n\nSkeleton.displayName = 'Skeleton';\n\nexport default Skeleton;\n"],"names":[],"mappings":";AAcA,SAAS,SAAS,EAAE,UAAU,QAAQ,OAAO,QAAQ,YAAY,IAAI,GAAG,SAAkC;AACxG,QAAM,iBAAiB;AAAA,IACrB,MAAM;AAAA,IACN,UAAU;AAAA,IACV,aAAa;AAAA,EAAA;AAGf,QAAM,QAAQ;AAAA,IACZ,OAAO,UAAU,YAAY,aAAa,SAAS;AAAA,IACnD,QAAQ,WAAW,YAAY,aAAa,SAAS;AAAA,EAAA;AAGvD,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,0BAA0B,eAAe,OAAO,CAAC,IAAI,SAAS;AAAA,MACzE;AAAA,MACA,aAAU;AAAA,MACV,aAAU;AAAA,MACT,GAAG;AAAA,MAEJ,UAAA,oBAAC,QAAA,EAAK,WAAU,WAAU,UAAA,aAAA,CAAU;AAAA,IAAA;AAAA,EAAA;AAG1C;AAEA,SAAS,cAAc;"}
@@ -0,0 +1,3 @@
1
+ export { default, useStaggeredTransition } from './smooth-transition';
2
+ export type { SmoothTransitionProps, TransitionType, TransitionDuration } from './smooth-transition';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/smooth-transition/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AACtE,YAAY,EAAE,qBAAqB,EAAE,cAAc,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC"}
@@ -0,0 +1,68 @@
1
+ import { ReactNode, CSSProperties } from 'react';
2
+ export type TransitionType = 'fade' | 'slide-up' | 'slide-down' | 'slide-left' | 'slide-right' | 'scale' | 'scale-fade' | 'slide-fade-up' | 'slide-fade-down' | 'zoom';
3
+ export type TransitionDuration = 'fast' | 'normal' | 'slow' | number;
4
+ export type SmoothTransitionProps = {
5
+ /** Content to animate */
6
+ children: ReactNode;
7
+ /** Whether to show the content (controls animation state) */
8
+ show?: boolean;
9
+ /** Type of animation to apply */
10
+ type?: TransitionType;
11
+ /** Duration of the animation ('fast', 'normal', 'slow', or custom milliseconds) */
12
+ duration?: TransitionDuration;
13
+ /** Delay before animation starts (in ms) */
14
+ delay?: number;
15
+ /** Additional CSS classes */
16
+ className?: string;
17
+ /** Additional inline styles */
18
+ style?: CSSProperties;
19
+ /** Apply hover effect (scale and shadow on hover) */
20
+ hover?: boolean;
21
+ /** Apply active effect (scale down on click) */
22
+ active?: boolean;
23
+ };
24
+ /**
25
+ * SmoothTransition - A reusable component for smooth animations and transitions
26
+ *
27
+ * @example
28
+ * // Fade in/out
29
+ * <SmoothTransition show={isOpen} type="fade">
30
+ * <div>Content</div>
31
+ * </SmoothTransition>
32
+ *
33
+ * @example
34
+ * // Slide up with hover effect
35
+ * <SmoothTransition show={true} type="slide-fade-up" hover>
36
+ * <button>Click me</button>
37
+ * </SmoothTransition>
38
+ *
39
+ * @example
40
+ * // Custom duration
41
+ * <SmoothTransition show={isVisible} type="scale-fade" duration={500}>
42
+ * <div>Animated content</div>
43
+ * </SmoothTransition>
44
+ *
45
+ * @example
46
+ * // Delayed animation
47
+ * <SmoothTransition show={true} type="fade" delay={200}>
48
+ * <div>Appears after 200ms</div>
49
+ * </SmoothTransition>
50
+ */
51
+ declare function SmoothTransition({ children, show, type, duration, delay, className, style, hover, active }: Readonly<SmoothTransitionProps>): import("react/jsx-runtime").JSX.Element;
52
+ declare namespace SmoothTransition {
53
+ var displayName: string;
54
+ }
55
+ export default SmoothTransition;
56
+ /**
57
+ * Hook for creating staggered animations
58
+ *
59
+ * @example
60
+ * const delays = useStaggeredTransition(5, 100);
61
+ * items.map((item, i) => (
62
+ * <SmoothTransition key={i} delay={delays[i]}>
63
+ * {item}
64
+ * </SmoothTransition>
65
+ * ))
66
+ */
67
+ export declare function useStaggeredTransition(count: number, baseDelay?: number): number[];
68
+ //# sourceMappingURL=smooth-transition.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"smooth-transition.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/smooth-transition/smooth-transition.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAEjD,MAAM,MAAM,cAAc,GACtB,MAAM,GACN,UAAU,GACV,YAAY,GACZ,YAAY,GACZ,aAAa,GACb,OAAO,GACP,YAAY,GACZ,eAAe,GACf,iBAAiB,GACjB,MAAM,CAAC;AAEX,MAAM,MAAM,kBAAkB,GAAG,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;AAErE,MAAM,MAAM,qBAAqB,GAAG;IAClC,yBAAyB;IACzB,QAAQ,EAAE,SAAS,CAAC;IACpB,6DAA6D;IAC7D,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,iCAAiC;IACjC,IAAI,CAAC,EAAE,cAAc,CAAC;IACtB,mFAAmF;IACnF,QAAQ,CAAC,EAAE,kBAAkB,CAAC;IAC9B,4CAA4C;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,6BAA6B;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,+BAA+B;IAC/B,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,qDAAqD;IACrD,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,gDAAgD;IAChD,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAkEF;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,iBAAS,gBAAgB,CAAC,EACxB,QAAQ,EACR,IAAW,EACX,IAAa,EACb,QAAmB,EACnB,KAAS,EACT,SAAc,EACd,KAAU,EACV,KAAa,EACb,MAAc,EACf,EAAE,QAAQ,CAAC,qBAAqB,CAAC,2CAejC;kBAzBQ,gBAAgB;;;AA6BzB,eAAe,gBAAgB,CAAC;AAEhC;;;;;;;;;;GAUG;AACH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,GAAE,MAAW,GAAG,MAAM,EAAE,CAEtF"}
@@ -0,0 +1,89 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ const getDurationClass = (duration) => {
3
+ if (typeof duration === "number") {
4
+ return "";
5
+ }
6
+ switch (duration) {
7
+ case "fast":
8
+ return "duration-150";
9
+ case "slow":
10
+ return "duration-500";
11
+ case "normal":
12
+ default:
13
+ return "duration-300";
14
+ }
15
+ };
16
+ const getTransitionClasses = (type, show, hover, active) => {
17
+ const baseClasses = "transition-all";
18
+ let typeClasses = "";
19
+ if (!show) {
20
+ switch (type) {
21
+ case "fade":
22
+ typeClasses = "opacity-0";
23
+ break;
24
+ case "slide-up":
25
+ typeClasses = "translate-y-4 opacity-0";
26
+ break;
27
+ case "slide-down":
28
+ typeClasses = "-translate-y-4 opacity-0";
29
+ break;
30
+ case "slide-left":
31
+ typeClasses = "translate-x-4 opacity-0";
32
+ break;
33
+ case "slide-right":
34
+ typeClasses = "-translate-x-4 opacity-0";
35
+ break;
36
+ case "scale":
37
+ typeClasses = "scale-95 opacity-0";
38
+ break;
39
+ case "scale-fade":
40
+ typeClasses = "scale-90 opacity-0";
41
+ break;
42
+ case "slide-fade-up":
43
+ typeClasses = "translate-y-2 opacity-0";
44
+ break;
45
+ case "slide-fade-down":
46
+ typeClasses = "-translate-y-2 opacity-0";
47
+ break;
48
+ case "zoom":
49
+ typeClasses = "scale-0 opacity-0";
50
+ break;
51
+ default:
52
+ typeClasses = "opacity-0";
53
+ }
54
+ } else {
55
+ typeClasses = "translate-y-0 translate-x-0 scale-100 opacity-100";
56
+ }
57
+ const hoverClasses = hover ? "hover:scale-105 hover:shadow-lg" : "";
58
+ const activeClasses = active ? "active:scale-95" : "";
59
+ return `${baseClasses} ${typeClasses} ${hoverClasses} ${activeClasses}`.trim();
60
+ };
61
+ function SmoothTransition({
62
+ children,
63
+ show = true,
64
+ type = "fade",
65
+ duration = "normal",
66
+ delay = 0,
67
+ className = "",
68
+ style = {},
69
+ hover = false,
70
+ active = false
71
+ }) {
72
+ const durationClass = getDurationClass(duration);
73
+ const transitionClasses = getTransitionClasses(type, show, hover, active);
74
+ const customStyle = {
75
+ ...style,
76
+ transitionDuration: typeof duration === "number" ? `${duration}ms` : void 0,
77
+ transitionDelay: delay > 0 ? `${delay}ms` : void 0
78
+ };
79
+ return /* @__PURE__ */ jsx("div", { className: `${transitionClasses} ${durationClass} ${className}`, style: customStyle, children });
80
+ }
81
+ SmoothTransition.displayName = "SmoothTransition";
82
+ function useStaggeredTransition(count, baseDelay = 50) {
83
+ return Array.from({ length: count }, (_, i) => i * baseDelay);
84
+ }
85
+ export {
86
+ SmoothTransition as default,
87
+ useStaggeredTransition
88
+ };
89
+ //# sourceMappingURL=smooth-transition.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"smooth-transition.js","sources":["../../../../src/components/feedback/smooth-transition/smooth-transition.tsx"],"sourcesContent":["import { ReactNode, CSSProperties } from 'react';\n\nexport type TransitionType =\n | 'fade'\n | 'slide-up'\n | 'slide-down'\n | 'slide-left'\n | 'slide-right'\n | 'scale'\n | 'scale-fade'\n | 'slide-fade-up'\n | 'slide-fade-down'\n | 'zoom';\n\nexport type TransitionDuration = 'fast' | 'normal' | 'slow' | number;\n\nexport type SmoothTransitionProps = {\n /** Content to animate */\n children: ReactNode;\n /** Whether to show the content (controls animation state) */\n show?: boolean;\n /** Type of animation to apply */\n type?: TransitionType;\n /** Duration of the animation ('fast', 'normal', 'slow', or custom milliseconds) */\n duration?: TransitionDuration;\n /** Delay before animation starts (in ms) */\n delay?: number;\n /** Additional CSS classes */\n className?: string;\n /** Additional inline styles */\n style?: CSSProperties;\n /** Apply hover effect (scale and shadow on hover) */\n hover?: boolean;\n /** Apply active effect (scale down on click) */\n active?: boolean;\n};\n\nconst getDurationClass = (duration: TransitionDuration): string => {\n if (typeof duration === 'number') {\n return '';\n }\n switch (duration) {\n case 'fast':\n return 'duration-150';\n case 'slow':\n return 'duration-500';\n case 'normal':\n default:\n return 'duration-300';\n }\n};\n\nconst getTransitionClasses = (type: TransitionType, show: boolean, hover: boolean, active: boolean): string => {\n const baseClasses = 'transition-all';\n let typeClasses = '';\n\n if (!show) {\n switch (type) {\n case 'fade':\n typeClasses = 'opacity-0';\n break;\n case 'slide-up':\n typeClasses = 'translate-y-4 opacity-0';\n break;\n case 'slide-down':\n typeClasses = '-translate-y-4 opacity-0';\n break;\n case 'slide-left':\n typeClasses = 'translate-x-4 opacity-0';\n break;\n case 'slide-right':\n typeClasses = '-translate-x-4 opacity-0';\n break;\n case 'scale':\n typeClasses = 'scale-95 opacity-0';\n break;\n case 'scale-fade':\n typeClasses = 'scale-90 opacity-0';\n break;\n case 'slide-fade-up':\n typeClasses = 'translate-y-2 opacity-0';\n break;\n case 'slide-fade-down':\n typeClasses = '-translate-y-2 opacity-0';\n break;\n case 'zoom':\n typeClasses = 'scale-0 opacity-0';\n break;\n default:\n typeClasses = 'opacity-0';\n }\n } else {\n typeClasses = 'translate-y-0 translate-x-0 scale-100 opacity-100';\n }\n\n const hoverClasses = hover ? 'hover:scale-105 hover:shadow-lg' : '';\n const activeClasses = active ? 'active:scale-95' : '';\n\n return `${baseClasses} ${typeClasses} ${hoverClasses} ${activeClasses}`.trim();\n};\n\n/**\n * SmoothTransition - A reusable component for smooth animations and transitions\n *\n * @example\n * // Fade in/out\n * <SmoothTransition show={isOpen} type=\"fade\">\n * <div>Content</div>\n * </SmoothTransition>\n *\n * @example\n * // Slide up with hover effect\n * <SmoothTransition show={true} type=\"slide-fade-up\" hover>\n * <button>Click me</button>\n * </SmoothTransition>\n *\n * @example\n * // Custom duration\n * <SmoothTransition show={isVisible} type=\"scale-fade\" duration={500}>\n * <div>Animated content</div>\n * </SmoothTransition>\n *\n * @example\n * // Delayed animation\n * <SmoothTransition show={true} type=\"fade\" delay={200}>\n * <div>Appears after 200ms</div>\n * </SmoothTransition>\n */\nfunction SmoothTransition({\n children,\n show = true,\n type = 'fade',\n duration = 'normal',\n delay = 0,\n className = '',\n style = {},\n hover = false,\n active = false\n}: Readonly<SmoothTransitionProps>) {\n const durationClass = getDurationClass(duration);\n const transitionClasses = getTransitionClasses(type, show, hover, active);\n\n const customStyle: CSSProperties = {\n ...style,\n transitionDuration: typeof duration === 'number' ? `${duration}ms` : undefined,\n transitionDelay: delay > 0 ? `${delay}ms` : undefined\n };\n\n return (\n <div className={`${transitionClasses} ${durationClass} ${className}`} style={customStyle}>\n {children}\n </div>\n );\n}\n\nSmoothTransition.displayName = 'SmoothTransition';\n\nexport default SmoothTransition;\n\n/**\n * Hook for creating staggered animations\n *\n * @example\n * const delays = useStaggeredTransition(5, 100);\n * items.map((item, i) => (\n * <SmoothTransition key={i} delay={delays[i]}>\n * {item}\n * </SmoothTransition>\n * ))\n */\nexport function useStaggeredTransition(count: number, baseDelay: number = 50): number[] {\n return Array.from({ length: count }, (_, i) => i * baseDelay);\n}\n"],"names":[],"mappings":";AAqCA,MAAM,mBAAmB,CAAC,aAAyC;AACjE,MAAI,OAAO,aAAa,UAAU;AAChC,WAAO;AAAA,EACT;AACA,UAAQ,UAAA;AAAA,IACN,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AACH,aAAO;AAAA,IACT,KAAK;AAAA,IACL;AACE,aAAO;AAAA,EAAA;AAEb;AAEA,MAAM,uBAAuB,CAAC,MAAsB,MAAe,OAAgB,WAA4B;AAC7G,QAAM,cAAc;AACpB,MAAI,cAAc;AAElB,MAAI,CAAC,MAAM;AACT,YAAQ,MAAA;AAAA,MACN,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF,KAAK;AACH,sBAAc;AACd;AAAA,MACF;AACE,sBAAc;AAAA,IAAA;AAAA,EAEpB,OAAO;AACL,kBAAc;AAAA,EAChB;AAEA,QAAM,eAAe,QAAQ,oCAAoC;AACjE,QAAM,gBAAgB,SAAS,oBAAoB;AAEnD,SAAO,GAAG,WAAW,IAAI,WAAW,IAAI,YAAY,IAAI,aAAa,GAAG,KAAA;AAC1E;AA6BA,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA,OAAO;AAAA,EACP,OAAO;AAAA,EACP,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ,QAAQ,CAAA;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AACX,GAAoC;AAClC,QAAM,gBAAgB,iBAAiB,QAAQ;AAC/C,QAAM,oBAAoB,qBAAqB,MAAM,MAAM,OAAO,MAAM;AAExE,QAAM,cAA6B;AAAA,IACjC,GAAG;AAAA,IACH,oBAAoB,OAAO,aAAa,WAAW,GAAG,QAAQ,OAAO;AAAA,IACrE,iBAAiB,QAAQ,IAAI,GAAG,KAAK,OAAO;AAAA,EAAA;AAG9C,SACE,oBAAC,OAAA,EAAI,WAAW,GAAG,iBAAiB,IAAI,aAAa,IAAI,SAAS,IAAI,OAAO,aAC1E,SAAA,CACH;AAEJ;AAEA,iBAAiB,cAAc;AAexB,SAAS,uBAAuB,OAAe,YAAoB,IAAc;AACtF,SAAO,MAAM,KAAK,EAAE,QAAQ,SAAS,CAAC,GAAG,MAAM,IAAI,SAAS;AAC9D;"}
@@ -0,0 +1,3 @@
1
+ export { default } from './spinner';
2
+ export type { SpinnerProps } from './spinner';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/spinner/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { Size } from '../../../theme/size-tokens';
2
+ export type SpinnerProps = {
3
+ /** Size variant - uses unified size system */
4
+ size?: Size;
5
+ /** Color variant */
6
+ variant?: 'primary' | 'accent' | 'neutral';
7
+ /** Additional CSS classes to apply to the spinner container */
8
+ className?: string;
9
+ /** Override animation duration (e.g. '0.6s') */
10
+ speed?: string;
11
+ } & React.HTMLAttributes<HTMLDivElement>;
12
+ /**
13
+ * Spinner - Loading indicator
14
+ * Uses unified size system from theme/size-tokens
15
+ */
16
+ declare function Spinner({ size, variant, className, speed, ...props }: Readonly<SpinnerProps>): import("react/jsx-runtime").JSX.Element;
17
+ declare namespace Spinner {
18
+ var displayName: string;
19
+ }
20
+ export default Spinner;
21
+ //# sourceMappingURL=spinner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/spinner/spinner.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAgB,MAAM,4BAA4B,CAAC;AAEhE,MAAM,MAAM,YAAY,GAAG;IACzB,8CAA8C;IAC9C,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,oBAAoB;IACpB,OAAO,CAAC,EAAE,SAAS,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC3C,+DAA+D;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GAAG,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;AAEzC;;;GAGG;AACH,iBAAS,OAAO,CAAC,EAAE,IAAW,EAAE,OAAmB,EAAE,SAAc,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,QAAQ,CAAC,YAAY,CAAC,2CAsB7G;kBAtBQ,OAAO;;;AA0BhB,eAAe,OAAO,CAAC"}
@@ -0,0 +1,27 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ import { spinnerSizes } from "../../../theme/size-tokens.js";
3
+ function Spinner({ size = "xl", variant = "primary", className = "", speed, ...props }) {
4
+ const sizeConfig = spinnerSizes[size];
5
+ const variantTopBorder = {
6
+ primary: "border-t-primary",
7
+ accent: "border-t-accent",
8
+ neutral: "border-t-neutral"
9
+ }[variant];
10
+ const duration = speed ? `[animation-duration:${speed}]` : "";
11
+ return /* @__PURE__ */ jsx(
12
+ "div",
13
+ {
14
+ role: "status",
15
+ "aria-label": "Loading",
16
+ "data-variant": variant,
17
+ className: `inline-block border-muted ${variantTopBorder} rounded-full animate-spin box-border ${duration} ${sizeConfig.classes} ${sizeConfig.border} ${className}`,
18
+ ...props,
19
+ children: /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Loading..." })
20
+ }
21
+ );
22
+ }
23
+ Spinner.displayName = "Spinner";
24
+ export {
25
+ Spinner as default
26
+ };
27
+ //# sourceMappingURL=spinner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.js","sources":["../../../../src/components/feedback/spinner/spinner.tsx"],"sourcesContent":["import { Size, spinnerSizes } from '../../../theme/size-tokens';\n\nexport type SpinnerProps = {\n /** Size variant - uses unified size system */\n size?: Size;\n /** Color variant */\n variant?: 'primary' | 'accent' | 'neutral';\n /** Additional CSS classes to apply to the spinner container */\n className?: string;\n /** Override animation duration (e.g. '0.6s') */\n speed?: string;\n} & React.HTMLAttributes<HTMLDivElement>;\n\n/**\n * Spinner - Loading indicator\n * Uses unified size system from theme/size-tokens\n */\nfunction Spinner({ size = 'xl', variant = 'primary', className = '', speed, ...props }: Readonly<SpinnerProps>) {\n const sizeConfig = spinnerSizes[size];\n\n const variantTopBorder = {\n primary: 'border-t-primary',\n accent: 'border-t-accent',\n neutral: 'border-t-neutral'\n }[variant];\n\n const duration = speed ? `[animation-duration:${speed}]` : '';\n\n return (\n <div\n role=\"status\"\n aria-label=\"Loading\"\n data-variant={variant}\n className={`inline-block border-muted ${variantTopBorder} rounded-full animate-spin box-border ${duration} ${sizeConfig.classes} ${sizeConfig.border} ${className}`}\n {...props}\n >\n <span className=\"sr-only\">Loading...</span>\n </div>\n );\n}\n\nSpinner.displayName = 'Spinner';\n\nexport default Spinner;\n"],"names":[],"mappings":";;AAiBA,SAAS,QAAQ,EAAE,OAAO,MAAM,UAAU,WAAW,YAAY,IAAI,OAAO,GAAG,SAAiC;AAC9G,QAAM,aAAa,aAAa,IAAI;AAEpC,QAAM,mBAAmB;AAAA,IACvB,SAAS;AAAA,IACT,QAAQ;AAAA,IACR,SAAS;AAAA,EAAA,EACT,OAAO;AAET,QAAM,WAAW,QAAQ,uBAAuB,KAAK,MAAM;AAE3D,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,cAAW;AAAA,MACX,gBAAc;AAAA,MACd,WAAW,6BAA6B,gBAAgB,yCAAyC,QAAQ,IAAI,WAAW,OAAO,IAAI,WAAW,MAAM,IAAI,SAAS;AAAA,MAChK,GAAG;AAAA,MAEJ,UAAA,oBAAC,QAAA,EAAK,WAAU,WAAU,UAAA,aAAA,CAAU;AAAA,IAAA;AAAA,EAAA;AAG1C;AAEA,QAAQ,cAAc;"}
@@ -0,0 +1,3 @@
1
+ export { default } from './toast';
2
+ export type { ToastProps } from './toast';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/toast/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,23 @@
1
+ export type ToastProps = {
2
+ /** Text message to display in the toast (alternative to children) */
3
+ message?: string;
4
+ /** React content to display in the toast (takes precedence over message) */
5
+ children?: React.ReactNode;
6
+ /** Visual style variant indicating the type of notification (info, success, warning, or error) */
7
+ type?: 'info' | 'success' | 'warning' | 'error';
8
+ /** Callback function invoked when the toast is closed (either manually or via auto-dismiss) */
9
+ onClose?: () => void;
10
+ /** Additional CSS classes to apply to the toast container */
11
+ className?: string;
12
+ /** Auto-dismiss duration in milliseconds (0 to disable) */
13
+ duration?: number;
14
+ };
15
+ /**
16
+ * Toast - Notification popup with slide-in/out animations and auto-dismiss
17
+ */
18
+ declare function Toast({ message, children, type, onClose, className, duration }: Readonly<ToastProps>): import("react/jsx-runtime").JSX.Element;
19
+ declare namespace Toast {
20
+ var displayName: string;
21
+ }
22
+ export default Toast;
23
+ //# sourceMappingURL=toast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toast.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/toast/toast.tsx"],"names":[],"mappings":"AAGA,MAAM,MAAM,UAAU,GAAG;IACvB,qEAAqE;IACrE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,4EAA4E;IAC5E,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,kGAAkG;IAClG,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,CAAC;IAChD,+FAA+F;IAC/F,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,6DAA6D;IAC7D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2DAA2D;IAC3D,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF;;GAEG;AACH,iBAAS,KAAK,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,IAAa,EAAE,OAAO,EAAE,SAAc,EAAE,QAAe,EAAE,EAAE,QAAQ,CAAC,UAAU,CAAC,2CA8ClH;kBA9CQ,KAAK;;;AAkDd,eAAe,KAAK,CAAC"}
@@ -0,0 +1,45 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { useState, useCallback, useEffect } from "react";
3
+ import { createPortal } from "react-dom";
4
+ function Toast({ message, children, type = "info", onClose, className = "", duration = 5e3 }) {
5
+ const [isClosing, setIsClosing] = useState(false);
6
+ const typeClasses = {
7
+ info: "bg-info text-info-foreground",
8
+ success: "bg-success text-success-foreground",
9
+ warning: "bg-warning text-warning-foreground",
10
+ error: "bg-error text-error-foreground"
11
+ };
12
+ const handleClose = useCallback(() => {
13
+ setIsClosing(true);
14
+ setTimeout(() => {
15
+ onClose?.();
16
+ }, 300);
17
+ }, [onClose]);
18
+ useEffect(() => {
19
+ if (duration > 0) {
20
+ const timer = setTimeout(() => {
21
+ handleClose();
22
+ }, duration);
23
+ return () => clearTimeout(timer);
24
+ }
25
+ return void 0;
26
+ }, [duration, handleClose]);
27
+ const toast = /* @__PURE__ */ jsxs(
28
+ "div",
29
+ {
30
+ role: "alert",
31
+ "aria-live": "polite",
32
+ className: `fixed bottom-4 right-4 left-4 sm:left-auto sm:max-w-md px-4 py-3 rounded-md shadow-lg z-[9999] ${typeClasses[type]} transition-all duration-300 ease-out ${isClosing ? "opacity-0 translate-x-full" : "opacity-100 translate-x-0 animate-slideInRight"} ${className}`,
33
+ children: [
34
+ /* @__PURE__ */ jsx("span", { children: children || message }),
35
+ onClose && /* @__PURE__ */ jsx("button", { onClick: handleClose, className: "ml-4 font-bold hover:opacity-70 transition-opacity", "aria-label": "Close", children: "×" })
36
+ ]
37
+ }
38
+ );
39
+ return typeof document !== "undefined" ? createPortal(toast, document.body) : toast;
40
+ }
41
+ Toast.displayName = "Toast";
42
+ export {
43
+ Toast as default
44
+ };
45
+ //# sourceMappingURL=toast.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toast.js","sources":["../../../../src/components/feedback/toast/toast.tsx"],"sourcesContent":["import { useEffect, useState, useCallback } from 'react';\nimport { createPortal } from 'react-dom';\n\nexport type ToastProps = {\n /** Text message to display in the toast (alternative to children) */\n message?: string;\n /** React content to display in the toast (takes precedence over message) */\n children?: React.ReactNode;\n /** Visual style variant indicating the type of notification (info, success, warning, or error) */\n type?: 'info' | 'success' | 'warning' | 'error';\n /** Callback function invoked when the toast is closed (either manually or via auto-dismiss) */\n onClose?: () => void;\n /** Additional CSS classes to apply to the toast container */\n className?: string;\n /** Auto-dismiss duration in milliseconds (0 to disable) */\n duration?: number;\n};\n\n/**\n * Toast - Notification popup with slide-in/out animations and auto-dismiss\n */\nfunction Toast({ message, children, type = 'info', onClose, className = '', duration = 5000 }: Readonly<ToastProps>) {\n const [isClosing, setIsClosing] = useState(false);\n\n const typeClasses = {\n info: 'bg-info text-info-foreground',\n success: 'bg-success text-success-foreground',\n warning: 'bg-warning text-warning-foreground',\n error: 'bg-error text-error-foreground'\n };\n\n const handleClose = useCallback(() => {\n setIsClosing(true);\n // Wait for animation to complete before calling onClose\n setTimeout(() => {\n onClose?.();\n }, 300); // Match animation duration\n }, [onClose]);\n\n useEffect(() => {\n if (duration > 0) {\n const timer = setTimeout(() => {\n handleClose();\n }, duration);\n return () => clearTimeout(timer);\n }\n return undefined;\n }, [duration, handleClose]);\n\n const toast = (\n <div\n role=\"alert\"\n aria-live=\"polite\"\n className={`fixed bottom-4 right-4 left-4 sm:left-auto sm:max-w-md px-4 py-3 rounded-md shadow-lg z-[9999] ${typeClasses[type]} transition-all duration-300 ease-out ${\n isClosing ? 'opacity-0 translate-x-full' : 'opacity-100 translate-x-0 animate-slideInRight'\n } ${className}`}\n >\n <span>{children || message}</span>\n {onClose && (\n <button onClick={handleClose} className=\"ml-4 font-bold hover:opacity-70 transition-opacity\" aria-label=\"Close\">\n ×\n </button>\n )}\n </div>\n );\n\n return typeof document !== 'undefined' ? createPortal(toast, document.body) : toast;\n}\n\nToast.displayName = 'Toast';\n\nexport default Toast;\n"],"names":[],"mappings":";;;AAqBA,SAAS,MAAM,EAAE,SAAS,UAAU,OAAO,QAAQ,SAAS,YAAY,IAAI,WAAW,IAAA,GAA8B;AACnH,QAAM,CAAC,WAAW,YAAY,IAAI,SAAS,KAAK;AAEhD,QAAM,cAAc;AAAA,IAClB,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,IACT,OAAO;AAAA,EAAA;AAGT,QAAM,cAAc,YAAY,MAAM;AACpC,iBAAa,IAAI;AAEjB,eAAW,MAAM;AACf,gBAAA;AAAA,IACF,GAAG,GAAG;AAAA,EACR,GAAG,CAAC,OAAO,CAAC;AAEZ,YAAU,MAAM;AACd,QAAI,WAAW,GAAG;AAChB,YAAM,QAAQ,WAAW,MAAM;AAC7B,oBAAA;AAAA,MACF,GAAG,QAAQ;AACX,aAAO,MAAM,aAAa,KAAK;AAAA,IACjC;AACA,WAAO;AAAA,EACT,GAAG,CAAC,UAAU,WAAW,CAAC;AAE1B,QAAM,QACJ;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,aAAU;AAAA,MACV,WAAW,kGAAkG,YAAY,IAAI,CAAC,yCAC5H,YAAY,+BAA+B,gDAC7C,IAAI,SAAS;AAAA,MAEb,UAAA;AAAA,QAAA,oBAAC,QAAA,EAAM,sBAAY,QAAA,CAAQ;AAAA,QAC1B,+BACE,UAAA,EAAO,SAAS,aAAa,WAAU,sDAAqD,cAAW,SAAQ,UAAA,IAAA,CAEhH;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAKN,SAAO,OAAO,aAAa,cAAc,aAAa,OAAO,SAAS,IAAI,IAAI;AAChF;AAEA,MAAM,cAAc;"}
@@ -0,0 +1,3 @@
1
+ export { default } from './tooltip';
2
+ export type { TooltipProps } from './tooltip';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/tooltip/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,39 @@
1
+ import { ReactNode } from 'react';
2
+ import { ColorVariant } from '../..';
3
+ export type TooltipProps = {
4
+ /** The element that triggers the tooltip */
5
+ children: ReactNode;
6
+ /** Tooltip text content */
7
+ content: string | ReactNode;
8
+ /** Position of the tooltip relative to the trigger element */
9
+ position?: 'top' | 'bottom' | 'left' | 'right';
10
+ /** Color variant of the tooltip */
11
+ variant?: ColorVariant;
12
+ /** Delay before showing tooltip in ms */
13
+ delayDuration?: number;
14
+ /** Additional CSS classes */
15
+ className?: string;
16
+ };
17
+ /**
18
+ * Tooltip - Simple CSS-based tooltip component
19
+ *
20
+ * Displays a tooltip message on hover. Uses CSS for positioning with
21
+ * portal rendering to escape overflow constraints.
22
+ *
23
+ * @example
24
+ * ```tsx
25
+ * <Tooltip content="Hello">
26
+ * <Button>Hover me</Button>
27
+ * </Tooltip>
28
+ *
29
+ * <Tooltip content="Success!" position="right" variant="success">
30
+ * <Button>Submit</Button>
31
+ * </Tooltip>
32
+ * ```
33
+ */
34
+ declare function Tooltip({ children, content, position, variant, delayDuration, className }: Readonly<TooltipProps>): import("react/jsx-runtime").JSX.Element;
35
+ declare namespace Tooltip {
36
+ var displayName: string;
37
+ }
38
+ export default Tooltip;
39
+ //# sourceMappingURL=tooltip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tooltip.d.ts","sourceRoot":"","sources":["../../../../src/components/feedback/tooltip/tooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA4C,MAAM,OAAO,CAAC;AAE5E,OAAO,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAErC,MAAM,MAAM,YAAY,GAAG;IACzB,4CAA4C;IAC5C,QAAQ,EAAE,SAAS,CAAC;IACpB,2BAA2B;IAC3B,OAAO,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5B,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,CAAC;IAC/C,mCAAmC;IACnC,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,yCAAyC;IACzC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,6BAA6B;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,iBAAS,OAAO,CAAC,EACf,QAAQ,EACR,OAAO,EACP,QAAgB,EAChB,OAAmB,EACnB,aAAmB,EACnB,SAAc,EACf,EAAE,QAAQ,CAAC,YAAY,CAAC,2CAkIxB;kBAzIQ,OAAO;;;AA6IhB,eAAe,OAAO,CAAC"}
@@ -0,0 +1,129 @@
1
+ import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
+ import { useState, useRef, useCallback, useEffect } from "react";
3
+ import { createPortal } from "react-dom";
4
+ function Tooltip({
5
+ children,
6
+ content,
7
+ position = "top",
8
+ variant = "neutral",
9
+ delayDuration = 200,
10
+ className = ""
11
+ }) {
12
+ const [isOpen, setIsOpen] = useState(false);
13
+ const [coords, setCoords] = useState({ top: 0, left: 0 });
14
+ const triggerRef = useRef(null);
15
+ const tooltipRef = useRef(null);
16
+ const timeoutRef = useRef(void 0);
17
+ const calculatePosition = useCallback(() => {
18
+ if (!triggerRef.current || !tooltipRef.current) return;
19
+ const triggerRect = triggerRef.current.getBoundingClientRect();
20
+ const tooltipRect = tooltipRef.current.getBoundingClientRect();
21
+ const offset = 8;
22
+ let top = 0;
23
+ let left = 0;
24
+ switch (position) {
25
+ case "top":
26
+ top = triggerRect.top - tooltipRect.height - offset;
27
+ left = triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
28
+ break;
29
+ case "bottom":
30
+ top = triggerRect.bottom + offset;
31
+ left = triggerRect.left + triggerRect.width / 2 - tooltipRect.width / 2;
32
+ break;
33
+ case "left":
34
+ top = triggerRect.top + triggerRect.height / 2 - tooltipRect.height / 2;
35
+ left = triggerRect.left - tooltipRect.width - offset;
36
+ break;
37
+ case "right":
38
+ top = triggerRect.top + triggerRect.height / 2 - tooltipRect.height / 2;
39
+ left = triggerRect.right + offset;
40
+ break;
41
+ }
42
+ const padding = 8;
43
+ if (left < padding) left = padding;
44
+ if (left + tooltipRect.width > window.innerWidth - padding) {
45
+ left = window.innerWidth - tooltipRect.width - padding;
46
+ }
47
+ if (top < padding) top = padding;
48
+ if (top + tooltipRect.height > window.innerHeight - padding) {
49
+ top = window.innerHeight - tooltipRect.height - padding;
50
+ }
51
+ setCoords({ top, left });
52
+ }, [position]);
53
+ const handleMouseEnter = () => {
54
+ timeoutRef.current = window.setTimeout(() => {
55
+ setIsOpen(true);
56
+ }, delayDuration);
57
+ };
58
+ const handleMouseLeave = () => {
59
+ if (timeoutRef.current) {
60
+ clearTimeout(timeoutRef.current);
61
+ }
62
+ setIsOpen(false);
63
+ };
64
+ useEffect(() => {
65
+ if (isOpen) {
66
+ requestAnimationFrame(() => {
67
+ calculatePosition();
68
+ });
69
+ const handleScroll = () => calculatePosition();
70
+ const handleResize = () => calculatePosition();
71
+ window.addEventListener("scroll", handleScroll, true);
72
+ window.addEventListener("resize", handleResize);
73
+ return () => {
74
+ window.removeEventListener("scroll", handleScroll, true);
75
+ window.removeEventListener("resize", handleResize);
76
+ };
77
+ }
78
+ return void 0;
79
+ }, [isOpen, calculatePosition]);
80
+ useEffect(() => {
81
+ return () => {
82
+ if (timeoutRef.current) {
83
+ clearTimeout(timeoutRef.current);
84
+ }
85
+ };
86
+ }, []);
87
+ const variantClasses = {
88
+ primary: "bg-primary text-primary-foreground",
89
+ accent: "bg-accent text-accent-foreground",
90
+ info: "bg-info text-info-foreground",
91
+ success: "bg-success text-success-foreground",
92
+ warning: "bg-warning text-warning-foreground",
93
+ error: "bg-error text-error-foreground",
94
+ neutral: "bg-muted text-muted-foreground"
95
+ };
96
+ const tooltip = isOpen ? /* @__PURE__ */ jsx(
97
+ "div",
98
+ {
99
+ ref: tooltipRef,
100
+ role: "tooltip",
101
+ className: `fixed z-9999 px-3 py-1.5 text-xs font-medium rounded-md shadow-md max-w-xs animate-in fade-in-0 zoom-in-95 ${variantClasses[variant]} ${className}`,
102
+ style: {
103
+ top: `${coords.top}px`,
104
+ left: `${coords.left}px`
105
+ },
106
+ children: content
107
+ }
108
+ ) : null;
109
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
110
+ /* @__PURE__ */ jsx(
111
+ "span",
112
+ {
113
+ ref: triggerRef,
114
+ onMouseEnter: handleMouseEnter,
115
+ onMouseLeave: handleMouseLeave,
116
+ onFocus: handleMouseEnter,
117
+ onBlur: handleMouseLeave,
118
+ className: "inline-flex",
119
+ children
120
+ }
121
+ ),
122
+ tooltip && createPortal(tooltip, document.body)
123
+ ] });
124
+ }
125
+ Tooltip.displayName = "Tooltip";
126
+ export {
127
+ Tooltip as default
128
+ };
129
+ //# sourceMappingURL=tooltip.js.map