draft-components 1.0.0-beta.3.1 → 1.0.0-beta.5

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 (650) hide show
  1. package/cjs/components/alert/alert.cjs +18 -0
  2. package/cjs/components/avatar/avatar.cjs +31 -0
  3. package/cjs/components/avatar-group/avatar-group.cjs +10 -0
  4. package/cjs/components/badge/{badge.js → badge.cjs} +7 -6
  5. package/cjs/components/breadcrumbs/breadcrumbs-context.cjs +19 -0
  6. package/cjs/components/breadcrumbs/breadcrumbs-item.cjs +21 -0
  7. package/cjs/components/breadcrumbs/breadcrumbs.cjs +12 -0
  8. package/cjs/components/button/button.cjs +39 -0
  9. package/cjs/components/button/icon-button.cjs +12 -0
  10. package/cjs/components/button-group/button-group.cjs +10 -0
  11. package/cjs/components/caption/caption.cjs +27 -0
  12. package/cjs/components/caption/icons.cjs +21 -0
  13. package/cjs/components/checkbox/checkbox.cjs +16 -0
  14. package/cjs/components/date-picker/{calendar-day.js → calendar-day.cjs} +8 -7
  15. package/cjs/components/date-picker/calendar-grid-head.cjs +16 -0
  16. package/cjs/components/date-picker/calendar-grid.cjs +106 -0
  17. package/cjs/components/date-picker/calendar-header.cjs +48 -0
  18. package/cjs/components/date-picker/calendar.cjs +24 -0
  19. package/cjs/components/date-picker/{date-helpers.js → date-helpers.cjs} +30 -26
  20. package/cjs/components/date-picker/date-picker.cjs +20 -0
  21. package/cjs/components/date-picker/date-range-picker.cjs +61 -0
  22. package/cjs/components/date-picker/date-range.cjs +28 -0
  23. package/cjs/components/date-picker/icons.cjs +13 -0
  24. package/cjs/components/date-picker/{parse-min-max-props.js → parse-min-max-props.cjs} +7 -6
  25. package/cjs/components/date-picker-popover/date-picker-popover.cjs +24 -0
  26. package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.cjs +11 -0
  27. package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.cjs +35 -0
  28. package/cjs/components/date-range-picker-popover/date-range-picker-popover.cjs +59 -0
  29. package/cjs/components/date-range-picker-popover/{helpers.js → helpers.cjs} +3 -3
  30. package/cjs/components/date-range-picker-popover/{use-is-compact-view.js → use-is-compact-view.cjs} +8 -7
  31. package/cjs/components/dialog/{dialog-body.js → dialog-body.cjs} +17 -16
  32. package/cjs/components/dialog/{dialog-context.js → dialog-context.cjs} +10 -9
  33. package/cjs/components/dialog/dialog-footer.cjs +10 -0
  34. package/cjs/components/dialog/dialog-header.cjs +18 -0
  35. package/cjs/components/dialog/dialog.cjs +50 -0
  36. package/cjs/components/dialog/x-mark-icon.cjs +9 -0
  37. package/cjs/components/empty-state/empty-state.cjs +10 -0
  38. package/cjs/components/file-picker/file-picker.cjs +47 -0
  39. package/cjs/components/filter-buttons/filter-button.cjs +11 -0
  40. package/cjs/components/filter-buttons/filter-buttons.cjs +27 -0
  41. package/cjs/components/form-field/form-field.cjs +26 -0
  42. package/cjs/components/index.cjs +123 -0
  43. package/cjs/components/label/label.cjs +13 -0
  44. package/cjs/components/menu/menu-item.cjs +14 -0
  45. package/cjs/components/menu/menu-separator.cjs +10 -0
  46. package/cjs/components/menu/{menu.js → menu.cjs} +50 -52
  47. package/cjs/components/nav-list/nav-list-item.cjs +20 -0
  48. package/cjs/components/nav-list/nav-list-title.cjs +10 -0
  49. package/cjs/components/nav-list/nav-list.cjs +10 -0
  50. package/cjs/components/password-input/icons.cjs +13 -0
  51. package/cjs/components/password-input/password-input.cjs +30 -0
  52. package/cjs/components/popover/popover.cjs +97 -0
  53. package/cjs/components/popover/{use-page-click.js → use-page-click.cjs} +8 -7
  54. package/cjs/components/portal/portal-context.cjs +22 -0
  55. package/cjs/components/portal/portal.cjs +11 -0
  56. package/cjs/components/positioner/{calc-position.js → calc-position.cjs} +4 -4
  57. package/cjs/components/positioner/{positioner.js → positioner.cjs} +14 -13
  58. package/cjs/components/radio/radio.cjs +24 -0
  59. package/cjs/components/segmented-control/segmented-control-button.cjs +15 -0
  60. package/cjs/components/segmented-control/segmented-control.cjs +48 -0
  61. package/cjs/components/select/select.cjs +27 -0
  62. package/cjs/components/selection-control/selection-control.cjs +18 -0
  63. package/cjs/components/slider/slider-tick-marks.cjs +17 -0
  64. package/cjs/components/slider/{slider.js → slider.cjs} +16 -14
  65. package/cjs/components/spinner/spinner.cjs +11 -0
  66. package/cjs/components/switch/switch.cjs +15 -0
  67. package/cjs/components/table/icons.cjs +17 -0
  68. package/cjs/components/table/table-body.cjs +11 -0
  69. package/cjs/components/table/table-cell.cjs +11 -0
  70. package/cjs/components/table/table-container.cjs +23 -0
  71. package/cjs/components/table/table-head-cell.cjs +30 -0
  72. package/cjs/components/table/table-head.cjs +14 -0
  73. package/cjs/components/table/table-row.cjs +14 -0
  74. package/cjs/components/table/table.cjs +16 -0
  75. package/cjs/components/tabs/tab-list.cjs +67 -0
  76. package/cjs/components/tabs/tab-panel.cjs +16 -0
  77. package/cjs/components/tabs/tab.cjs +19 -0
  78. package/cjs/components/tabs/{tabs-context.js → tabs-context.cjs} +13 -12
  79. package/cjs/components/tabs/tabs.cjs +11 -0
  80. package/cjs/components/tag/{tag.js → tag.cjs} +7 -6
  81. package/cjs/components/text-input/text-input.cjs +26 -0
  82. package/cjs/components/textarea/textarea.cjs +40 -0
  83. package/cjs/components/toast/toast-button.cjs +11 -0
  84. package/cjs/components/toast/toast.cjs +11 -0
  85. package/cjs/components/toast/x-mark-icon.cjs +9 -0
  86. package/cjs/components/toaster/toaster.cjs +115 -0
  87. package/cjs/components/tooltip/tooltip.cjs +75 -0
  88. package/cjs/hooks/index.cjs +13 -0
  89. package/cjs/hooks/{use-disable-body-scroll.js → use-disable-body-scroll.cjs} +9 -8
  90. package/cjs/hooks/{use-esc-key-down.js → use-esc-key-down.cjs} +10 -9
  91. package/cjs/hooks/{use-focus-trap.js → use-focus-trap.cjs} +12 -11
  92. package/cjs/hooks/{use-mount-transition.js → use-mount-transition.cjs} +13 -12
  93. package/cjs/index.cjs +141 -0
  94. package/cjs/lib/{helpers.js → helpers.cjs} +4 -4
  95. package/cjs/lib/index.cjs +15 -0
  96. package/cjs/lib/{keyboard-keys.js → keyboard-keys.cjs} +5 -4
  97. package/cjs/lib/{react-helpers.js → react-helpers.cjs} +9 -8
  98. package/css/draft-components-utilities.css +4 -0
  99. package/css/draft-components.css +15 -1
  100. package/esm/components/alert/alert.js +9 -5
  101. package/esm/components/avatar/avatar.js +17 -14
  102. package/esm/components/avatar-group/avatar-group.js +7 -4
  103. package/esm/components/badge/badge.js +7 -4
  104. package/esm/components/breadcrumbs/breadcrumbs-context.js +7 -4
  105. package/esm/components/breadcrumbs/breadcrumbs-item.js +10 -7
  106. package/esm/components/breadcrumbs/breadcrumbs.js +9 -6
  107. package/esm/components/button/button.js +11 -8
  108. package/esm/components/button/icon-button.js +8 -5
  109. package/esm/components/button-group/button-group.js +7 -4
  110. package/esm/components/caption/caption.js +10 -7
  111. package/esm/components/caption/icons.js +12 -9
  112. package/esm/components/checkbox/checkbox.js +12 -9
  113. package/esm/components/date-picker/calendar-day.js +8 -5
  114. package/esm/components/date-picker/calendar-grid-head.js +8 -5
  115. package/esm/components/date-picker/calendar-grid.js +15 -12
  116. package/esm/components/date-picker/calendar-header.js +20 -16
  117. package/esm/components/date-picker/calendar.js +11 -8
  118. package/esm/components/date-picker/date-helpers.js +22 -20
  119. package/esm/components/date-picker/date-picker.js +10 -7
  120. package/esm/components/date-picker/date-range-picker.js +15 -12
  121. package/esm/components/date-picker/date-range.js +5 -2
  122. package/esm/components/date-picker/icons.js +8 -5
  123. package/esm/components/date-picker/parse-min-max-props.js +5 -2
  124. package/esm/components/date-picker-popover/date-picker-popover.js +14 -8
  125. package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.js +8 -4
  126. package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.js +12 -9
  127. package/esm/components/date-range-picker-popover/date-range-picker-popover.js +20 -13
  128. package/esm/components/date-range-picker-popover/helpers.js +3 -1
  129. package/esm/components/date-range-picker-popover/use-is-compact-view.js +6 -3
  130. package/esm/components/dialog/dialog-body.js +14 -11
  131. package/esm/components/dialog/dialog-context.js +7 -4
  132. package/esm/components/dialog/dialog-footer.js +7 -4
  133. package/esm/components/dialog/dialog-header.js +11 -7
  134. package/esm/components/dialog/dialog.js +18 -12
  135. package/esm/components/dialog/x-mark-icon.js +6 -3
  136. package/esm/components/empty-state/empty-state.js +7 -4
  137. package/esm/components/file-picker/file-picker.js +13 -9
  138. package/esm/components/filter-buttons/filter-button.js +7 -4
  139. package/esm/components/filter-buttons/filter-buttons.js +9 -6
  140. package/esm/components/form-field/form-field.js +11 -8
  141. package/esm/components/index.js +59 -37
  142. package/esm/components/label/label.js +7 -4
  143. package/esm/components/menu/menu-item.js +9 -6
  144. package/esm/components/menu/menu-separator.js +7 -4
  145. package/esm/components/menu/menu.js +24 -24
  146. package/esm/components/nav-list/nav-list-item.js +10 -7
  147. package/esm/components/nav-list/nav-list-title.js +7 -4
  148. package/esm/components/nav-list/nav-list.js +7 -4
  149. package/esm/components/password-input/icons.js +8 -5
  150. package/esm/components/password-input/password-input.js +12 -9
  151. package/esm/components/popover/popover.js +22 -21
  152. package/esm/components/popover/use-page-click.js +5 -2
  153. package/esm/components/portal/portal-context.js +5 -6
  154. package/esm/components/portal/portal.js +5 -2
  155. package/esm/components/positioner/calc-position.js +4 -2
  156. package/esm/components/positioner/positioner.js +9 -6
  157. package/esm/components/radio/radio.js +12 -9
  158. package/esm/components/segmented-control/segmented-control-button.js +7 -4
  159. package/esm/components/segmented-control/segmented-control.js +12 -9
  160. package/esm/components/select/select.js +12 -9
  161. package/esm/components/selection-control/selection-control.js +10 -7
  162. package/esm/components/slider/slider-tick-marks.js +8 -5
  163. package/esm/components/slider/slider.js +13 -10
  164. package/esm/components/spinner/spinner.js +7 -4
  165. package/esm/components/switch/switch.js +11 -8
  166. package/esm/components/table/icons.js +10 -7
  167. package/esm/components/table/table-body.js +7 -4
  168. package/esm/components/table/table-cell.js +7 -4
  169. package/esm/components/table/table-container.js +7 -4
  170. package/esm/components/table/table-head-cell.js +18 -15
  171. package/esm/components/table/table-head.js +7 -4
  172. package/esm/components/table/table-row.js +7 -4
  173. package/esm/components/table/table.js +7 -4
  174. package/esm/components/tabs/tab-list.js +14 -11
  175. package/esm/components/tabs/tab-panel.js +8 -5
  176. package/esm/components/tabs/tab.js +10 -7
  177. package/esm/components/tabs/tabs-context.js +8 -5
  178. package/esm/components/tabs/tabs.js +8 -5
  179. package/esm/components/tag/tag.js +7 -4
  180. package/esm/components/text-input/text-input.js +11 -8
  181. package/esm/components/textarea/textarea.js +20 -17
  182. package/esm/components/toast/toast-button.js +7 -4
  183. package/esm/components/toast/toast.js +8 -5
  184. package/esm/components/toast/x-mark-icon.js +6 -3
  185. package/esm/components/toaster/toaster.js +29 -46
  186. package/esm/components/tooltip/tooltip.js +22 -24
  187. package/esm/hooks/index.js +4 -4
  188. package/esm/hooks/use-disable-body-scroll.js +5 -2
  189. package/esm/hooks/use-esc-key-down.js +6 -3
  190. package/esm/hooks/use-focus-trap.js +6 -3
  191. package/esm/hooks/use-mount-transition.js +6 -3
  192. package/esm/index.js +66 -3
  193. package/esm/lib/helpers.js +4 -2
  194. package/esm/lib/index.js +3 -3
  195. package/esm/lib/keyboard-keys.js +3 -1
  196. package/esm/lib/react-helpers.js +8 -5
  197. package/package.json +21 -20
  198. package/{cjs → types}/components/alert/alert.d.ts +0 -0
  199. package/{cjs → types}/components/alert/index.d.ts +0 -0
  200. package/{cjs → types}/components/avatar/avatar.d.ts +0 -0
  201. package/{cjs → types}/components/avatar/index.d.ts +0 -0
  202. package/{cjs → types}/components/avatar-group/avatar-group.d.ts +0 -0
  203. package/{cjs → types}/components/avatar-group/index.d.ts +0 -0
  204. package/{cjs → types}/components/badge/badge.d.ts +0 -0
  205. package/{cjs → types}/components/badge/index.d.ts +0 -0
  206. package/{cjs → types}/components/breadcrumbs/breadcrumbs-context.d.ts +0 -0
  207. package/{cjs → types}/components/breadcrumbs/breadcrumbs-item.d.ts +0 -0
  208. package/{cjs → types}/components/breadcrumbs/breadcrumbs.d.ts +0 -0
  209. package/{cjs → types}/components/breadcrumbs/index.d.ts +0 -0
  210. package/{cjs → types}/components/button/button.d.ts +0 -0
  211. package/{cjs → types}/components/button/icon-button.d.ts +0 -0
  212. package/{cjs → types}/components/button/index.d.ts +0 -0
  213. package/{cjs → types}/components/button-group/button-group.d.ts +0 -0
  214. package/{cjs → types}/components/button-group/index.d.ts +0 -0
  215. package/{cjs → types}/components/caption/caption.d.ts +0 -0
  216. package/{cjs → types}/components/caption/icons.d.ts +0 -0
  217. package/{cjs → types}/components/caption/index.d.ts +0 -0
  218. package/{cjs → types}/components/checkbox/checkbox.d.ts +0 -0
  219. package/{cjs → types}/components/checkbox/index.d.ts +0 -0
  220. package/{cjs → types}/components/color-picker/color-picker-button.d.ts +0 -0
  221. package/{cjs → types}/components/color-picker/color-picker.d.ts +0 -0
  222. package/{cjs → types}/components/color-picker/index.d.ts +0 -0
  223. package/{cjs → types}/components/date-picker/calendar-day.d.ts +0 -0
  224. package/{cjs → types}/components/date-picker/calendar-grid-head.d.ts +0 -0
  225. package/{cjs → types}/components/date-picker/calendar-grid.d.ts +0 -0
  226. package/{cjs → types}/components/date-picker/calendar-header.d.ts +0 -0
  227. package/{cjs → types}/components/date-picker/calendar.d.ts +0 -0
  228. package/{cjs → types}/components/date-picker/date-helpers.d.ts +0 -0
  229. package/{cjs → types}/components/date-picker/date-picker.d.ts +0 -0
  230. package/{cjs → types}/components/date-picker/date-range-picker.d.ts +0 -0
  231. package/{cjs → types}/components/date-picker/date-range.d.ts +0 -0
  232. package/{cjs → types}/components/date-picker/icons.d.ts +0 -0
  233. package/{cjs → types}/components/date-picker/index.d.ts +0 -0
  234. package/{cjs → types}/components/date-picker/parse-min-max-props.d.ts +0 -0
  235. package/{cjs → types}/components/date-picker-popover/date-picker-popover.d.ts +0 -0
  236. package/{cjs → types}/components/date-picker-popover/index.d.ts +0 -0
  237. package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -0
  238. package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -0
  239. package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -0
  240. package/{cjs → types}/components/date-range-picker-popover/helpers.d.ts +0 -0
  241. package/{cjs → types}/components/date-range-picker-popover/index.d.ts +0 -0
  242. package/{cjs → types}/components/date-range-picker-popover/types.d.ts +0 -0
  243. package/{cjs → types}/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -0
  244. package/{cjs → types}/components/dialog/dialog-body.d.ts +0 -0
  245. package/{cjs → types}/components/dialog/dialog-context.d.ts +0 -0
  246. package/{cjs → types}/components/dialog/dialog-footer.d.ts +0 -0
  247. package/{cjs → types}/components/dialog/dialog-header.d.ts +0 -0
  248. package/{cjs → types}/components/dialog/dialog.d.ts +0 -0
  249. package/{cjs → types}/components/dialog/index.d.ts +0 -0
  250. package/{cjs → types}/components/dialog/x-mark-icon.d.ts +0 -0
  251. package/{cjs → types}/components/empty-state/empty-state.d.ts +0 -0
  252. package/{cjs → types}/components/empty-state/index.d.ts +0 -0
  253. package/{cjs → types}/components/file-picker/file-picker.d.ts +0 -0
  254. package/{cjs → types}/components/file-picker/index.d.ts +0 -0
  255. package/{cjs → types}/components/filter-buttons/filter-button.d.ts +0 -0
  256. package/{cjs → types}/components/filter-buttons/filter-buttons.d.ts +0 -0
  257. package/{cjs → types}/components/filter-buttons/index.d.ts +0 -0
  258. package/{cjs → types}/components/form-field/form-field.d.ts +0 -0
  259. package/{cjs → types}/components/form-field/index.d.ts +0 -0
  260. package/{cjs → types}/components/index.d.ts +0 -0
  261. package/{cjs → types}/components/label/index.d.ts +0 -0
  262. package/{cjs → types}/components/label/label.d.ts +0 -0
  263. package/{cjs → types}/components/menu/index.d.ts +0 -0
  264. package/{cjs → types}/components/menu/menu-item.d.ts +0 -0
  265. package/{cjs → types}/components/menu/menu-separator.d.ts +0 -0
  266. package/{cjs → types}/components/menu/menu.d.ts +0 -0
  267. package/{cjs → types}/components/nav-list/index.d.ts +0 -0
  268. package/{cjs → types}/components/nav-list/nav-list-item.d.ts +0 -0
  269. package/{cjs → types}/components/nav-list/nav-list-title.d.ts +0 -0
  270. package/{cjs → types}/components/nav-list/nav-list.d.ts +0 -0
  271. package/{cjs → types}/components/password-input/icons.d.ts +0 -0
  272. package/{cjs → types}/components/password-input/index.d.ts +0 -0
  273. package/{cjs → types}/components/password-input/password-input.d.ts +0 -0
  274. package/{cjs → types}/components/popover/index.d.ts +0 -0
  275. package/{cjs → types}/components/popover/popover.d.ts +0 -0
  276. package/{cjs → types}/components/popover/use-page-click.d.ts +0 -0
  277. package/{cjs → types}/components/portal/index.d.ts +0 -0
  278. package/{cjs → types}/components/portal/portal-context.d.ts +0 -0
  279. package/{cjs → types}/components/portal/portal.d.ts +0 -0
  280. package/{cjs → types}/components/positioner/calc-position.d.ts +0 -0
  281. package/{cjs → types}/components/positioner/index.d.ts +0 -0
  282. package/{cjs → types}/components/positioner/positioner.d.ts +0 -0
  283. package/{cjs → types}/components/positioner/types.d.ts +0 -0
  284. package/{cjs → types}/components/radio/index.d.ts +0 -0
  285. package/{cjs → types}/components/radio/radio.d.ts +0 -0
  286. package/{cjs → types}/components/segmented-control/index.d.ts +0 -0
  287. package/{cjs → types}/components/segmented-control/segmented-control-button.d.ts +0 -0
  288. package/{cjs → types}/components/segmented-control/segmented-control.d.ts +0 -0
  289. package/{cjs → types}/components/select/index.d.ts +0 -0
  290. package/{cjs → types}/components/select/select.d.ts +1 -1
  291. package/{cjs → types}/components/selection-control/index.d.ts +0 -0
  292. package/{cjs → types}/components/selection-control/selection-control.d.ts +0 -0
  293. package/{cjs → types}/components/slider/index.d.ts +0 -0
  294. package/{cjs → types}/components/slider/slider-tick-marks.d.ts +0 -0
  295. package/{cjs → types}/components/slider/slider.d.ts +0 -0
  296. package/{cjs → types}/components/spinner/index.d.ts +0 -0
  297. package/{cjs → types}/components/spinner/spinner.d.ts +0 -0
  298. package/{cjs → types}/components/switch/index.d.ts +0 -0
  299. package/{cjs → types}/components/switch/switch.d.ts +0 -0
  300. package/{cjs → types}/components/table/icons.d.ts +0 -0
  301. package/{cjs → types}/components/table/index.d.ts +0 -0
  302. package/{cjs → types}/components/table/table-body.d.ts +0 -0
  303. package/{cjs → types}/components/table/table-cell.d.ts +0 -0
  304. package/{cjs → types}/components/table/table-container.d.ts +0 -0
  305. package/{cjs → types}/components/table/table-head-cell.d.ts +0 -0
  306. package/{cjs → types}/components/table/table-head.d.ts +0 -0
  307. package/{cjs → types}/components/table/table-row.d.ts +0 -0
  308. package/{cjs → types}/components/table/table.d.ts +0 -0
  309. package/{cjs → types}/components/tabs/index.d.ts +0 -0
  310. package/{cjs → types}/components/tabs/tab-list.d.ts +0 -0
  311. package/{cjs → types}/components/tabs/tab-panel.d.ts +0 -0
  312. package/{cjs → types}/components/tabs/tab.d.ts +0 -0
  313. package/{cjs → types}/components/tabs/tabs-context.d.ts +0 -0
  314. package/{cjs → types}/components/tabs/tabs.d.ts +0 -0
  315. package/{cjs → types}/components/tabs/types.d.ts +0 -0
  316. package/{cjs → types}/components/tag/index.d.ts +0 -0
  317. package/{cjs → types}/components/tag/tag.d.ts +0 -0
  318. package/{cjs → types}/components/text-input/index.d.ts +0 -0
  319. package/{cjs → types}/components/text-input/text-input.d.ts +0 -0
  320. package/{cjs → types}/components/textarea/index.d.ts +0 -0
  321. package/{cjs → types}/components/textarea/textarea.d.ts +0 -0
  322. package/{cjs → types}/components/toast/index.d.ts +0 -0
  323. package/{cjs → types}/components/toast/toast-button.d.ts +0 -0
  324. package/{cjs → types}/components/toast/toast.d.ts +0 -0
  325. package/{cjs → types}/components/toast/x-mark-icon.d.ts +0 -0
  326. package/{cjs → types}/components/toaster/index.d.ts +0 -0
  327. package/{esm → types}/components/toaster/toaster.d.ts +5 -1
  328. package/{cjs → types}/components/tooltip/index.d.ts +0 -0
  329. package/{cjs → types}/components/tooltip/tooltip.d.ts +0 -0
  330. package/{cjs → types}/hooks/index.d.ts +0 -0
  331. package/{cjs → types}/hooks/use-disable-body-scroll.d.ts +0 -0
  332. package/{cjs → types}/hooks/use-esc-key-down.d.ts +0 -0
  333. package/{cjs → types}/hooks/use-focus-trap.d.ts +0 -0
  334. package/{cjs → types}/hooks/use-mount-transition.d.ts +0 -0
  335. package/{cjs → types}/index.d.ts +0 -0
  336. package/types/lib/helpers.d.ts +4 -0
  337. package/{cjs → types}/lib/index.d.ts +0 -0
  338. package/{cjs → types}/lib/keyboard-keys.d.ts +0 -0
  339. package/{cjs → types}/lib/react-helpers.d.ts +0 -0
  340. package/cjs/components/alert/alert.js +0 -16
  341. package/cjs/components/alert/index.js +0 -17
  342. package/cjs/components/avatar/avatar.js +0 -29
  343. package/cjs/components/avatar/index.js +0 -17
  344. package/cjs/components/avatar-group/avatar-group.js +0 -9
  345. package/cjs/components/avatar-group/index.js +0 -17
  346. package/cjs/components/badge/index.js +0 -17
  347. package/cjs/components/breadcrumbs/breadcrumbs-context.js +0 -18
  348. package/cjs/components/breadcrumbs/breadcrumbs-item.js +0 -20
  349. package/cjs/components/breadcrumbs/breadcrumbs.js +0 -11
  350. package/cjs/components/breadcrumbs/index.js +0 -18
  351. package/cjs/components/button/button.js +0 -37
  352. package/cjs/components/button/icon-button.js +0 -10
  353. package/cjs/components/button/index.js +0 -18
  354. package/cjs/components/button-group/button-group.js +0 -9
  355. package/cjs/components/button-group/index.js +0 -17
  356. package/cjs/components/caption/caption.js +0 -25
  357. package/cjs/components/caption/icons.js +0 -20
  358. package/cjs/components/caption/index.js +0 -17
  359. package/cjs/components/checkbox/checkbox.js +0 -14
  360. package/cjs/components/checkbox/index.js +0 -17
  361. package/cjs/components/color-picker/color-picker-button.js +0 -15
  362. package/cjs/components/color-picker/color-picker.js +0 -13
  363. package/cjs/components/color-picker/index.js +0 -17
  364. package/cjs/components/date-picker/calendar-grid-head.js +0 -15
  365. package/cjs/components/date-picker/calendar-grid.js +0 -105
  366. package/cjs/components/date-picker/calendar-header.js +0 -46
  367. package/cjs/components/date-picker/calendar.js +0 -23
  368. package/cjs/components/date-picker/date-picker.js +0 -19
  369. package/cjs/components/date-picker/date-range-picker.js +0 -60
  370. package/cjs/components/date-picker/date-range.js +0 -27
  371. package/cjs/components/date-picker/icons.js +0 -12
  372. package/cjs/components/date-picker/index.js +0 -18
  373. package/cjs/components/date-picker-popover/date-picker-popover.js +0 -20
  374. package/cjs/components/date-picker-popover/index.js +0 -17
  375. package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.js +0 -9
  376. package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.js +0 -34
  377. package/cjs/components/date-range-picker-popover/date-range-picker-popover.js +0 -54
  378. package/cjs/components/date-range-picker-popover/index.js +0 -18
  379. package/cjs/components/date-range-picker-popover/types.js +0 -2
  380. package/cjs/components/dialog/dialog-footer.js +0 -9
  381. package/cjs/components/dialog/dialog-header.js +0 -16
  382. package/cjs/components/dialog/dialog.js +0 -46
  383. package/cjs/components/dialog/index.js +0 -20
  384. package/cjs/components/dialog/x-mark-icon.js +0 -8
  385. package/cjs/components/empty-state/empty-state.js +0 -9
  386. package/cjs/components/empty-state/index.js +0 -17
  387. package/cjs/components/file-picker/file-picker.js +0 -44
  388. package/cjs/components/file-picker/index.js +0 -17
  389. package/cjs/components/filter-buttons/filter-button.js +0 -9
  390. package/cjs/components/filter-buttons/filter-buttons.js +0 -26
  391. package/cjs/components/filter-buttons/index.js +0 -18
  392. package/cjs/components/form-field/form-field.js +0 -25
  393. package/cjs/components/form-field/index.js +0 -17
  394. package/cjs/components/index.js +0 -53
  395. package/cjs/components/label/index.js +0 -17
  396. package/cjs/components/label/label.js +0 -11
  397. package/cjs/components/menu/index.js +0 -19
  398. package/cjs/components/menu/menu-item.js +0 -12
  399. package/cjs/components/menu/menu-separator.js +0 -9
  400. package/cjs/components/nav-list/index.js +0 -19
  401. package/cjs/components/nav-list/nav-list-item.js +0 -19
  402. package/cjs/components/nav-list/nav-list-title.js +0 -9
  403. package/cjs/components/nav-list/nav-list.js +0 -9
  404. package/cjs/components/password-input/icons.js +0 -12
  405. package/cjs/components/password-input/index.js +0 -17
  406. package/cjs/components/password-input/password-input.js +0 -28
  407. package/cjs/components/popover/index.js +0 -17
  408. package/cjs/components/popover/popover.js +0 -97
  409. package/cjs/components/portal/index.js +0 -17
  410. package/cjs/components/portal/portal-context.js +0 -26
  411. package/cjs/components/portal/portal.js +0 -10
  412. package/cjs/components/positioner/index.js +0 -17
  413. package/cjs/components/positioner/types.js +0 -2
  414. package/cjs/components/radio/index.js +0 -17
  415. package/cjs/components/radio/radio.js +0 -22
  416. package/cjs/components/segmented-control/index.js +0 -17
  417. package/cjs/components/segmented-control/segmented-control-button.js +0 -14
  418. package/cjs/components/segmented-control/segmented-control.js +0 -47
  419. package/cjs/components/select/index.js +0 -17
  420. package/cjs/components/select/select.js +0 -25
  421. package/cjs/components/selection-control/index.js +0 -17
  422. package/cjs/components/selection-control/selection-control.js +0 -17
  423. package/cjs/components/slider/index.js +0 -20
  424. package/cjs/components/slider/slider-tick-marks.js +0 -16
  425. package/cjs/components/spinner/index.js +0 -17
  426. package/cjs/components/spinner/spinner.js +0 -9
  427. package/cjs/components/switch/index.js +0 -17
  428. package/cjs/components/switch/switch.js +0 -13
  429. package/cjs/components/table/icons.js +0 -16
  430. package/cjs/components/table/index.js +0 -23
  431. package/cjs/components/table/table-body.js +0 -9
  432. package/cjs/components/table/table-cell.js +0 -9
  433. package/cjs/components/table/table-container.js +0 -21
  434. package/cjs/components/table/table-head-cell.js +0 -28
  435. package/cjs/components/table/table-head.js +0 -12
  436. package/cjs/components/table/table-row.js +0 -12
  437. package/cjs/components/table/table.js +0 -14
  438. package/cjs/components/tabs/index.js +0 -20
  439. package/cjs/components/tabs/tab-list.js +0 -66
  440. package/cjs/components/tabs/tab-panel.js +0 -15
  441. package/cjs/components/tabs/tab.js +0 -18
  442. package/cjs/components/tabs/tabs.js +0 -10
  443. package/cjs/components/tabs/types.js +0 -2
  444. package/cjs/components/tag/index.js +0 -17
  445. package/cjs/components/text-input/index.js +0 -17
  446. package/cjs/components/text-input/text-input.js +0 -24
  447. package/cjs/components/textarea/index.js +0 -17
  448. package/cjs/components/textarea/textarea.js +0 -38
  449. package/cjs/components/toast/index.js +0 -18
  450. package/cjs/components/toast/toast-button.js +0 -9
  451. package/cjs/components/toast/toast.js +0 -10
  452. package/cjs/components/toast/x-mark-icon.js +0 -8
  453. package/cjs/components/toaster/index.js +0 -17
  454. package/cjs/components/toaster/toaster.d.ts +0 -40
  455. package/cjs/components/toaster/toaster.js +0 -134
  456. package/cjs/components/tooltip/index.js +0 -17
  457. package/cjs/components/tooltip/tooltip.js +0 -79
  458. package/cjs/hooks/index.js +0 -20
  459. package/cjs/index.js +0 -19
  460. package/cjs/lib/helpers.d.ts +0 -2
  461. package/cjs/lib/index.js +0 -19
  462. package/css/draft-components-utilities.min.css +0 -1
  463. package/css/draft-components.dark.min.css +0 -1
  464. package/css/draft-components.min.css +0 -1
  465. package/esm/components/alert/alert.d.ts +0 -10
  466. package/esm/components/alert/index.d.ts +0 -1
  467. package/esm/components/alert/index.js +0 -1
  468. package/esm/components/avatar/avatar.d.ts +0 -13
  469. package/esm/components/avatar/index.d.ts +0 -1
  470. package/esm/components/avatar/index.js +0 -1
  471. package/esm/components/avatar-group/avatar-group.d.ts +0 -7
  472. package/esm/components/avatar-group/index.d.ts +0 -1
  473. package/esm/components/avatar-group/index.js +0 -1
  474. package/esm/components/badge/badge.d.ts +0 -8
  475. package/esm/components/badge/index.d.ts +0 -1
  476. package/esm/components/badge/index.js +0 -1
  477. package/esm/components/breadcrumbs/breadcrumbs-context.d.ts +0 -9
  478. package/esm/components/breadcrumbs/breadcrumbs-item.d.ts +0 -12
  479. package/esm/components/breadcrumbs/breadcrumbs.d.ts +0 -7
  480. package/esm/components/breadcrumbs/index.d.ts +0 -2
  481. package/esm/components/breadcrumbs/index.js +0 -2
  482. package/esm/components/button/button.d.ts +0 -19
  483. package/esm/components/button/icon-button.d.ts +0 -6
  484. package/esm/components/button/index.d.ts +0 -2
  485. package/esm/components/button/index.js +0 -2
  486. package/esm/components/button-group/button-group.d.ts +0 -7
  487. package/esm/components/button-group/index.d.ts +0 -1
  488. package/esm/components/button-group/index.js +0 -1
  489. package/esm/components/caption/caption.d.ts +0 -7
  490. package/esm/components/caption/icons.d.ts +0 -5
  491. package/esm/components/caption/index.d.ts +0 -1
  492. package/esm/components/caption/index.js +0 -1
  493. package/esm/components/checkbox/checkbox.d.ts +0 -10
  494. package/esm/components/checkbox/index.d.ts +0 -1
  495. package/esm/components/checkbox/index.js +0 -1
  496. package/esm/components/color-picker/color-picker-button.d.ts +0 -12
  497. package/esm/components/color-picker/color-picker-button.js +0 -11
  498. package/esm/components/color-picker/color-picker.d.ts +0 -13
  499. package/esm/components/color-picker/color-picker.js +0 -9
  500. package/esm/components/color-picker/index.d.ts +0 -1
  501. package/esm/components/color-picker/index.js +0 -1
  502. package/esm/components/date-picker/calendar-day.d.ts +0 -17
  503. package/esm/components/date-picker/calendar-grid-head.d.ts +0 -7
  504. package/esm/components/date-picker/calendar-grid.d.ts +0 -17
  505. package/esm/components/date-picker/calendar-header.d.ts +0 -12
  506. package/esm/components/date-picker/calendar.d.ts +0 -11
  507. package/esm/components/date-picker/date-helpers.d.ts +0 -22
  508. package/esm/components/date-picker/date-picker.d.ts +0 -13
  509. package/esm/components/date-picker/date-range-picker.d.ts +0 -14
  510. package/esm/components/date-picker/date-range.d.ts +0 -13
  511. package/esm/components/date-picker/icons.d.ts +0 -3
  512. package/esm/components/date-picker/index.d.ts +0 -2
  513. package/esm/components/date-picker/index.js +0 -2
  514. package/esm/components/date-picker/parse-min-max-props.d.ts +0 -8
  515. package/esm/components/date-picker-popover/date-picker-popover.d.ts +0 -13
  516. package/esm/components/date-picker-popover/index.d.ts +0 -1
  517. package/esm/components/date-picker-popover/index.js +0 -1
  518. package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -9
  519. package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -10
  520. package/esm/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -26
  521. package/esm/components/date-range-picker-popover/helpers.d.ts +0 -2
  522. package/esm/components/date-range-picker-popover/index.d.ts +0 -2
  523. package/esm/components/date-range-picker-popover/index.js +0 -2
  524. package/esm/components/date-range-picker-popover/types.d.ts +0 -10
  525. package/esm/components/date-range-picker-popover/types.js +0 -1
  526. package/esm/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -1
  527. package/esm/components/dialog/dialog-body.d.ts +0 -8
  528. package/esm/components/dialog/dialog-context.d.ts +0 -15
  529. package/esm/components/dialog/dialog-footer.d.ts +0 -5
  530. package/esm/components/dialog/dialog-header.d.ts +0 -8
  531. package/esm/components/dialog/dialog.d.ts +0 -12
  532. package/esm/components/dialog/index.d.ts +0 -4
  533. package/esm/components/dialog/index.js +0 -4
  534. package/esm/components/dialog/x-mark-icon.d.ts +0 -2
  535. package/esm/components/empty-state/empty-state.d.ts +0 -11
  536. package/esm/components/empty-state/index.d.ts +0 -1
  537. package/esm/components/empty-state/index.js +0 -1
  538. package/esm/components/file-picker/file-picker.d.ts +0 -13
  539. package/esm/components/file-picker/index.d.ts +0 -1
  540. package/esm/components/file-picker/index.js +0 -1
  541. package/esm/components/filter-buttons/filter-button.d.ts +0 -7
  542. package/esm/components/filter-buttons/filter-buttons.d.ts +0 -5
  543. package/esm/components/filter-buttons/index.d.ts +0 -2
  544. package/esm/components/filter-buttons/index.js +0 -2
  545. package/esm/components/form-field/form-field.d.ts +0 -15
  546. package/esm/components/form-field/index.d.ts +0 -1
  547. package/esm/components/form-field/index.js +0 -1
  548. package/esm/components/index.d.ts +0 -37
  549. package/esm/components/label/index.d.ts +0 -1
  550. package/esm/components/label/index.js +0 -1
  551. package/esm/components/label/label.d.ts +0 -5
  552. package/esm/components/menu/index.d.ts +0 -3
  553. package/esm/components/menu/index.js +0 -3
  554. package/esm/components/menu/menu-item.d.ts +0 -11
  555. package/esm/components/menu/menu-separator.d.ts +0 -6
  556. package/esm/components/menu/menu.d.ts +0 -31
  557. package/esm/components/nav-list/index.d.ts +0 -3
  558. package/esm/components/nav-list/index.js +0 -3
  559. package/esm/components/nav-list/nav-list-item.d.ts +0 -13
  560. package/esm/components/nav-list/nav-list-title.d.ts +0 -8
  561. package/esm/components/nav-list/nav-list.d.ts +0 -5
  562. package/esm/components/password-input/icons.d.ts +0 -3
  563. package/esm/components/password-input/index.d.ts +0 -1
  564. package/esm/components/password-input/index.js +0 -1
  565. package/esm/components/password-input/password-input.d.ts +0 -10
  566. package/esm/components/popover/index.d.ts +0 -1
  567. package/esm/components/popover/index.js +0 -1
  568. package/esm/components/popover/popover.d.ts +0 -49
  569. package/esm/components/popover/use-page-click.d.ts +0 -16
  570. package/esm/components/portal/index.d.ts +0 -1
  571. package/esm/components/portal/index.js +0 -1
  572. package/esm/components/portal/portal-context.d.ts +0 -6
  573. package/esm/components/portal/portal.d.ts +0 -5
  574. package/esm/components/positioner/calc-position.d.ts +0 -32
  575. package/esm/components/positioner/index.d.ts +0 -1
  576. package/esm/components/positioner/index.js +0 -1
  577. package/esm/components/positioner/positioner.d.ts +0 -20
  578. package/esm/components/positioner/types.d.ts +0 -14
  579. package/esm/components/positioner/types.js +0 -1
  580. package/esm/components/radio/index.d.ts +0 -1
  581. package/esm/components/radio/index.js +0 -1
  582. package/esm/components/radio/radio.d.ts +0 -11
  583. package/esm/components/segmented-control/index.d.ts +0 -1
  584. package/esm/components/segmented-control/index.js +0 -1
  585. package/esm/components/segmented-control/segmented-control-button.d.ts +0 -10
  586. package/esm/components/segmented-control/segmented-control.d.ts +0 -15
  587. package/esm/components/select/index.d.ts +0 -1
  588. package/esm/components/select/index.js +0 -1
  589. package/esm/components/select/select.d.ts +0 -46
  590. package/esm/components/selection-control/index.d.ts +0 -1
  591. package/esm/components/selection-control/index.js +0 -1
  592. package/esm/components/selection-control/selection-control.d.ts +0 -14
  593. package/esm/components/slider/index.d.ts +0 -2
  594. package/esm/components/slider/index.js +0 -2
  595. package/esm/components/slider/slider-tick-marks.d.ts +0 -7
  596. package/esm/components/slider/slider.d.ts +0 -17
  597. package/esm/components/spinner/index.d.ts +0 -1
  598. package/esm/components/spinner/index.js +0 -1
  599. package/esm/components/spinner/spinner.d.ts +0 -7
  600. package/esm/components/switch/index.d.ts +0 -1
  601. package/esm/components/switch/index.js +0 -1
  602. package/esm/components/switch/switch.d.ts +0 -10
  603. package/esm/components/table/icons.d.ts +0 -4
  604. package/esm/components/table/index.d.ts +0 -7
  605. package/esm/components/table/index.js +0 -7
  606. package/esm/components/table/table-body.d.ts +0 -5
  607. package/esm/components/table/table-cell.d.ts +0 -5
  608. package/esm/components/table/table-container.d.ts +0 -13
  609. package/esm/components/table/table-head-cell.d.ts +0 -10
  610. package/esm/components/table/table-head.d.ts +0 -7
  611. package/esm/components/table/table-row.d.ts +0 -7
  612. package/esm/components/table/table.d.ts +0 -11
  613. package/esm/components/tabs/index.d.ts +0 -4
  614. package/esm/components/tabs/index.js +0 -4
  615. package/esm/components/tabs/tab-list.d.ts +0 -3
  616. package/esm/components/tabs/tab-panel.d.ts +0 -6
  617. package/esm/components/tabs/tab.d.ts +0 -7
  618. package/esm/components/tabs/tabs-context.d.ts +0 -20
  619. package/esm/components/tabs/tabs.d.ts +0 -7
  620. package/esm/components/tabs/types.d.ts +0 -2
  621. package/esm/components/tabs/types.js +0 -1
  622. package/esm/components/tag/index.d.ts +0 -1
  623. package/esm/components/tag/index.js +0 -1
  624. package/esm/components/tag/tag.d.ts +0 -13
  625. package/esm/components/text-input/index.d.ts +0 -1
  626. package/esm/components/text-input/index.js +0 -1
  627. package/esm/components/text-input/text-input.d.ts +0 -21
  628. package/esm/components/textarea/index.d.ts +0 -1
  629. package/esm/components/textarea/index.js +0 -1
  630. package/esm/components/textarea/textarea.d.ts +0 -20
  631. package/esm/components/toast/index.d.ts +0 -2
  632. package/esm/components/toast/index.js +0 -2
  633. package/esm/components/toast/toast-button.d.ts +0 -5
  634. package/esm/components/toast/toast.d.ts +0 -11
  635. package/esm/components/toast/x-mark-icon.d.ts +0 -2
  636. package/esm/components/toaster/index.d.ts +0 -1
  637. package/esm/components/toaster/index.js +0 -1
  638. package/esm/components/tooltip/index.d.ts +0 -1
  639. package/esm/components/tooltip/index.js +0 -1
  640. package/esm/components/tooltip/tooltip.d.ts +0 -25
  641. package/esm/hooks/index.d.ts +0 -4
  642. package/esm/hooks/use-disable-body-scroll.d.ts +0 -5
  643. package/esm/hooks/use-esc-key-down.d.ts +0 -17
  644. package/esm/hooks/use-focus-trap.d.ts +0 -15
  645. package/esm/hooks/use-mount-transition.d.ts +0 -32
  646. package/esm/index.d.ts +0 -3
  647. package/esm/lib/helpers.d.ts +0 -2
  648. package/esm/lib/index.d.ts +0 -3
  649. package/esm/lib/keyboard-keys.d.ts +0 -14
  650. package/esm/lib/react-helpers.d.ts +0 -13
@@ -1,23 +1,25 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { KeyboardKeys } from '../../lib/keyboard-keys';
3
- import { Children, cloneElement, isValidElement, useId, useState, } from 'react';
4
- import { classNames, focusElement } from '../../lib/react-helpers';
5
- import { assertIfNullable } from '../../lib/helpers';
6
- import { Button, } from '../button';
7
- import { Popover, } from '../popover';
8
- import { MenuItem } from './menu-item';
9
- export function Menu({ defaultIsOpen = false, placement = 'bottom', alignment = 'start', buttonAppearance = 'default', buttonVariant = 'filled', button, className, children, onOpen, onClose, onKeyDown, ...props }) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { KeyboardKeys } from '../../lib/keyboard-keys.js';
3
+ import { useId, useState, Children, cloneElement, isValidElement } from 'react';
4
+ import { classNames, focusElement } from '../../lib/react-helpers.js';
5
+ import { assertIfNullable } from '../../lib/helpers.js';
6
+ import { Button } from '../button/button.js';
7
+ import '../button/icon-button.js';
8
+ import { Popover } from '../popover/popover.js';
9
+ import { MenuItem } from './menu-item.js';
10
+
11
+ function Menu({ defaultIsOpen = false, placement = 'bottom', alignment = 'start', buttonAppearance = 'default', buttonVariant = 'filled', button, className, children, onOpen, onClose, onKeyDown, ...props }) {
10
12
  const id = useId();
11
13
  const menuId = props.id || id;
12
14
  const buttonId = `menu-button-${menuId}`;
13
15
  const [isOpen, setIsOpen] = useState(defaultIsOpen);
14
16
  const openMenu = () => {
15
17
  setIsOpen(true);
16
- onOpen === null || onOpen === void 0 ? void 0 : onOpen();
18
+ onOpen?.();
17
19
  };
18
20
  const closeMenu = () => {
19
21
  setIsOpen(false);
20
- onClose === null || onClose === void 0 ? void 0 : onClose();
22
+ onClose?.();
21
23
  };
22
24
  const focusMenuButton = () => {
23
25
  const menuButton = document.getElementById(buttonId);
@@ -63,9 +65,7 @@ export function Menu({ defaultIsOpen = false, placement = 'bottom', alignment =
63
65
  if (el.textContent) {
64
66
  return el.textContent[0].toLowerCase();
65
67
  }
66
- else {
67
- return '';
68
- }
68
+ return '';
69
69
  });
70
70
  const activeMenuItemIndex = menuItems.findIndex((el) => el === document.activeElement);
71
71
  let fromIndex = activeMenuItemIndex + 1;
@@ -139,38 +139,36 @@ export function Menu({ defaultIsOpen = false, placement = 'bottom', alignment =
139
139
  event.preventDefault();
140
140
  event.stopPropagation();
141
141
  }
142
- onKeyDown === null || onKeyDown === void 0 ? void 0 : onKeyDown(event);
142
+ onKeyDown?.(event);
143
143
  };
144
144
  const renderAnchor = ({ ref }) => {
145
145
  if (typeof button === 'function') {
146
146
  return button({
147
147
  ref,
148
- id: buttonId,
148
+ 'id': buttonId,
149
149
  'aria-haspopup': true,
150
150
  'aria-expanded': isOpen,
151
151
  'aria-controls': menuId,
152
- onClick: handleButtonClick,
153
- onKeyDown: handleButtonKeyDown,
152
+ 'onClick': handleButtonClick,
153
+ 'onKeyDown': handleButtonKeyDown,
154
154
  }, {
155
155
  isOpen,
156
156
  openMenu,
157
157
  closeMenu,
158
158
  });
159
159
  }
160
- return (_jsx(Button, { ref: ref, id: buttonId, "aria-haspopup": true, "aria-expanded": isOpen, "aria-controls": menuId, onClick: handleButtonClick, onKeyDown: handleButtonKeyDown, appearance: buttonAppearance, variant: buttonVariant, children: button }));
160
+ return (jsx(Button, { ref: ref, id: buttonId, "aria-haspopup": true, "aria-expanded": isOpen, "aria-controls": menuId, onClick: handleButtonClick, onKeyDown: handleButtonKeyDown, appearance: buttonAppearance, variant: buttonVariant, children: button }));
161
161
  };
162
- return (_jsx(Popover, { className: "dc-menu__container", placement: placement, alignment: alignment, anchor: renderAnchor, isOpen: isOpen, onClose: closeMenu, children: _jsx("ul", { ...props, className: classNames('dc-menu', className), role: "menu", id: menuId, "aria-labelledby": buttonId, onKeyDown: handleMenuKeyDown, children: Children.map(children, (child) => {
162
+ return (jsx(Popover, { className: "dc-menu__container", placement: placement, alignment: alignment, anchor: renderAnchor, isOpen: isOpen, onClose: closeMenu, children: jsx("ul", { ...props, className: classNames('dc-menu', className), role: "menu", id: menuId, "aria-labelledby": buttonId, onKeyDown: handleMenuKeyDown, children: Children.map(children, (child) => {
163
163
  if (isMenuItem(child)) {
164
164
  const props = child.props;
165
165
  const onClick = (event) => {
166
- var _a;
167
- (_a = props.onClick) === null || _a === void 0 ? void 0 : _a.call(props, event);
166
+ props.onClick?.(event);
168
167
  closeMenu();
169
168
  };
170
169
  const onMouseEnter = (event) => {
171
- var _a;
172
170
  focusElement(event.currentTarget);
173
- (_a = props.onMouseEnter) === null || _a === void 0 ? void 0 : _a.call(props, event);
171
+ props.onMouseEnter?.(event);
174
172
  };
175
173
  return cloneElement(child, { onClick, onMouseEnter });
176
174
  }
@@ -188,3 +186,5 @@ function getMenuItems(menuId) {
188
186
  const nodes = menuEl.querySelectorAll('button[role="menuitem"]');
189
187
  return Array.from(nodes);
190
188
  }
189
+
190
+ export { Menu };
@@ -1,15 +1,18 @@
1
- import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { classNames } from '../../lib/react-helpers';
3
- import { Badge } from '../badge';
4
- export function NavListItem({ className, icon, badge, children, renderAs, ...props }) {
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+ import { Badge } from '../badge/badge.js';
4
+
5
+ function NavListItem({ className, icon, badge, children, renderAs, ...props }) {
5
6
  className = classNames(className, 'dc-nav-link');
6
- children = (_jsxs(_Fragment, { children: [icon != null && _jsxs("div", { className: "dc-nav-link__icon", children: [icon, " "] }), _jsx("div", { className: "dc-nav-link__text", children: children }), badge != null && _jsxs(_Fragment, { children: ["\u00A0", _jsx(Badge, { className: "dc-nav-link__badge", children: badge })] })] }));
7
+ children = (jsxs(Fragment, { children: [icon != null && jsxs("div", { className: "dc-nav-link__icon", children: [icon, " "] }), jsx("div", { className: "dc-nav-link__text", children: children }), badge != null && jsxs(Fragment, { children: ["\u00A0", jsx(Badge, { className: "dc-nav-link__badge", children: badge })] })] }));
7
8
  let content;
8
9
  if (typeof renderAs === 'function') {
9
10
  content = renderAs({ className, children });
10
11
  }
11
12
  else {
12
- content = _jsx("a", { ...props, className: className, children: children });
13
+ content = jsx("a", { ...props, className: className, children: children });
13
14
  }
14
- return _jsx("li", { className: "dc-nav-list__item", children: content });
15
+ return jsx("li", { className: "dc-nav-list__item", children: content });
15
16
  }
17
+
18
+ export { NavListItem };
@@ -1,5 +1,8 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { classNames } from '../../lib/react-helpers';
3
- export function NavListTitle({ className, children, ...props }) {
4
- return (_jsx("li", { ...props, className: classNames('dc-nav-list__title', className), children: children }));
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+
4
+ function NavListTitle({ className, children, ...props }) {
5
+ return (jsx("li", { ...props, className: classNames('dc-nav-list__title', className), children: children }));
5
6
  }
7
+
8
+ export { NavListTitle };
@@ -1,5 +1,8 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { classNames } from '../../lib/react-helpers';
3
- export function NavList({ className, children, ...props }) {
4
- return (_jsx("nav", { ...props, className: classNames('dc-nav-list', className), children: _jsx("ul", { className: "dc-nav-list__items", children: children }) }));
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+
4
+ function NavList({ className, children, ...props }) {
5
+ return (jsx("nav", { ...props, className: classNames('dc-nav-list', className), children: jsx("ul", { className: "dc-nav-list__items", children: children }) }));
5
6
  }
7
+
8
+ export { NavList };
@@ -1,7 +1,10 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- export function EyeIcon(props) {
3
- return (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", strokeWidth: 1.5, stroke: "currentColor", ...props, children: [_jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M2.036 12.322a1.012 1.012 0 010-.639C3.423 7.51 7.36 4.5 12 4.5c4.638 0 8.573 3.007 9.963 7.178.07.207.07.431 0 .639C20.577 16.49 16.64 19.5 12 19.5c-4.638 0-8.573-3.007-9.963-7.178z" }), _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M15 12a3 3 0 11-6 0 3 3 0 016 0z" })] }));
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+
3
+ function EyeIcon(props) {
4
+ return (jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", strokeWidth: 1.5, stroke: "currentColor", ...props, children: [jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M2.036 12.322a1.012 1.012 0 010-.639C3.423 7.51 7.36 4.5 12 4.5c4.638 0 8.573 3.007 9.963 7.178.07.207.07.431 0 .639C20.577 16.49 16.64 19.5 12 19.5c-4.638 0-8.573-3.007-9.963-7.178z" }), jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M15 12a3 3 0 11-6 0 3 3 0 016 0z" })] }));
4
5
  }
5
- export function EyeSlashIcon(props) {
6
- return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", strokeWidth: 1.5, stroke: "currentColor", ...props, children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88" }) }));
6
+ function EyeSlashIcon(props) {
7
+ return (jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", strokeWidth: 1.5, stroke: "currentColor", ...props, children: jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M3.98 8.223A10.477 10.477 0 001.934 12C3.226 16.338 7.244 19.5 12 19.5c.993 0 1.953-.138 2.863-.395M6.228 6.228A10.45 10.45 0 0112 4.5c4.756 0 8.773 3.162 10.065 7.498a10.523 10.523 0 01-4.293 5.774M6.228 6.228L3 3m3.228 3.228l3.65 3.65m7.894 7.894L21 21m-3.228-3.228l-3.65-3.65m0 0a3 3 0 10-4.243-4.243m4.242 4.242L9.88 9.88" }) }));
7
8
  }
9
+
10
+ export { EyeIcon, EyeSlashIcon };
@@ -1,10 +1,11 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { forwardRef, useState, } from 'react';
3
- import { classNames } from '../../lib/react-helpers';
4
- import { TextInput } from '../text-input';
5
- import { Tooltip } from '../tooltip';
6
- import { EyeIcon, EyeSlashIcon } from './icons';
7
- export const PasswordInput = forwardRef(function PasswordInput({ isDefaultVisible = false, showPasswordTitle = 'Show password', hidePasswordTitle = 'Hide password', className, ...props }, ref) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { forwardRef, useState } from 'react';
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+ import { TextInput } from '../text-input/text-input.js';
5
+ import { Tooltip } from '../tooltip/tooltip.js';
6
+ import { EyeIcon, EyeSlashIcon } from './icons.js';
7
+
8
+ const PasswordInput = forwardRef(function PasswordInput({ isDefaultVisible = false, showPasswordTitle = 'Show password', hidePasswordTitle = 'Hide password', className, ...props }, ref) {
8
9
  const [visible, setVisible] = useState(isDefaultVisible);
9
10
  let type;
10
11
  let content;
@@ -20,6 +21,8 @@ export const PasswordInput = forwardRef(function PasswordInput({ isDefaultVisibl
20
21
  Icon = EyeSlashIcon;
21
22
  }
22
23
  const handleButtonClick = () => setVisible(!visible);
23
- const button = (_jsx(Tooltip, { content: content, children: _jsx("button", { className: "dc-password-input__btn", type: "button", onClick: handleButtonClick, children: _jsx(Icon, { className: "dc-password-input__icon", "aria-hidden": true }) }) }));
24
- return (_jsx(TextInput, { ...props, className: classNames('dc-password-input', className), ref: ref, type: type, suffix: button }));
24
+ const button = (jsx(Tooltip, { content: content, children: jsx("button", { className: "dc-password-input__btn", type: "button", onClick: handleButtonClick, children: jsx(Icon, { className: "dc-password-input__icon", "aria-hidden": true }) }) }));
25
+ return (jsx(TextInput, { ...props, className: classNames('dc-password-input', className), ref: ref, type: type, suffix: button }));
25
26
  });
27
+
28
+ export { PasswordInput };
@@ -1,17 +1,17 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { cloneElement, forwardRef, useCallback, useImperativeHandle, useRef, useState, } from 'react';
3
- import { classNames, focusElement, isReactElementWithRef, mergeRefs, } from '../../lib/react-helpers';
4
- import { useMountTransition } from '../../hooks/use-mount-transition';
5
- import { useEscKeyDown } from '../../hooks/use-esc-key-down';
6
- import { useFocusTrap } from '../../hooks/use-focus-trap';
7
- import { usePageClick } from './use-page-click';
8
- import { Positioner, } from '../positioner';
9
- export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocusAnchorAfterEscPress = true, placement = 'bottom', alignment = 'start', anchorGap, viewportGap, anchor, className, children, onOpen, onClose, ...props }, ref) {
10
- var _a, _b;
11
- const [defaultIsOpen, setDefaultIsOpen] = useState((_a = props.defaultIsOpen) !== null && _a !== void 0 ? _a : false);
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { forwardRef, useState, useRef, useCallback, useImperativeHandle, cloneElement } from 'react';
3
+ import { focusElement, mergeRefs, isReactElementWithRef, classNames } from '../../lib/react-helpers.js';
4
+ import { useMountTransition } from '../../hooks/use-mount-transition.js';
5
+ import { useEscKeyDown } from '../../hooks/use-esc-key-down.js';
6
+ import { useFocusTrap } from '../../hooks/use-focus-trap.js';
7
+ import { usePageClick } from './use-page-click.js';
8
+ import { Positioner } from '../positioner/positioner.js';
9
+
10
+ const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocusAnchorAfterEscPress = true, placement = 'bottom', alignment = 'start', anchorGap, viewportGap, anchor, className, children, onOpen, onClose, ...props }, ref) {
11
+ const [defaultIsOpen, setDefaultIsOpen] = useState(props.defaultIsOpen ?? false);
12
12
  const anchorRef = useRef(null);
13
13
  const contentRef = useRef(null);
14
- const isOpen = (_b = props.isOpen) !== null && _b !== void 0 ? _b : defaultIsOpen;
14
+ const isOpen = props.isOpen ?? defaultIsOpen;
15
15
  const durationMs = 100;
16
16
  const { isMounted, className: transitionClass } = useMountTransition({
17
17
  durationMs,
@@ -21,11 +21,11 @@ export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, sho
21
21
  });
22
22
  const openPopover = useCallback(() => {
23
23
  setDefaultIsOpen(true);
24
- onOpen === null || onOpen === void 0 ? void 0 : onOpen();
24
+ onOpen?.();
25
25
  }, [onOpen]);
26
26
  const closePopover = useCallback(() => {
27
27
  setDefaultIsOpen(false);
28
- onClose === null || onClose === void 0 ? void 0 : onClose();
28
+ onClose?.();
29
29
  }, [onClose]);
30
30
  const togglePopover = useCallback(() => {
31
31
  if (isOpen) {
@@ -45,8 +45,8 @@ export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, sho
45
45
  const anchor = anchorRef.current;
46
46
  const content = contentRef.current;
47
47
  if (target instanceof Node &&
48
- !(anchor === null || anchor === void 0 ? void 0 : anchor.contains(target)) &&
49
- !(content === null || content === void 0 ? void 0 : content.contains(target))) {
48
+ !anchor?.contains(target) &&
49
+ !content?.contains(target)) {
50
50
  closePopover();
51
51
  }
52
52
  }, { isEnabled: isOpen });
@@ -72,9 +72,8 @@ export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, sho
72
72
  return cloneElement(anchor, {
73
73
  ref: mergeRefs(setRef, anchorRef, anchor.ref),
74
74
  onClick: (event) => {
75
- var _a, _b;
76
75
  togglePopover();
77
- (_b = (_a = anchor.props).onClick) === null || _b === void 0 ? void 0 : _b.call(_a, event);
76
+ anchor.props.onClick?.(event);
78
77
  },
79
78
  });
80
79
  }
@@ -84,11 +83,13 @@ export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, sho
84
83
  if (isOpen || isMounted) {
85
84
  delete props.defaultIsOpen;
86
85
  delete props.isOpen;
87
- return (_jsx("div", { ref: portalRef, style: {
86
+ return (jsx("div", { ref: portalRef, style: {
88
87
  '--dc-popover-transition-duration': `${durationMs}ms`,
89
88
  ...portalStyle,
90
- }, className: classNames('dc-popover', transitionClass), children: _jsx("div", { ...props, ref: contentRef, className: classNames('dc-popover-modal', className), children: children }) }));
89
+ }, className: classNames('dc-popover', transitionClass), children: jsx("div", { ...props, ref: contentRef, className: classNames('dc-popover-modal', className), children: children }) }));
91
90
  }
92
91
  };
93
- return (_jsx(Positioner, { position: "absolute", placement: placement, alignment: alignment, anchorGap: anchorGap, viewportGap: viewportGap, renderAnchor: renderAnchor, renderContent: renderContent }));
92
+ return (jsx(Positioner, { position: "absolute", placement: placement, alignment: alignment, anchorGap: anchorGap, viewportGap: viewportGap, renderAnchor: renderAnchor, renderContent: renderContent }));
94
93
  });
94
+
95
+ export { Popover };
@@ -1,4 +1,5 @@
1
- import { useEffect, useRef } from 'react';
1
+ import { useRef, useEffect } from 'react';
2
+
2
3
  const handlers = [];
3
4
  /**
4
5
  * Invokes a given handler when the user clicks on any place on the page.
@@ -10,7 +11,7 @@ const handlers = [];
10
11
  * @param options.isEnabled - A flag that determines whether to run
11
12
  * the passed handler or not.
12
13
  */
13
- export function usePageClick(handler, options) {
14
+ function usePageClick(handler, options) {
14
15
  const handlerRef = useRef(handler);
15
16
  const isEnabled = options.isEnabled;
16
17
  useEffect(() => {
@@ -44,3 +45,5 @@ export function usePageClick(handler, options) {
44
45
  };
45
46
  }, [isEnabled]);
46
47
  }
48
+
49
+ export { usePageClick };
@@ -1,5 +1,6 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
1
+ import 'react/jsx-runtime';
2
2
  import { createContext, useContext } from 'react';
3
+
3
4
  let root = null;
4
5
  const getPortalRoot = () => {
5
6
  if (root == null) {
@@ -11,11 +12,9 @@ const getPortalRoot = () => {
11
12
  return root;
12
13
  };
13
14
  const PortalContext = createContext(getPortalRoot);
14
- export function usePortalRoot() {
15
+ function usePortalRoot() {
15
16
  const getRoot = useContext(PortalContext);
16
17
  return getRoot();
17
18
  }
18
- export function PortalRootProvider(props) {
19
- const { getPortalRoot, children } = props;
20
- return (_jsx(PortalContext.Provider, { value: getPortalRoot, children: children }));
21
- }
19
+
20
+ export { usePortalRoot };
@@ -1,6 +1,9 @@
1
1
  import { createPortal } from 'react-dom';
2
- import { usePortalRoot } from './portal-context';
3
- export function Portal({ children }) {
2
+ import { usePortalRoot } from './portal-context.js';
3
+
4
+ function Portal({ children }) {
4
5
  const container = usePortalRoot();
5
6
  return createPortal(children, container);
6
7
  }
8
+
9
+ export { Portal };
@@ -1,4 +1,4 @@
1
- export function calcPosition({ placement, alignment, anchorRect, contentRect, viewportWidth, viewportHeight, scrollX, scrollY, anchorGap, viewportGap, }) {
1
+ function calcPosition({ placement, alignment, anchorRect, contentRect, viewportWidth, viewportHeight, scrollX, scrollY, anchorGap, viewportGap, }) {
2
2
  const maxWidth = viewportWidth - (2 * viewportGap);
3
3
  const maxSideWidth = Math.max(anchorRect.left - anchorGap - viewportGap, viewportWidth - anchorRect.right - anchorGap - viewportGap);
4
4
  if ((placement === 'left' || placement === 'right') &&
@@ -88,7 +88,7 @@ function getXAxisOffset({ alignment, viewportGap, scrollX, anchorX, viewportWidt
88
88
  }
89
89
  return x;
90
90
  }
91
- export function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewportHeight, contentHeight, anchorHeight, }) {
91
+ function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewportHeight, contentHeight, anchorHeight, }) {
92
92
  const anchorBottom = viewportHeight - anchorY + anchorHeight;
93
93
  const top = scrollY + anchorY - anchorGap - contentHeight;
94
94
  const bottom = scrollY + anchorY + anchorHeight + anchorGap;
@@ -110,3 +110,5 @@ export function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewpor
110
110
  }
111
111
  return { offset: y, placement };
112
112
  }
113
+
114
+ export { calcPosition, getYAxisOffset };
@@ -1,8 +1,9 @@
1
- import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useLayoutEffect, useState, } from 'react';
3
- import { calcPosition } from './calc-position';
4
- import { Portal } from '../portal';
5
- export function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed', placement = 'bottom', alignment = 'start', renderAnchor, renderContent, }) {
1
+ import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
2
+ import { useState, useLayoutEffect } from 'react';
3
+ import { calcPosition } from './calc-position.js';
4
+ import { Portal } from '../portal/portal.js';
5
+
6
+ function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed', placement = 'bottom', alignment = 'start', renderAnchor, renderContent, }) {
6
7
  const [anchor, setAnchor] = useState(null);
7
8
  const [content, setContent] = useState(null);
8
9
  useLayoutEffect(() => {
@@ -34,7 +35,7 @@ export function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed',
34
35
  window.removeEventListener('scroll', calcContentPosition);
35
36
  };
36
37
  }, [anchor, content, position, placement, alignment, anchorGap, viewportGap]);
37
- return (_jsxs(_Fragment, { children: [renderAnchor({ setRef: setAnchor }), _jsx(Portal, { children: renderContent({
38
+ return (jsxs(Fragment, { children: [renderAnchor({ setRef: setAnchor }), jsx(Portal, { children: renderContent({
38
39
  setRef: setContent,
39
40
  style: {
40
41
  position,
@@ -57,3 +58,5 @@ function getRect(element) {
57
58
  bottom: top + height,
58
59
  };
59
60
  }
61
+
62
+ export { Positioner };
@@ -1,7 +1,10 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
- import { classNames } from '../../lib/react-helpers';
4
- export const Radio = forwardRef(function Radio({ icon = 'dot', style = {}, className = '', onChange, onToggle, ...props }, ref) {
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+
5
+ const checkIcon = (jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "24", height: "24", className: "dc-radio__icon", "data-testid": "radio-check-icon", children: jsx("path", { d: "M7 12.7222L11 16.5L17 8", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
6
+ const dotIcon = (jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "24", height: "24", className: "dc-radio__icon", "data-testid": "radio-dot-icon", children: jsx("circle", { cx: "12", cy: "12", r: "5", fill: "currentColor" }) }));
7
+ const Radio = forwardRef(function Radio({ icon = 'dot', style = {}, className = '', onChange, onToggle, ...props }, ref) {
5
8
  let renderedIcon;
6
9
  switch (icon) {
7
10
  case 'check':
@@ -10,10 +13,10 @@ export const Radio = forwardRef(function Radio({ icon = 'dot', style = {}, class
10
13
  default:
11
14
  renderedIcon = dotIcon;
12
15
  }
13
- return (_jsxs("label", { style: style, className: classNames('dc-radio', className), children: [_jsx("input", { ...props, ref: ref, type: "radio", className: "dc-radio__input", onChange: (event) => {
14
- onChange === null || onChange === void 0 ? void 0 : onChange(event);
15
- onToggle === null || onToggle === void 0 ? void 0 : onToggle(event.target.checked);
16
- } }), _jsx("span", { className: "dc-radio__check", "data-testid": "radio-check", "aria-hidden": true, children: renderedIcon })] }));
16
+ return (jsxs("label", { style: style, className: classNames('dc-radio', className), children: [jsx("input", { ...props, ref: ref, type: "radio", className: "dc-radio__input", onChange: (event) => {
17
+ onChange?.(event);
18
+ onToggle?.(event.target.checked);
19
+ } }), jsx("span", { className: "dc-radio__check", "data-testid": "radio-check", "aria-hidden": true, children: renderedIcon })] }));
17
20
  });
18
- const checkIcon = (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "24", height: "24", className: "dc-radio__icon", "data-testid": "radio-check-icon", children: _jsx("path", { d: "M7 12.7222L11 16.5L17 8", fill: "none", stroke: "currentColor", strokeWidth: "2.5", strokeLinecap: "round", strokeLinejoin: "round" }) }));
19
- const dotIcon = (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "24", height: "24", className: "dc-radio__icon", "data-testid": "radio-dot-icon", children: _jsx("circle", { cx: "12", cy: "12", r: "5", fill: "currentColor" }) }));
21
+
22
+ export { Radio };
@@ -1,10 +1,13 @@
1
- import { jsxs as _jsxs } from "react/jsx-runtime";
2
- import { classNames } from '../../lib/react-helpers';
3
- export function SegmentedControlButton({ className, checked, icon, children, value, onChangeValue, }) {
1
+ import { jsxs } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+
4
+ function SegmentedControlButton({ className, checked, icon, children, value, onChangeValue, }) {
4
5
  function handleClick() {
5
6
  if (!checked) {
6
7
  onChangeValue(value);
7
8
  }
8
9
  }
9
- return (_jsxs("li", { className: classNames(className, 'dc-segmented__button'), role: "radio", "data-value": value, "aria-checked": checked, tabIndex: checked ? 0 : -1, onClick: handleClick, children: [icon, children] }));
10
+ return (jsxs("li", { className: classNames(className, 'dc-segmented__button'), role: "radio", "data-value": value, "aria-checked": checked, tabIndex: checked ? 0 : -1, onClick: handleClick, children: [icon, children] }));
10
11
  }
12
+
13
+ export { SegmentedControlButton };
@@ -1,10 +1,11 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { useRef, } from 'react';
3
- import { KeyboardKeys } from '../../lib/keyboard-keys';
4
- import { assertIfNullable } from '../../lib/helpers';
5
- import { classNames, focusElement } from '../../lib/react-helpers';
6
- import { SegmentedControlButton } from './segmented-control-button';
7
- export function SegmentedControl({ size = 'md', disabled = false, className, value, options, onChangeValue, ...props }) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useRef } from 'react';
3
+ import { KeyboardKeys } from '../../lib/keyboard-keys.js';
4
+ import { assertIfNullable } from '../../lib/helpers.js';
5
+ import { classNames, focusElement } from '../../lib/react-helpers.js';
6
+ import { SegmentedControlButton } from './segmented-control-button.js';
7
+
8
+ function SegmentedControl({ size = 'md', disabled = false, className, value, options, onChangeValue, ...props }) {
8
9
  const ref = useRef(null);
9
10
  function handleKeyDown(event) {
10
11
  const prevIndex = options.findIndex((option) => option.value === value);
@@ -36,8 +37,10 @@ export function SegmentedControl({ size = 'md', disabled = false, className, val
36
37
  focusElement(radioEl);
37
38
  }
38
39
  }
39
- return (_jsx("ul", { ...props, ref: ref, role: "radiogroup", className: classNames(className, 'dc-segmented', {
40
+ return (jsx("ul", { ...props, ref: ref, role: "radiogroup", className: classNames(className, 'dc-segmented', {
40
41
  [`dc-segmented_${size}`]: size,
41
42
  'dc-segmented_disabled': disabled,
42
- }), onKeyDown: handleKeyDown, children: options.map((option) => (_jsx(SegmentedControlButton, { icon: option.icon, value: option.value, checked: value === option.value, onChangeValue: onChangeValue, children: option.label }, option.value))) }));
43
+ }), onKeyDown: handleKeyDown, children: options.map((option) => (jsx(SegmentedControlButton, { icon: option.icon, value: option.value, checked: value === option.value, onChangeValue: onChangeValue, children: option.label }, option.value))) }));
43
44
  }
45
+
46
+ export { SegmentedControl };
@@ -1,22 +1,25 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
- import { classNames } from '../../lib/react-helpers';
4
- export const Select = forwardRef(function Select({ hasError, isBlock, size = 'md', style, className, disabled, multiple, htmlSize, children, onChange, onChangeValue, ...props }, ref) {
5
- return (_jsxs("div", { style: style, className: classNames(className, 'dc-select__container', {
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+
5
+ const Select = forwardRef(function Select({ hasError, isBlock, size = 'md', style, className, disabled, multiple, htmlSize, children, onChange, onChangeValue, ...props }, ref) {
6
+ return (jsxs("div", { style: style, className: classNames(className, 'dc-select__container', {
6
7
  [`dc-select__container_${size}`]: size !== undefined,
7
8
  'dc-select__container_multiple': multiple,
8
9
  'dc-select__container_disabled': disabled,
9
10
  'dc-select__container_has_error': hasError,
10
11
  'dc-select__container_block': isBlock,
11
- }), children: [_jsx("select", { ...props, ref: ref, className: "dc-select", size: htmlSize, multiple: multiple, disabled: disabled, onChange: (event) => {
12
- onChange === null || onChange === void 0 ? void 0 : onChange(event);
12
+ }), children: [jsx("select", { ...props, ref: ref, className: "dc-select", size: htmlSize, multiple: multiple, disabled: disabled, onChange: (event) => {
13
+ onChange?.(event);
13
14
  if (multiple === true) {
14
- onChangeValue === null || onChangeValue === void 0 ? void 0 : onChangeValue(Array.from(event.target.options)
15
+ onChangeValue?.(Array.from(event.target.options)
15
16
  .filter((option) => option.selected)
16
17
  .map((option) => option.value));
17
18
  }
18
19
  else {
19
- onChangeValue === null || onChangeValue === void 0 ? void 0 : onChangeValue(event.target.value);
20
+ onChangeValue?.(event.target.value);
20
21
  }
21
- }, children: children }), _jsx("svg", { className: "dc-select__icon", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", stroke: "currentColor", strokeWidth: 1.5, "aria-hidden": true, children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M8.25 15L12 18.75 15.75 15m-7.5-6L12 5.25 15.75 9" }) })] }));
22
+ }, children: children }), jsx("svg", { className: "dc-select__icon", xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: 24, height: 24, fill: "none", stroke: "currentColor", strokeWidth: 1.5, "aria-hidden": true, children: jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M8.25 15L12 18.75 15.75 15m-7.5-6L12 5.25 15.75 9" }) })] }));
22
23
  });
24
+
25
+ export { Select };
@@ -1,13 +1,16 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { useId } from 'react';
3
- import { classNames } from '../../lib/react-helpers';
4
- import { Label } from '../label';
5
- import { Caption } from '../caption';
6
- export function SelectionControl({ label, labelFor, caption, className, children, ...props }) {
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+ import { Label } from '../label/label.js';
5
+ import { Caption } from '../caption/caption.js';
6
+
7
+ function SelectionControl({ label, labelFor, caption, className, children, ...props }) {
7
8
  const defaultId = useId();
8
9
  const controlId = labelFor || defaultId;
9
10
  const shouldRenderCaption = Boolean(caption);
10
- return (_jsxs("div", { ...props, className: classNames('dc-selection-control', className), children: [_jsx("div", { className: "dc-selection-control__input", children: typeof children === 'function'
11
+ return (jsxs("div", { ...props, className: classNames('dc-selection-control', className), children: [jsx("div", { className: "dc-selection-control__input", children: typeof children === 'function'
11
12
  ? children({ id: controlId })
12
- : children }), _jsx(Label, { className: "dc-selection-control__label", htmlFor: controlId, children: label }), shouldRenderCaption && (_jsx(Caption, { className: "dc-selection-control__caption", children: caption }))] }));
13
+ : children }), jsx(Label, { className: "dc-selection-control__label", htmlFor: controlId, children: label }), shouldRenderCaption && (jsx(Caption, { className: "dc-selection-control__caption", children: caption }))] }));
13
14
  }
15
+
16
+ export { SelectionControl };
@@ -1,12 +1,15 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- export function SliderTickMarks({ tickMarksCount, renderTickMarkLabel, }) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ function SliderTickMarks({ tickMarksCount, renderTickMarkLabel, }) {
3
4
  if (tickMarksCount < 1) {
4
5
  return null;
5
6
  }
6
7
  const tickMarks = [];
7
8
  for (let index = 0; index < tickMarksCount; index += 1) {
8
- const label = renderTickMarkLabel === null || renderTickMarkLabel === void 0 ? void 0 : renderTickMarkLabel(index);
9
- tickMarks.push((_jsx("div", { className: "dc-slider-tick-mark", "data-testid": "tick-mark", children: Boolean(label) && (_jsx("span", { className: "dc-slider-tick-mark__label", children: label })) }, index)));
9
+ const label = renderTickMarkLabel?.(index);
10
+ tickMarks.push((jsx("div", { className: "dc-slider-tick-mark", "data-testid": "tick-mark", children: Boolean(label) && (jsx("span", { className: "dc-slider-tick-mark__label", children: label })) }, index)));
10
11
  }
11
- return _jsx("div", { className: "dc-slider__tick-marks", children: tickMarks });
12
+ return jsx("div", { className: "dc-slider__tick-marks", children: tickMarks });
12
13
  }
14
+
15
+ export { SliderTickMarks };