@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,259 @@
1
+ import { jsxs, jsx, Fragment } from "react/jsx-runtime";
2
+ import { useState, useRef, useEffect } from "react";
3
+ import { Icon } from "../../system/icon/icon.js";
4
+ import { getIconPixels, chipSizes, interactiveSizes } from "../../../theme/size-tokens.js";
5
+ function MultiSelect({
6
+ options,
7
+ value = [],
8
+ onChange,
9
+ placeholder = "Select options...",
10
+ noneFoundText = "No options found",
11
+ disabled = false,
12
+ maxSelections,
13
+ size = "md",
14
+ className = ""
15
+ }) {
16
+ const [isOpen, setIsOpen] = useState(false);
17
+ const [searchQuery, setSearchQuery] = useState("");
18
+ const [focusedIndex, setFocusedIndex] = useState(-1);
19
+ const containerRef = useRef(null);
20
+ const searchInputRef = useRef(null);
21
+ const selectedValues = value || [];
22
+ useEffect(() => {
23
+ const handleClickOutside = (event) => {
24
+ if (containerRef.current && !containerRef.current.contains(event.target)) {
25
+ setIsOpen(false);
26
+ setSearchQuery("");
27
+ }
28
+ };
29
+ if (isOpen) {
30
+ document.addEventListener("mousedown", handleClickOutside);
31
+ return () => document.removeEventListener("mousedown", handleClickOutside);
32
+ }
33
+ return void 0;
34
+ }, [isOpen]);
35
+ useEffect(() => {
36
+ if (isOpen && searchInputRef.current) {
37
+ searchInputRef.current.focus();
38
+ }
39
+ }, [isOpen]);
40
+ const filteredOptions = options.filter((option) => option.label.toLowerCase().includes(searchQuery.toLowerCase()));
41
+ const handleToggleOption = (optionValue) => {
42
+ const isSelected = selectedValues.includes(optionValue);
43
+ let newValues;
44
+ if (isSelected) {
45
+ newValues = selectedValues.filter((v) => v !== optionValue);
46
+ } else {
47
+ if (maxSelections && selectedValues.length >= maxSelections) {
48
+ return;
49
+ }
50
+ newValues = [...selectedValues, optionValue];
51
+ }
52
+ onChange?.(newValues);
53
+ };
54
+ const handleRemoveValue = (valueToRemove, e) => {
55
+ e.stopPropagation();
56
+ const newValues = selectedValues.filter((v) => v !== valueToRemove);
57
+ onChange?.(newValues);
58
+ };
59
+ const handleClearAll = (e) => {
60
+ e.stopPropagation();
61
+ onChange?.([]);
62
+ };
63
+ const handleKeyDown = (e) => {
64
+ if (disabled) return;
65
+ switch (e.key) {
66
+ case "Enter":
67
+ e.preventDefault();
68
+ if (!isOpen) {
69
+ setIsOpen(true);
70
+ } else if (focusedIndex >= 0 && focusedIndex < filteredOptions.length) {
71
+ handleToggleOption(filteredOptions[focusedIndex].value);
72
+ }
73
+ break;
74
+ case "Escape":
75
+ e.preventDefault();
76
+ setIsOpen(false);
77
+ setSearchQuery("");
78
+ break;
79
+ case "ArrowDown":
80
+ e.preventDefault();
81
+ if (!isOpen) {
82
+ setIsOpen(true);
83
+ } else {
84
+ setFocusedIndex((prev) => prev < filteredOptions.length - 1 ? prev + 1 : prev);
85
+ }
86
+ break;
87
+ case "ArrowUp":
88
+ e.preventDefault();
89
+ setFocusedIndex((prev) => prev > 0 ? prev - 1 : 0);
90
+ break;
91
+ }
92
+ };
93
+ const sizeClasses = {
94
+ xs: {
95
+ container: interactiveSizes.xs.height.split(" ")[0].replace("h-", "min-h-") + " py-0.5 px-1.5",
96
+ text: interactiveSizes.xs.text,
97
+ chip: chipSizes.sm.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
98
+ icon: getIconPixels("xs", "desktop")
99
+ },
100
+ sm: {
101
+ container: interactiveSizes.sm.height.split(" ")[0].replace("h-", "min-h-") + " py-1 px-2",
102
+ text: interactiveSizes.sm.text,
103
+ chip: chipSizes.sm.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
104
+ icon: getIconPixels("sm", "desktop")
105
+ },
106
+ md: {
107
+ container: interactiveSizes.md.height.split(" ")[0].replace("h-", "min-h-") + " py-2 px-3",
108
+ text: interactiveSizes.md.text,
109
+ chip: chipSizes.md.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
110
+ icon: getIconPixels("md", "desktop")
111
+ },
112
+ lg: {
113
+ container: interactiveSizes.lg.height.split(" ")[0].replace("h-", "min-h-") + " py-2 px-4",
114
+ text: interactiveSizes.lg.text,
115
+ chip: chipSizes.lg.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
116
+ icon: getIconPixels("lg", "desktop")
117
+ },
118
+ xl: {
119
+ container: interactiveSizes.xl.height.split(" ")[0].replace("h-", "min-h-") + " py-2.5 px-5",
120
+ text: interactiveSizes.xl.text,
121
+ chip: chipSizes.lg.classes.split(" ").filter((c) => !c.includes("gap")).join(" "),
122
+ icon: getIconPixels("xl", "desktop")
123
+ }
124
+ };
125
+ const currentSize = sizeClasses[size];
126
+ const getSelectedLabels = () => {
127
+ return selectedValues.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);
128
+ };
129
+ return /* @__PURE__ */ jsxs("div", { ref: containerRef, className: `relative w-full ${className}`, children: [
130
+ /* @__PURE__ */ jsxs(
131
+ "div",
132
+ {
133
+ className: `
134
+ w-full flex flex-wrap items-center gap-1.5
135
+ border border-input rounded-md
136
+ bg-background text-foreground
137
+ cursor-pointer
138
+ transition-all duration-200
139
+ ${currentSize.container}
140
+ ${currentSize.text}
141
+ ${isOpen ? "ring-2 ring-ring ring-offset-2" : "hover:border-ring"}
142
+ ${disabled ? "opacity-50 cursor-not-allowed" : ""}
143
+ `.trim(),
144
+ onClick: () => !disabled && setIsOpen(!isOpen),
145
+ onKeyDown: handleKeyDown,
146
+ tabIndex: disabled ? -1 : 0,
147
+ role: "button",
148
+ "aria-haspopup": "listbox",
149
+ "aria-expanded": isOpen,
150
+ "aria-label": "Multi-select",
151
+ children: [
152
+ selectedValues.length > 0 ? /* @__PURE__ */ jsx(Fragment, { children: getSelectedLabels().map((label, index) => /* @__PURE__ */ jsxs(
153
+ "span",
154
+ {
155
+ className: `
156
+ inline-flex items-center gap-1
157
+ bg-primary/10 text-primary rounded-md font-medium
158
+ animate-scaleIn origin-left
159
+ transition-all duration-200
160
+ ${currentSize.chip}
161
+ `.trim(),
162
+ children: [
163
+ label,
164
+ /* @__PURE__ */ jsx(
165
+ "button",
166
+ {
167
+ type: "button",
168
+ onClick: (e) => handleRemoveValue(selectedValues[index], e),
169
+ className: "hover:bg-primary/20 rounded-sm transition-colors duration-150",
170
+ "aria-label": `Remove ${label}`,
171
+ tabIndex: -1,
172
+ children: /* @__PURE__ */ jsx(Icon, { name: "x", size })
173
+ }
174
+ )
175
+ ]
176
+ },
177
+ selectedValues[index]
178
+ )) }) : /* @__PURE__ */ jsx("span", { className: "text-muted-foreground", children: placeholder }),
179
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1 ml-auto shrink-0", children: [
180
+ selectedValues.length > 0 && !disabled && /* @__PURE__ */ jsx(
181
+ "button",
182
+ {
183
+ type: "button",
184
+ onClick: handleClearAll,
185
+ className: "p-1 hover:bg-muted rounded transition-colors",
186
+ "aria-label": "Clear all",
187
+ tabIndex: -1,
188
+ children: /* @__PURE__ */ jsx(Icon, { name: "x", size })
189
+ }
190
+ ),
191
+ /* @__PURE__ */ jsx(
192
+ Icon,
193
+ {
194
+ name: "chevron-down",
195
+ size,
196
+ className: `text-muted-foreground transition-transform ${isOpen ? "rotate-180" : ""}`
197
+ }
198
+ )
199
+ ] })
200
+ ]
201
+ }
202
+ ),
203
+ isOpen && !disabled && /* @__PURE__ */ jsxs("div", { className: "absolute top-full left-0 right-0 mt-2 z-50 bg-card border border-border rounded-md shadow-lg max-h-64 overflow-hidden flex flex-col animate-scaleIn origin-top", children: [
204
+ /* @__PURE__ */ jsx("div", { className: "p-2 border-b border-border", children: /* @__PURE__ */ jsx(
205
+ "input",
206
+ {
207
+ ref: searchInputRef,
208
+ type: "text",
209
+ value: searchQuery,
210
+ onChange: (e) => {
211
+ setSearchQuery(e.target.value);
212
+ setFocusedIndex(-1);
213
+ },
214
+ placeholder: "Search...",
215
+ className: `w-full px-3 py-1.5 ${currentSize.text} border border-input rounded-md bg-background text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring`,
216
+ onClick: (e) => e.stopPropagation()
217
+ }
218
+ ) }),
219
+ /* @__PURE__ */ jsx("div", { className: "overflow-y-auto", role: "listbox", children: filteredOptions.length > 0 ? filteredOptions.map((option, index) => {
220
+ const isSelected = selectedValues.includes(option.value);
221
+ const isFocused = index === focusedIndex;
222
+ const isDisabled = Boolean(maxSelections && !isSelected && selectedValues.length >= maxSelections);
223
+ return /* @__PURE__ */ jsxs(
224
+ "button",
225
+ {
226
+ type: "button",
227
+ onClick: () => !isDisabled && handleToggleOption(option.value),
228
+ className: `
229
+ w-full px-3 py-2 flex items-center justify-between gap-2
230
+ transition-all duration-200 text-left ${currentSize.text}
231
+ ${isFocused ? "bg-muted" : ""}
232
+ ${isSelected ? "bg-primary/10 text-primary font-medium" : "hover:bg-muted"}
233
+ ${isDisabled ? "opacity-50 cursor-not-allowed" : ""}
234
+ `.trim(),
235
+ role: "option",
236
+ "aria-selected": isSelected,
237
+ disabled: isDisabled,
238
+ children: [
239
+ /* @__PURE__ */ jsx("span", { className: "flex-1 truncate", children: option.label }),
240
+ isSelected && /* @__PURE__ */ jsx(Icon, { name: "check", size, className: "shrink-0 animate-scaleIn" })
241
+ ]
242
+ },
243
+ option.value
244
+ );
245
+ }) : /* @__PURE__ */ jsx("div", { className: "px-3 py-6 text-center text-muted-foreground", children: noneFoundText }) }),
246
+ maxSelections && /* @__PURE__ */ jsxs("div", { className: "px-3 py-2 border-t border-border bg-muted/30 text-xs text-muted-foreground", children: [
247
+ selectedValues.length,
248
+ " / ",
249
+ maxSelections,
250
+ " selected"
251
+ ] })
252
+ ] })
253
+ ] });
254
+ }
255
+ MultiSelect.displayName = "MultiSelect";
256
+ export {
257
+ MultiSelect as default
258
+ };
259
+ //# sourceMappingURL=multi-select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multi-select.js","sources":["../../../../src/components/forms/multi-select/multi-select.tsx"],"sourcesContent":["import { useState, useRef, useEffect } from 'react';\nimport Icon from '../../system/icon/icon';\nimport { interactiveSizes, chipSizes, getIconPixels, type InteractiveSize } from '../../../theme/size-tokens';\n\nexport type MultiSelectOption = {\n value: string;\n label: string;\n};\n\nexport type MultiSelectProps = {\n /**\n * Available options to select from\n */\n options: MultiSelectOption[];\n /**\n * Currently selected values\n */\n value?: string[];\n /**\n * Callback when selection changes\n */\n onChange?: (values: string[]) => void;\n /**\n * Placeholder text when no selection\n */\n placeholder?: string;\n /**\n * Disabled state\n */\n disabled?: boolean;\n /**\n * Maximum number of selections allowed\n */\n maxSelections?: number;\n /**\n * Size variant - uses unified size system\n */\n size?: InteractiveSize;\n /**\n * Additional CSS classes\n */\n className?: string;\n /**\n * Text to display when no options are found\n */\n noneFoundText?: string;\n};\n\n/**\n * MultiSelect - Select multiple options from a dropdown list\n *\n * Features:\n * - Multiple selections with chips\n * - Searchable dropdown\n * - Keyboard navigation\n * - Max selections limit\n * - Clearable\n * - Accessible\n *\n * @example\n * ```tsx\n * const [selected, setSelected] = useState<string[]>([]);\n *\n * <MultiSelect\n * options={[\n * { value: '1', label: 'Option 1' },\n * { value: '2', label: 'Option 2' }\n * ]}\n * value={selected}\n * onChange={setSelected}\n * placeholder=\"Select options...\"\n * />\n * ```\n */\nfunction MultiSelect({\n options,\n value = [],\n onChange,\n placeholder = 'Select options...',\n noneFoundText = 'No options found',\n disabled = false,\n maxSelections,\n size = 'md',\n className = ''\n}: Readonly<MultiSelectProps>) {\n const [isOpen, setIsOpen] = useState(false);\n const [searchQuery, setSearchQuery] = useState('');\n const [focusedIndex, setFocusedIndex] = useState(-1);\n const containerRef = useRef<HTMLDivElement>(null);\n const searchInputRef = useRef<HTMLInputElement>(null);\n\n const selectedValues = value || [];\n\n // Close on click outside\n useEffect(() => {\n const handleClickOutside = (event: MouseEvent) => {\n if (containerRef.current && !containerRef.current.contains(event.target as Node)) {\n setIsOpen(false);\n setSearchQuery('');\n }\n };\n\n if (isOpen) {\n document.addEventListener('mousedown', handleClickOutside);\n return () => document.removeEventListener('mousedown', handleClickOutside);\n }\n return undefined;\n }, [isOpen]);\n\n // Focus search input when opened\n useEffect(() => {\n if (isOpen && searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, [isOpen]);\n\n const filteredOptions = options.filter((option) => option.label.toLowerCase().includes(searchQuery.toLowerCase()));\n\n const handleToggleOption = (optionValue: string) => {\n const isSelected = selectedValues.includes(optionValue);\n let newValues: string[];\n\n if (isSelected) {\n newValues = selectedValues.filter((v) => v !== optionValue);\n } else {\n if (maxSelections && selectedValues.length >= maxSelections) {\n return; // Don't add if max reached\n }\n newValues = [...selectedValues, optionValue];\n }\n\n onChange?.(newValues);\n };\n\n const handleRemoveValue = (valueToRemove: string, e: React.MouseEvent) => {\n e.stopPropagation();\n const newValues = selectedValues.filter((v) => v !== valueToRemove);\n onChange?.(newValues);\n };\n\n const handleClearAll = (e: React.MouseEvent) => {\n e.stopPropagation();\n onChange?.([]);\n };\n\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (disabled) return;\n\n switch (e.key) {\n case 'Enter':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else if (focusedIndex >= 0 && focusedIndex < filteredOptions.length) {\n handleToggleOption(filteredOptions[focusedIndex].value);\n }\n break;\n case 'Escape':\n e.preventDefault();\n setIsOpen(false);\n setSearchQuery('');\n break;\n case 'ArrowDown':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else {\n setFocusedIndex((prev) => (prev < filteredOptions.length - 1 ? prev + 1 : prev));\n }\n break;\n case 'ArrowUp':\n e.preventDefault();\n setFocusedIndex((prev) => (prev > 0 ? prev - 1 : 0));\n break;\n }\n };\n\n const sizeClasses = {\n xs: {\n container: interactiveSizes.xs.height.split(' ')[0].replace('h-', 'min-h-') + ' py-0.5 px-1.5',\n text: interactiveSizes.xs.text,\n chip: chipSizes.sm.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('xs', 'desktop')\n },\n sm: {\n container: interactiveSizes.sm.height.split(' ')[0].replace('h-', 'min-h-') + ' py-1 px-2',\n text: interactiveSizes.sm.text,\n chip: chipSizes.sm.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('sm', 'desktop')\n },\n md: {\n container: interactiveSizes.md.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2 px-3',\n text: interactiveSizes.md.text,\n chip: chipSizes.md.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('md', 'desktop')\n },\n lg: {\n container: interactiveSizes.lg.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2 px-4',\n text: interactiveSizes.lg.text,\n chip: chipSizes.lg.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('lg', 'desktop')\n },\n xl: {\n container: interactiveSizes.xl.height.split(' ')[0].replace('h-', 'min-h-') + ' py-2.5 px-5',\n text: interactiveSizes.xl.text,\n chip: chipSizes.lg.classes\n .split(' ')\n .filter((c) => !c.includes('gap'))\n .join(' '),\n icon: getIconPixels('xl', 'desktop')\n }\n };\n\n const currentSize = sizeClasses[size];\n\n const getSelectedLabels = () => {\n return selectedValues.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);\n };\n\n return (\n <div ref={containerRef} className={`relative w-full ${className}`}>\n {/* Trigger */}\n <div\n className={`\n w-full flex flex-wrap items-center gap-1.5\n border border-input rounded-md\n bg-background text-foreground\n cursor-pointer\n transition-all duration-200\n ${currentSize.container}\n ${currentSize.text}\n ${isOpen ? 'ring-2 ring-ring ring-offset-2' : 'hover:border-ring'}\n ${disabled ? 'opacity-50 cursor-not-allowed' : ''}\n `.trim()}\n onClick={() => !disabled && setIsOpen(!isOpen)}\n onKeyDown={handleKeyDown}\n tabIndex={disabled ? -1 : 0}\n role=\"button\"\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-label=\"Multi-select\"\n >\n {/* Selected items as chips */}\n {selectedValues.length > 0 ? (\n <>\n {getSelectedLabels().map((label, index) => (\n <span\n key={selectedValues[index]}\n className={`\n inline-flex items-center gap-1 \n bg-primary/10 text-primary rounded-md font-medium \n animate-scaleIn origin-left\n transition-all duration-200\n ${currentSize.chip}\n `.trim()}\n >\n {label}\n <button\n type=\"button\"\n onClick={(e) => handleRemoveValue(selectedValues[index], e)}\n className=\"hover:bg-primary/20 rounded-sm transition-colors duration-150\"\n aria-label={`Remove ${label}`}\n tabIndex={-1}\n >\n <Icon name=\"x\" size={size} />\n </button>\n </span>\n ))}\n </>\n ) : (\n <span className=\"text-muted-foreground\">{placeholder}</span>\n )}\n\n {/* Right side icons */}\n <div className=\"flex items-center gap-1 ml-auto shrink-0\">\n {selectedValues.length > 0 && !disabled && (\n <button\n type=\"button\"\n onClick={handleClearAll}\n className=\"p-1 hover:bg-muted rounded transition-colors\"\n aria-label=\"Clear all\"\n tabIndex={-1}\n >\n <Icon name=\"x\" size={size} />\n </button>\n )}\n <Icon\n name=\"chevron-down\"\n size={size}\n className={`text-muted-foreground transition-transform ${isOpen ? 'rotate-180' : ''}`}\n />\n </div>\n </div>\n\n {/* Dropdown */}\n {isOpen && !disabled && (\n <div className=\"absolute top-full left-0 right-0 mt-2 z-50 bg-card border border-border rounded-md shadow-lg max-h-64 overflow-hidden flex flex-col animate-scaleIn origin-top\">\n {/* Search input */}\n <div className=\"p-2 border-b border-border\">\n <input\n ref={searchInputRef}\n type=\"text\"\n value={searchQuery}\n onChange={(e) => {\n setSearchQuery(e.target.value);\n setFocusedIndex(-1);\n }}\n placeholder=\"Search...\"\n className={`w-full px-3 py-1.5 ${currentSize.text} border border-input rounded-md bg-background text-foreground placeholder:text-muted-foreground focus:outline-none focus:ring-2 focus:ring-ring`}\n onClick={(e) => e.stopPropagation()}\n />\n </div>\n\n {/* Options list */}\n <div className=\"overflow-y-auto\" role=\"listbox\">\n {filteredOptions.length > 0 ? (\n filteredOptions.map((option, index) => {\n const isSelected = selectedValues.includes(option.value);\n const isFocused = index === focusedIndex;\n const isDisabled = Boolean(maxSelections && !isSelected && selectedValues.length >= maxSelections);\n\n return (\n <button\n key={option.value}\n type=\"button\"\n onClick={() => !isDisabled && handleToggleOption(option.value)}\n className={`\n w-full px-3 py-2 flex items-center justify-between gap-2\n transition-all duration-200 text-left ${currentSize.text}\n ${isFocused ? 'bg-muted' : ''}\n ${isSelected ? 'bg-primary/10 text-primary font-medium' : 'hover:bg-muted'}\n ${isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\n `.trim()}\n role=\"option\"\n aria-selected={isSelected}\n disabled={isDisabled}\n >\n <span className=\"flex-1 truncate\">{option.label}</span>\n {isSelected && <Icon name=\"check\" size={size} className=\"shrink-0 animate-scaleIn\" />}\n </button>\n );\n })\n ) : (\n <div className=\"px-3 py-6 text-center text-muted-foreground\">{noneFoundText}</div>\n )}\n </div>\n\n {/* Footer info */}\n {maxSelections && (\n <div className=\"px-3 py-2 border-t border-border bg-muted/30 text-xs text-muted-foreground\">\n {selectedValues.length} / {maxSelections} selected\n </div>\n )}\n </div>\n )}\n </div>\n );\n}\n\nMultiSelect.displayName = 'MultiSelect';\n\nexport default MultiSelect;\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { default } from './radio';
2
+ export type { RadioProps } from './radio';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { default as React } from 'react';
2
+ export type ValidationState = 'default' | 'error' | 'success' | 'warning';
3
+ export type RadioProps = {
4
+ /** Controlled checked state - overridden by RadioGroup context if present */
5
+ checked?: boolean;
6
+ /** Change event handler - called in addition to RadioGroup onChange if both are provided */
7
+ onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;
8
+ /** Disables radio interaction and applies disabled styling */
9
+ disabled?: boolean;
10
+ /** Additional CSS classes applied to the radio button indicator */
11
+ className?: string;
12
+ /** Accessible label for screen readers when visual label is not present */
13
+ ariaLabel?: string;
14
+ /** HTML id attribute - auto-generated if not provided */
15
+ id?: string;
16
+ /** Form input name - overridden by RadioGroup context if present */
17
+ name?: string;
18
+ /** Input value submitted with form - required when used in RadioGroup */
19
+ value?: string;
20
+ /** Visual validation state affecting border and ring colors */
21
+ validationState?: ValidationState;
22
+ };
23
+ /**
24
+ * Accessible Radio component
25
+ */
26
+ declare function Radio({ checked, onChange, disabled, className, ariaLabel, id, name: nameProp, value, validationState }: Readonly<RadioProps>): import("react/jsx-runtime").JSX.Element;
27
+ declare namespace Radio {
28
+ var displayName: string;
29
+ }
30
+ export default Radio;
31
+ //# sourceMappingURL=radio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio/radio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAgB,MAAM,OAAO,CAAC;AAGrC,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,CAAC;AAE1E,MAAM,MAAM,UAAU,GAAG;IACvB,6EAA6E;IAC7E,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,4FAA4F;IAC5F,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;IAC5D,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,mEAAmE;IACnE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,2EAA2E;IAC3E,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,yDAAyD;IACzD,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,oEAAoE;IACpE,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,yEAAyE;IACzE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,+DAA+D;IAC/D,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,CAAC;AAEF;;GAEG;AACH,iBAAS,KAAK,CAAC,EACb,OAAO,EACP,QAAQ,EACR,QAAgB,EAChB,SAAc,EACd,SAAS,EACT,EAAE,EACF,IAAI,EAAE,QAAQ,EACd,KAAK,EACL,eAA2B,EAC5B,EAAE,QAAQ,CAAC,UAAU,CAAC,2CAwDtB;kBAlEQ,KAAK;;;AAsEd,eAAe,KAAK,CAAC"}
@@ -0,0 +1,74 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { useId } from "react";
3
+ import { useRadioGroup } from "../radio-group/radio-group.js";
4
+ function Radio({
5
+ checked,
6
+ onChange,
7
+ disabled = false,
8
+ className = "",
9
+ ariaLabel,
10
+ id,
11
+ name: nameProp,
12
+ value,
13
+ validationState = "default"
14
+ }) {
15
+ const radioGroup = useRadioGroup();
16
+ const name = radioGroup?.name || nameProp;
17
+ const isChecked = radioGroup?.value !== void 0 ? radioGroup.value === value : checked;
18
+ const handleChange = (e) => {
19
+ if (radioGroup?.onChange && value) {
20
+ radioGroup.onChange(value);
21
+ }
22
+ onChange?.(e);
23
+ };
24
+ const validationClasses = {
25
+ default: "border-input focus:ring-ring",
26
+ error: "border-error focus:ring-error",
27
+ success: "border-success focus:ring-success",
28
+ warning: "border-warning focus:ring-warning"
29
+ };
30
+ const generatedId = useId();
31
+ const inputId = id || `radio-${value || generatedId}`;
32
+ return /* @__PURE__ */ jsxs(
33
+ "div",
34
+ {
35
+ className: `inline-flex items-center justify-center relative ${disabled ? "opacity-60 cursor-not-allowed" : "cursor-pointer"}`,
36
+ children: [
37
+ /* @__PURE__ */ jsx(
38
+ "input",
39
+ {
40
+ type: "radio",
41
+ checked: isChecked,
42
+ onChange: handleChange,
43
+ disabled,
44
+ "aria-label": ariaLabel,
45
+ "aria-invalid": validationState === "error" ? "true" : void 0,
46
+ id: inputId,
47
+ name,
48
+ value,
49
+ className: "peer sr-only"
50
+ }
51
+ ),
52
+ /* @__PURE__ */ jsx(
53
+ "span",
54
+ {
55
+ "aria-hidden": "true",
56
+ onClick: () => !disabled && document.getElementById(inputId)?.click(),
57
+ className: `w-6 h-6 sm:w-5 sm:h-5 rounded-full border-2 flex items-center justify-center transition-all duration-200 ease-out bg-background shadow-sm
58
+ before:content-[''] before:w-3 before:h-3 sm:before:w-2.5 sm:before:h-2.5 before:rounded-full before:scale-0 before:transition-transform before:duration-200 before:ease-out before:bg-primary
59
+ peer-checked:before:scale-100 peer-checked:border-primary
60
+ peer-focus-visible:ring-2 peer-focus-visible:ring-offset-2 peer-focus-visible:ring-ring
61
+ peer-disabled:opacity-50 peer-disabled:cursor-not-allowed
62
+ peer-hover:border-primary/60 peer-active:scale-95
63
+ ${validationClasses[validationState]} ${className}`
64
+ }
65
+ )
66
+ ]
67
+ }
68
+ );
69
+ }
70
+ Radio.displayName = "Radio";
71
+ export {
72
+ Radio as default
73
+ };
74
+ //# sourceMappingURL=radio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio.js","sources":["../../../../src/components/forms/radio/radio.tsx"],"sourcesContent":["import React, { useId } from 'react';\nimport { useRadioGroup } from '../radio-group/radio-group';\n\nexport type ValidationState = 'default' | 'error' | 'success' | 'warning';\n\nexport type RadioProps = {\n /** Controlled checked state - overridden by RadioGroup context if present */\n checked?: boolean;\n /** Change event handler - called in addition to RadioGroup onChange if both are provided */\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n /** Disables radio interaction and applies disabled styling */\n disabled?: boolean;\n /** Additional CSS classes applied to the radio button indicator */\n className?: string;\n /** Accessible label for screen readers when visual label is not present */\n ariaLabel?: string;\n /** HTML id attribute - auto-generated if not provided */\n id?: string;\n /** Form input name - overridden by RadioGroup context if present */\n name?: string;\n /** Input value submitted with form - required when used in RadioGroup */\n value?: string;\n /** Visual validation state affecting border and ring colors */\n validationState?: ValidationState;\n};\n\n/**\n * Accessible Radio component\n */\nfunction Radio({\n checked,\n onChange,\n disabled = false,\n className = '',\n ariaLabel,\n id,\n name: nameProp,\n value,\n validationState = 'default'\n}: Readonly<RadioProps>) {\n const radioGroup = useRadioGroup();\n\n // Use name from RadioGroup context if available, otherwise use prop\n const name = radioGroup?.name || nameProp;\n\n // Use checked state from RadioGroup if available\n const isChecked = radioGroup?.value !== undefined ? radioGroup.value === value : checked;\n\n // Handle change with RadioGroup callback if available\n const handleChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n if (radioGroup?.onChange && value) {\n radioGroup.onChange(value);\n }\n onChange?.(e);\n };\n\n const validationClasses = {\n default: 'border-input focus:ring-ring',\n error: 'border-error focus:ring-error',\n success: 'border-success focus:ring-success',\n warning: 'border-warning focus:ring-warning'\n };\n\n const generatedId = useId();\n const inputId = id || `radio-${value || generatedId}`;\n\n return (\n <div\n className={`inline-flex items-center justify-center relative ${disabled ? 'opacity-60 cursor-not-allowed' : 'cursor-pointer'}`}\n >\n <input\n type=\"radio\"\n checked={isChecked}\n onChange={handleChange}\n disabled={disabled}\n aria-label={ariaLabel}\n aria-invalid={validationState === 'error' ? 'true' : undefined}\n id={inputId}\n name={name}\n value={value}\n className=\"peer sr-only\"\n />\n <span\n aria-hidden=\"true\"\n onClick={() => !disabled && document.getElementById(inputId)?.click()}\n className={`w-6 h-6 sm:w-5 sm:h-5 rounded-full border-2 flex items-center justify-center transition-all duration-200 ease-out bg-background shadow-sm\n before:content-[''] before:w-3 before:h-3 sm:before:w-2.5 sm:before:h-2.5 before:rounded-full before:scale-0 before:transition-transform before:duration-200 before:ease-out before:bg-primary\n peer-checked:before:scale-100 peer-checked:border-primary\n peer-focus-visible:ring-2 peer-focus-visible:ring-offset-2 peer-focus-visible:ring-ring\n peer-disabled:opacity-50 peer-disabled:cursor-not-allowed\n peer-hover:border-primary/60 peer-active:scale-95\n ${validationClasses[validationState]} ${className}`}\n />\n </div>\n );\n}\n\nRadio.displayName = 'Radio';\n\nexport default Radio;\n"],"names":[],"mappings":";;;AA6BA,SAAS,MAAM;AAAA,EACb;AAAA,EACA;AAAA,EACA,WAAW;AAAA,EACX,YAAY;AAAA,EACZ;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN;AAAA,EACA,kBAAkB;AACpB,GAAyB;AACvB,QAAM,aAAa,cAAA;AAGnB,QAAM,OAAO,YAAY,QAAQ;AAGjC,QAAM,YAAY,YAAY,UAAU,SAAY,WAAW,UAAU,QAAQ;AAGjF,QAAM,eAAe,CAAC,MAA2C;AAC/D,QAAI,YAAY,YAAY,OAAO;AACjC,iBAAW,SAAS,KAAK;AAAA,IAC3B;AACA,eAAW,CAAC;AAAA,EACd;AAEA,QAAM,oBAAoB;AAAA,IACxB,SAAS;AAAA,IACT,OAAO;AAAA,IACP,SAAS;AAAA,IACT,SAAS;AAAA,EAAA;AAGX,QAAM,cAAc,MAAA;AACpB,QAAM,UAAU,MAAM,SAAS,SAAS,WAAW;AAEnD,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAW,oDAAoD,WAAW,kCAAkC,gBAAgB;AAAA,MAE5H,UAAA;AAAA,QAAA;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,MAAK;AAAA,YACL,SAAS;AAAA,YACT,UAAU;AAAA,YACV;AAAA,YACA,cAAY;AAAA,YACZ,gBAAc,oBAAoB,UAAU,SAAS;AAAA,YACrD,IAAI;AAAA,YACJ;AAAA,YACA;AAAA,YACA,WAAU;AAAA,UAAA;AAAA,QAAA;AAAA,QAEZ;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,eAAY;AAAA,YACZ,SAAS,MAAM,CAAC,YAAY,SAAS,eAAe,OAAO,GAAG,MAAA;AAAA,YAC9D,WAAW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAMT,kBAAkB,eAAe,CAAC,IAAI,SAAS;AAAA,UAAA;AAAA,QAAA;AAAA,MACnD;AAAA,IAAA;AAAA,EAAA;AAGN;AAEA,MAAM,cAAc;"}
@@ -0,0 +1,3 @@
1
+ export { default, useRadioGroup } from './radio-group';
2
+ export type { RadioGroupProps } from './radio-group';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio-group/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AACvD,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,32 @@
1
+ import { ReactNode } from 'react';
2
+ export type RadioGroupProps = {
3
+ /** Radio components - typically multiple Radio components */
4
+ children: ReactNode;
5
+ /** Form input name shared by all child radios for grouping */
6
+ name: string;
7
+ /** Optional legend text displayed above the radio group */
8
+ label?: string;
9
+ /** Layout direction - horizontal arranges radios in a row, vertical stacks them */
10
+ orientation?: 'horizontal' | 'vertical';
11
+ /** Additional CSS classes applied to the fieldset container */
12
+ className?: string;
13
+ /** Controlled value - matches the value prop of the selected Radio */
14
+ value?: string;
15
+ /** Change handler receiving the selected radio's value */
16
+ onChange?: (value: string) => void;
17
+ };
18
+ type RadioGroupContextValue = {
19
+ name: string;
20
+ value?: string;
21
+ onChange?: (value: string) => void;
22
+ };
23
+ export declare const useRadioGroup: () => RadioGroupContextValue | null;
24
+ /**
25
+ * RadioGroup - Wrapper for radio inputs with consistent spacing and shared name
26
+ */
27
+ declare function RadioGroup({ children, name, label, orientation, className, value, onChange }: Readonly<RadioGroupProps>): import("react/jsx-runtime").JSX.Element;
28
+ declare namespace RadioGroup {
29
+ var displayName: string;
30
+ }
31
+ export default RadioGroup;
32
+ //# sourceMappingURL=radio-group.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-group.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/radio-group/radio-group.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAA6B,MAAM,OAAO,CAAC;AAE7D,MAAM,MAAM,eAAe,GAAG;IAC5B,6DAA6D;IAC7D,QAAQ,EAAE,SAAS,CAAC;IACpB,8DAA8D;IAC9D,IAAI,EAAE,MAAM,CAAC;IACb,2DAA2D;IAC3D,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,mFAAmF;IACnF,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;IACxC,+DAA+D;IAC/D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,sEAAsE;IACtE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC,CAAC;AAEF,KAAK,sBAAsB,GAAG;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACpC,CAAC;AAIF,eAAO,MAAM,aAAa,qCAGzB,CAAC;AAEF;;GAEG;AACH,iBAAS,UAAU,CAAC,EAClB,QAAQ,EACR,IAAI,EACJ,KAAK,EACL,WAAwB,EACxB,SAAc,EACd,KAAK,EACL,QAAQ,EACT,EAAE,QAAQ,CAAC,eAAe,CAAC,2CAa3B;kBArBQ,UAAU;;;AAyBnB,eAAe,UAAU,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { useContext, createContext } from "react";
3
+ const RadioGroupContext = createContext(null);
4
+ const useRadioGroup = () => {
5
+ const context = useContext(RadioGroupContext);
6
+ return context;
7
+ };
8
+ function RadioGroup({
9
+ children,
10
+ name,
11
+ label,
12
+ orientation = "vertical",
13
+ className = "",
14
+ value,
15
+ onChange
16
+ }) {
17
+ const orientationClasses = orientation === "horizontal" ? "flex flex-row gap-4" : "flex flex-col gap-2";
18
+ return /* @__PURE__ */ jsx(RadioGroupContext.Provider, { value: { name, value, onChange }, children: /* @__PURE__ */ jsxs("fieldset", { className, children: [
19
+ label && /* @__PURE__ */ jsx("legend", { className: "text-sm font-medium text-foreground mb-2", children: label }),
20
+ /* @__PURE__ */ jsx("div", { className: orientationClasses, role: "radiogroup", children })
21
+ ] }) });
22
+ }
23
+ RadioGroup.displayName = "RadioGroup";
24
+ export {
25
+ RadioGroup as default,
26
+ useRadioGroup
27
+ };
28
+ //# sourceMappingURL=radio-group.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-group.js","sources":["../../../../src/components/forms/radio-group/radio-group.tsx"],"sourcesContent":["import { ReactNode, createContext, useContext } from 'react';\n\nexport type RadioGroupProps = {\n /** Radio components - typically multiple Radio components */\n children: ReactNode;\n /** Form input name shared by all child radios for grouping */\n name: string;\n /** Optional legend text displayed above the radio group */\n label?: string;\n /** Layout direction - horizontal arranges radios in a row, vertical stacks them */\n orientation?: 'horizontal' | 'vertical';\n /** Additional CSS classes applied to the fieldset container */\n className?: string;\n /** Controlled value - matches the value prop of the selected Radio */\n value?: string;\n /** Change handler receiving the selected radio's value */\n onChange?: (value: string) => void;\n};\n\ntype RadioGroupContextValue = {\n name: string;\n value?: string;\n onChange?: (value: string) => void;\n};\n\nconst RadioGroupContext = createContext<RadioGroupContextValue | null>(null);\n\nexport const useRadioGroup = () => {\n const context = useContext(RadioGroupContext);\n return context;\n};\n\n/**\n * RadioGroup - Wrapper for radio inputs with consistent spacing and shared name\n */\nfunction RadioGroup({\n children,\n name,\n label,\n orientation = 'vertical',\n className = '',\n value,\n onChange\n}: Readonly<RadioGroupProps>) {\n const orientationClasses = orientation === 'horizontal' ? 'flex flex-row gap-4' : 'flex flex-col gap-2';\n\n return (\n <RadioGroupContext.Provider value={{ name, value, onChange }}>\n <fieldset className={className}>\n {label && <legend className=\"text-sm font-medium text-foreground mb-2\">{label}</legend>}\n <div className={orientationClasses} role=\"radiogroup\">\n {children}\n </div>\n </fieldset>\n </RadioGroupContext.Provider>\n );\n}\n\nRadioGroup.displayName = 'RadioGroup';\n\nexport default RadioGroup;\n"],"names":[],"mappings":";;AAyBA,MAAM,oBAAoB,cAA6C,IAAI;AAEpE,MAAM,gBAAgB,MAAM;AACjC,QAAM,UAAU,WAAW,iBAAiB;AAC5C,SAAO;AACT;AAKA,SAAS,WAAW;AAAA,EAClB;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,YAAY;AAAA,EACZ;AAAA,EACA;AACF,GAA8B;AAC5B,QAAM,qBAAqB,gBAAgB,eAAe,wBAAwB;AAElF,SACE,oBAAC,kBAAkB,UAAlB,EAA2B,OAAO,EAAE,MAAM,OAAO,SAAA,GAChD,UAAA,qBAAC,YAAA,EAAS,WACP,UAAA;AAAA,IAAA,SAAS,oBAAC,UAAA,EAAO,WAAU,4CAA4C,UAAA,OAAM;AAAA,wBAC7E,OAAA,EAAI,WAAW,oBAAoB,MAAK,cACtC,SAAA,CACH;AAAA,EAAA,EAAA,CACF,EAAA,CACF;AAEJ;AAEA,WAAW,cAAc;"}
@@ -0,0 +1,5 @@
1
+ export { default } from './select';
2
+ export type { SelectProps } from './select';
3
+ export { default as SelectItem } from './select-item';
4
+ export type { SelectItemProps } from './select-item';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,YAAY,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,eAAe,CAAC;AACtD,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { default as React } from 'react';
2
+ export type SelectItemProps = {
3
+ value?: string;
4
+ disabled?: boolean;
5
+ children: React.ReactNode;
6
+ };
7
+ /**
8
+ * SelectItem - Option element for Select component
9
+ * Replaces native <option> element with semantic component
10
+ */
11
+ declare function SelectItem({ value, disabled, children }: Readonly<SelectItemProps>): import("react/jsx-runtime").JSX.Element;
12
+ declare namespace SelectItem {
13
+ var displayName: string;
14
+ }
15
+ export default SelectItem;
16
+ //# sourceMappingURL=select-item.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select-item.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/select-item.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,CAAC;AAEF;;;GAGG;AACH,iBAAS,UAAU,CAAC,EAAE,KAAK,EAAE,QAAgB,EAAE,QAAQ,EAAE,EAAE,QAAQ,CAAC,eAAe,CAAC,2CAMnF;kBANQ,UAAU;;;AAUnB,eAAe,UAAU,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { jsx } from "react/jsx-runtime";
2
+ function SelectItem({ value, disabled = false, children }) {
3
+ return /* @__PURE__ */ jsx("option", { value, disabled, children });
4
+ }
5
+ SelectItem.displayName = "SelectItem";
6
+ export {
7
+ SelectItem as default
8
+ };
9
+ //# sourceMappingURL=select-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select-item.js","sources":["../../../../src/components/forms/select/select-item.tsx"],"sourcesContent":["import React from 'react';\n\nexport type SelectItemProps = {\n value?: string;\n disabled?: boolean;\n children: React.ReactNode;\n};\n\n/**\n * SelectItem - Option element for Select component\n * Replaces native <option> element with semantic component\n */\nfunction SelectItem({ value, disabled = false, children }: Readonly<SelectItemProps>) {\n return (\n <option value={value} disabled={disabled}>\n {children}\n </option>\n );\n}\n\nSelectItem.displayName = 'SelectItem';\n\nexport default SelectItem;\n"],"names":[],"mappings":";AAYA,SAAS,WAAW,EAAE,OAAO,WAAW,OAAO,YAAuC;AACpF,SACE,oBAAC,UAAA,EAAO,OAAc,UACnB,SAAA,CACH;AAEJ;AAEA,WAAW,cAAc;"}
@@ -0,0 +1,52 @@
1
+ import { default as React } from 'react';
2
+ import { InteractiveSize, InputWidth, ValidationState } from '../../../theme/size-tokens';
3
+ export type { ValidationState };
4
+ export type SelectProps = {
5
+ /** Current selected value (controlled) */
6
+ value?: string;
7
+ /** Default value for uncontrolled select */
8
+ defaultValue?: string;
9
+ /** Change event handler for controlled select */
10
+ onChange?: (e: React.ChangeEvent<HTMLSelectElement>) => void;
11
+ /** Focus event handler */
12
+ onFocus?: (e: React.FocusEvent<HTMLSelectElement>) => void;
13
+ /** Blur event handler */
14
+ onBlur?: (e: React.FocusEvent<HTMLSelectElement>) => void;
15
+ /** Disables select interaction and applies disabled styling */
16
+ disabled?: boolean;
17
+ /** Accessible label for screen readers */
18
+ ariaLabel?: string;
19
+ /** HTML id attribute for the select */
20
+ id?: string;
21
+ /** HTML name attribute for form submission */
22
+ name?: string;
23
+ /** SelectItem children defining the available options */
24
+ children: React.ReactNode;
25
+ /** Marks select as required for form validation */
26
+ required?: boolean;
27
+ /** Size variant - uses unified size system */
28
+ size?: InteractiveSize;
29
+ /** Width of the select field - uses semantic sizing */
30
+ width?: InputWidth;
31
+ /** Visual validation state affecting border color and styling */
32
+ validationState?: ValidationState;
33
+ /** Placeholder text shown as disabled, selected, hidden option */
34
+ label?: string;
35
+ };
36
+ /**
37
+ * Select - Accessible select dropdown with validation state support
38
+ *
39
+ * @example
40
+ * ```tsx
41
+ * <Select>
42
+ * <SelectItem value="1">Option 1</SelectItem>
43
+ * <SelectItem value="2">Option 2</SelectItem>
44
+ * </Select>
45
+ * ```
46
+ */
47
+ declare function Select({ value, defaultValue, onChange, onFocus, onBlur, disabled, ariaLabel, id, name, children, required, size, width, validationState, label }: Readonly<SelectProps>): import("react/jsx-runtime").JSX.Element;
48
+ declare namespace Select {
49
+ var displayName: string;
50
+ }
51
+ export default Select;
52
+ //# sourceMappingURL=select.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../../src/components/forms/select/select.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAML,KAAK,eAAe,EACpB,KAAK,UAAU,EACf,KAAK,eAAe,EACrB,MAAM,4BAA4B,CAAC;AAEpC,YAAY,EAAE,eAAe,EAAE,CAAC;AAEhC,MAAM,MAAM,WAAW,GAAG;IACxB,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,4CAA4C;IAC5C,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iDAAiD;IACjD,QAAQ,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC7D,0BAA0B;IAC1B,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC3D,yBAAyB;IACzB,MAAM,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAC1D,+DAA+D;IAC/D,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,0CAA0C;IAC1C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uCAAuC;IACvC,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,8CAA8C;IAC9C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,yDAAyD;IACzD,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,mDAAmD;IACnD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,8CAA8C;IAC9C,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,uDAAuD;IACvD,KAAK,CAAC,EAAE,UAAU,CAAC;IACnB,iEAAiE;IACjE,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,kEAAkE;IAClE,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAMF;;;;;;;;;;GAUG;AACH,iBAAS,MAAM,CAAC,EACd,KAAK,EACL,YAAY,EACZ,QAAQ,EACR,OAAO,EACP,MAAM,EACN,QAAgB,EAChB,SAAS,EACT,EAAE,EACF,IAAI,EACJ,QAAQ,EACR,QAAgB,EAChB,IAAW,EACX,KAAK,EACL,eAA2B,EAC3B,KAAK,EACN,EAAE,QAAQ,CAAC,WAAW,CAAC,2CA8BvB;kBA9CQ,MAAM;;;AAkDf,eAAe,MAAM,CAAC"}