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
@@ -0,0 +1,67 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const keyboardKeys = require('../../lib/keyboard-keys.cjs');
6
+ const helpers = require('../../lib/helpers.cjs');
7
+ const reactHelpers = require('../../lib/react-helpers.cjs');
8
+ const tabsContext = require('./tabs-context.cjs');
9
+
10
+ function TabList({ className, children, onFocus, onBlur, onKeyDown, ...props }) {
11
+ const ref = react.useRef(null);
12
+ const { selectedTab, setTabListHasFocus } = tabsContext.useTabsContext();
13
+ function handleFocus(event) {
14
+ setTabListHasFocus(true);
15
+ onFocus?.(event);
16
+ }
17
+ function handleBlur(event) {
18
+ setTabListHasFocus(false);
19
+ onBlur?.(event);
20
+ }
21
+ function handleKeyDown(event) {
22
+ const tabList = ref.current;
23
+ helpers.assertIfNullable(tabList, 'ref.current is null or undefined');
24
+ let focusTabIndex = 0;
25
+ const tabs = tabList.querySelectorAll('[role="tab"]');
26
+ for (let index = 0; index < tabs.length; index += 1) {
27
+ const tab = tabs[index];
28
+ if (document.activeElement === tab) {
29
+ focusTabIndex = index;
30
+ break;
31
+ }
32
+ if (tab.name === selectedTab) {
33
+ focusTabIndex = index;
34
+ }
35
+ }
36
+ let index = focusTabIndex;
37
+ if (event.key === keyboardKeys.KeyboardKeys.ArrowRight) {
38
+ index += 1;
39
+ }
40
+ else if (event.key === keyboardKeys.KeyboardKeys.ArrowLeft) {
41
+ index -= 1;
42
+ }
43
+ else if (event.key === keyboardKeys.KeyboardKeys.End) {
44
+ index = tabs.length - 1;
45
+ }
46
+ else if (event.key === keyboardKeys.KeyboardKeys.Home) {
47
+ index = 0;
48
+ }
49
+ if (index < 0) {
50
+ index = tabs.length - 1;
51
+ }
52
+ else if (index >= tabs.length) {
53
+ index = 0;
54
+ }
55
+ if (index !== focusTabIndex) {
56
+ event.preventDefault();
57
+ event.stopPropagation();
58
+ const newFocusTab = tabs[index];
59
+ helpers.assertIfNullable(newFocusTab, `Unable to get tab at index ${index}`);
60
+ reactHelpers.focusElement(newFocusTab);
61
+ }
62
+ onKeyDown?.(event);
63
+ }
64
+ return (jsxRuntime.jsx("div", { ...props, ref: ref, role: "tablist", className: reactHelpers.classNames('dc-tab-list', className), onFocus: handleFocus, onBlur: handleBlur, onKeyDown: handleKeyDown, children: children }));
65
+ }
66
+
67
+ exports.TabList = TabList;
@@ -0,0 +1,16 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const reactHelpers = require('../../lib/react-helpers.cjs');
5
+ const tabsContext = require('./tabs-context.cjs');
6
+
7
+ function TabPanel({ tab, id, className, children, 'aria-labelledby': ariaLabelledBy, ...props }) {
8
+ const { selectedTab, getTabProps } = tabsContext.useTabsContext();
9
+ if (selectedTab !== tab) {
10
+ return null;
11
+ }
12
+ const tabProps = getTabProps(tab);
13
+ return (jsxRuntime.jsx("div", { ...props, className: reactHelpers.classNames('dc-tab-panel', className), role: "tabpanel", id: id || tabProps.ariaControls, "aria-labelledby": ariaLabelledBy || tabProps.id, children: children }));
14
+ }
15
+
16
+ exports.TabPanel = TabPanel;
@@ -0,0 +1,19 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const reactHelpers = require('../../lib/react-helpers.cjs');
5
+ const tabsContext = require('./tabs-context.cjs');
6
+ const badge = require('../badge/badge.cjs');
7
+
8
+ function Tab({ id, name, icon, counter, className, children, onClick, 'aria-controls': ariaControls, ...props }) {
9
+ const { getTabProps, selectedTab, setSelectedTab, tabListHasFocus, } = tabsContext.useTabsContext();
10
+ const tabProps = getTabProps(name);
11
+ const selected = name === selectedTab;
12
+ function handleClick(event) {
13
+ setSelectedTab(name);
14
+ onClick?.(event);
15
+ }
16
+ return (jsxRuntime.jsx("button", { ...props, className: reactHelpers.classNames('dc-tab', className), type: "button", role: "tab", name: name, id: id || tabProps.id, "aria-controls": ariaControls || tabProps.ariaControls, "aria-selected": selected, tabIndex: selected && !tabListHasFocus ? 0 : -1, onClick: handleClick, children: jsxRuntime.jsxs("span", { className: "dc-tab__layout", children: [icon != null && (jsxRuntime.jsx("span", { className: "dc-tab__icon", children: icon })), children != null && (jsxRuntime.jsxs("span", { className: "dc-tab__label", children: [children, " "] })), counter != null && counter !== 0 && (jsxRuntime.jsx(badge.Badge, { className: "dc-tab__counter", children: counter }))] }) }));
17
+ }
18
+
19
+ exports.Tab = Tab;
@@ -1,17 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useTabsContext = exports.TabsContextProvider = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_1 = require("react");
6
- const TabsContext = (0, react_1.createContext)(null);
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+
6
+ const TabsContext = react.createContext(null);
7
7
  function TabsContextProvider({ children, selectedTab, setSelectedTab, }) {
8
- const [tabListHasFocus, setTabListHasFocus] = (0, react_1.useState)(false);
9
- const id = (0, react_1.useId)();
10
- const getTabProps = (0, react_1.useCallback)((tab) => ({
8
+ const [tabListHasFocus, setTabListHasFocus] = react.useState(false);
9
+ const id = react.useId();
10
+ const getTabProps = react.useCallback((tab) => ({
11
11
  id: `${id}-tab[${tab}]`,
12
12
  ariaControls: `${id}-tabPanel[${tab}]`,
13
13
  }), [id]);
14
- return ((0, jsx_runtime_1.jsx)(TabsContext.Provider, { value: {
14
+ return (jsxRuntime.jsx(TabsContext.Provider, { value: {
15
15
  getTabProps,
16
16
  selectedTab,
17
17
  setSelectedTab,
@@ -19,12 +19,13 @@ function TabsContextProvider({ children, selectedTab, setSelectedTab, }) {
19
19
  setTabListHasFocus,
20
20
  }, children: children }));
21
21
  }
22
- exports.TabsContextProvider = TabsContextProvider;
23
22
  function useTabsContext() {
24
- const context = (0, react_1.useContext)(TabsContext);
23
+ const context = react.useContext(TabsContext);
25
24
  if (!context) {
26
25
  throw new Error('useTabsContext must be used within TabsContextProvider');
27
26
  }
28
27
  return context;
29
28
  }
29
+
30
+ exports.TabsContextProvider = TabsContextProvider;
30
31
  exports.useTabsContext = useTabsContext;
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const reactHelpers = require('../../lib/react-helpers.cjs');
5
+ const tabsContext = require('./tabs-context.cjs');
6
+
7
+ function Tabs({ className, children, selectedTab, onSelectTab, ...props }) {
8
+ return (jsxRuntime.jsx(tabsContext.TabsContextProvider, { selectedTab: selectedTab, setSelectedTab: onSelectTab, children: jsxRuntime.jsx("div", { ...props, className: reactHelpers.classNames('dc-tabs', className), children: children }) }));
9
+ }
10
+
11
+ exports.Tabs = Tabs;
@@ -1,14 +1,15 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Tag = void 0;
4
- const jsx_runtime_1 = require("react/jsx-runtime");
5
- const react_helpers_1 = require("../../lib/react-helpers");
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const reactHelpers = require('../../lib/react-helpers.cjs');
5
+
6
6
  function Tag({ isRounded = false, variant = 'tinted', fill = 'gray', size = 'md', className, children, ...props }) {
7
- return ((0, jsx_runtime_1.jsx)("strong", { ...props, className: (0, react_helpers_1.classNames)(className, 'dc-tag', {
7
+ return (jsxRuntime.jsx("strong", { ...props, className: reactHelpers.classNames(className, 'dc-tag', {
8
8
  [`dc-tag_${variant}`]: variant,
9
9
  [`dc-tag_${fill}`]: fill,
10
10
  [`dc-tag_${size}`]: size,
11
11
  'dc-tag_rounded': isRounded,
12
12
  }), children: children }));
13
13
  }
14
+
14
15
  exports.Tag = Tag;
@@ -0,0 +1,26 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const reactHelpers = require('../../lib/react-helpers.cjs');
6
+
7
+ const TextInput = react.forwardRef(function TextInput({ hasError = false, isBlock = false, type = 'text', size = 'md', prefix, suffix, style, className, disabled, width, htmlSize, onChange, onChangeValue, ...props }, ref) {
8
+ const shouldRenderPrefix = Boolean(prefix);
9
+ const shouldRenderSuffix = Boolean(suffix);
10
+ return (jsxRuntime.jsxs("div", { style: style, className: reactHelpers.classNames(className, 'dc-text-input__container', {
11
+ [`dc-text-input__container_${size}`]: size,
12
+ 'dc-text-input__container_disabled': disabled,
13
+ 'dc-text-input__container_has_error': hasError,
14
+ 'dc-text-input__container_block': isBlock,
15
+ 'dc-text-input__container_has_prefix': shouldRenderPrefix,
16
+ 'dc-text-input__container_has_suffix': shouldRenderSuffix,
17
+ }), children: [shouldRenderPrefix && (jsxRuntime.jsx("div", { className: "dc-text-input__prefix", children: prefix })), jsxRuntime.jsx("input", { ...props, className: reactHelpers.classNames({
18
+ 'dc-text-input': true,
19
+ [`dc-text-input_width_${width}`]: width,
20
+ }), ref: ref, type: type, size: htmlSize, disabled: disabled, onChange: (event) => {
21
+ onChange?.(event);
22
+ onChangeValue?.(event.target.value);
23
+ } }), shouldRenderSuffix && (jsxRuntime.jsx("div", { className: "dc-text-input__suffix", children: suffix }))] }));
24
+ });
25
+
26
+ exports.TextInput = TextInput;
@@ -0,0 +1,40 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const reactHelpers = require('../../lib/react-helpers.cjs');
6
+ const caption = require('../caption/caption.cjs');
7
+
8
+ const getCharactersCountMessage = ({ maxCharacters, characterCount, }) => {
9
+ const charsRemaining = maxCharacters - characterCount;
10
+ const characters = (jsxRuntime.jsx("span", { style: { fontVariant: 'tabular-nums' }, children: charsRemaining === 1
11
+ ? `${charsRemaining} character`
12
+ : `${charsRemaining} characters` }));
13
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, { children: ["You have ", characters, " remaining"] });
14
+ };
15
+ const Textarea = react.forwardRef(function Textarea({ disabled = false, hasError = false, isBlock = false, showCharacterCount = false, size = 'md', rows = 3, width, style, className, maxLength, onChange, onChangeValue, renderCharacterCount = getCharactersCountMessage, ...props }, ref) {
16
+ const shouldRenderCharacterCount = (showCharacterCount &&
17
+ maxLength != null && maxLength > 0);
18
+ const [characterCount, setCharacterCount] = react.useState(() => {
19
+ const value = props.value || props.defaultValue;
20
+ return typeof value === 'string' ? value.length : 0;
21
+ });
22
+ return (jsxRuntime.jsxs("div", { style: style, className: reactHelpers.classNames(className, 'dc-textarea__container', {
23
+ [`dc-textarea__container_size_${size}`]: size !== undefined,
24
+ 'dc-textarea__container_disabled': disabled,
25
+ 'dc-textarea__container_has_error': hasError,
26
+ 'dc-textarea__container_block': isBlock,
27
+ }), children: [jsxRuntime.jsx("textarea", { ...props, ref: ref, className: reactHelpers.classNames('dc-textarea', {
28
+ [`dc-textarea_width_${width}`]: width !== undefined,
29
+ }), rows: rows, maxLength: maxLength, disabled: disabled, onChange: (event) => {
30
+ const value = event.target.value;
31
+ onChange?.(event);
32
+ onChangeValue?.(value);
33
+ setCharacterCount(value.length);
34
+ } }), shouldRenderCharacterCount && (jsxRuntime.jsx(caption.Caption, { "data-testid": "textarea-character-count", className: "dc-textarea__character-count", children: renderCharacterCount({
35
+ characterCount,
36
+ maxCharacters: maxLength,
37
+ }) }))] }));
38
+ });
39
+
40
+ exports.Textarea = Textarea;
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const reactHelpers = require('../../lib/react-helpers.cjs');
6
+
7
+ const ToastButton = react.forwardRef(function ToastButton({ className, ...props }, ref) {
8
+ return (jsxRuntime.jsx("button", { ...props, ref: ref, className: reactHelpers.classNames(className, 'dc-toast__btn') }));
9
+ });
10
+
11
+ exports.ToastButton = ToastButton;
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const reactHelpers = require('../../lib/react-helpers.cjs');
5
+ const xMarkIcon = require('./x-mark-icon.cjs');
6
+
7
+ function Toast({ icon, message, actions, closeButtonAriaLabel = 'close', onClickCloseButton, children, className, ...props }) {
8
+ return (jsxRuntime.jsxs("section", { ...props, className: reactHelpers.classNames('dc-toast', className), children: [jsxRuntime.jsx("button", { className: "dc-toast__close-btn", "aria-label": closeButtonAriaLabel, onClick: onClickCloseButton, children: jsxRuntime.jsx(xMarkIcon.XMarkIcon, { width: 16, height: 16 }) }), jsxRuntime.jsxs("div", { className: "dc-toast__body", children: [icon && jsxRuntime.jsx("div", { className: "dc-toast__icon", children: icon }), jsxRuntime.jsxs("div", { className: "dc-toast__content", children: [jsxRuntime.jsx("h1", { className: "dc-toast__title", children: children }), message && jsxRuntime.jsx("div", { className: "dc-toast__message", children: message })] })] }), actions && jsxRuntime.jsx("div", { className: "dc-toast__actions", children: actions })] }));
9
+ }
10
+
11
+ exports.Toast = Toast;
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+
5
+ function XMarkIcon(props) {
6
+ return (jsxRuntime.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: jsxRuntime.jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" }) }));
7
+ }
8
+
9
+ exports.XMarkIcon = XMarkIcon;
@@ -0,0 +1,115 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const helpers = require('../../lib/helpers.cjs');
6
+ const reactHelpers = require('../../lib/react-helpers.cjs');
7
+ const portal = require('../portal/portal.cjs');
8
+ const toast = require('../toast/toast.cjs');
9
+ const toastButton = require('../toast/toast-button.cjs');
10
+
11
+ const TOAST_SHOW_EVENT = 'toast_show';
12
+ const isToastShowEvent = (event) => (event instanceof CustomEvent && event.type === TOAST_SHOW_EVENT);
13
+ const TOAST_HIDE_EVENT = 'toast_hide';
14
+ const isToastHideEvent = (event) => (event instanceof CustomEvent && event.type === TOAST_HIDE_EVENT);
15
+ class Toaster {
16
+ constructor(params) {
17
+ this._id = 0;
18
+ this.timeoutMs = params?.timeoutMs || 10000;
19
+ this.onShow = params?.onShowToast;
20
+ this.onHide = params?.onHideToast;
21
+ }
22
+ _getNextId() {
23
+ this._id += 1;
24
+ return this._id;
25
+ }
26
+ showToast(toast, params) {
27
+ const id = this._getNextId();
28
+ const event = new CustomEvent(TOAST_SHOW_EVENT, {
29
+ detail: {
30
+ toaster: this,
31
+ toast: { ...toast, id },
32
+ },
33
+ });
34
+ const timeoutMs = toast.timeoutMs || params?.timeoutMs || this.timeoutMs;
35
+ this.onShow?.(event.detail.toast);
36
+ window.dispatchEvent(event);
37
+ window.setTimeout(() => this.hideToast(id), timeoutMs);
38
+ return id;
39
+ }
40
+ hideToast(id) {
41
+ const event = new CustomEvent(TOAST_HIDE_EVENT, {
42
+ detail: {
43
+ toaster: this,
44
+ toastId: id,
45
+ },
46
+ });
47
+ this.onHide?.(id);
48
+ window.dispatchEvent(event);
49
+ }
50
+ render(options) {
51
+ return (jsxRuntime.jsx(ToastsList, { toaster: this, toastGap: options?.toastGap, toastPosition: options?.toastPosition, toastCloseButtonAriaLabel: options?.toastCloseButtonAriaLabel }));
52
+ }
53
+ }
54
+ function ToastsList({ toaster, toastGap = 12, toastPosition = 'top-center', toastCloseButtonAriaLabel = 'Close', }) {
55
+ const ref = react.useRef(null);
56
+ const [toasts, setToasts] = react.useState([]);
57
+ react.useEffect(() => {
58
+ function handleShowToast(event) {
59
+ if (isToastShowEvent(event)) {
60
+ const detail = event.detail;
61
+ if (detail.toaster === toaster) {
62
+ setToasts((prevToasts) => [detail.toast, ...prevToasts]);
63
+ }
64
+ }
65
+ }
66
+ function handleCloseToast(event) {
67
+ if (isToastHideEvent(event)) {
68
+ const detail = event.detail;
69
+ if (detail.toaster === toaster) {
70
+ setToasts((prevToasts) => prevToasts.filter((toast) => toast.id !== detail.toastId));
71
+ }
72
+ }
73
+ }
74
+ window.addEventListener(TOAST_SHOW_EVENT, handleShowToast);
75
+ window.addEventListener(TOAST_HIDE_EVENT, handleCloseToast);
76
+ return () => {
77
+ window.removeEventListener(TOAST_SHOW_EVENT, handleShowToast);
78
+ window.removeEventListener(TOAST_HIDE_EVENT, handleCloseToast);
79
+ };
80
+ }, [toaster]);
81
+ react.useEffect(() => {
82
+ const listEl = ref.current;
83
+ helpers.assertIfNullable(listEl, 'ToastsList ref was not set');
84
+ let offset = 0;
85
+ for (const item of listEl.children) {
86
+ if (item instanceof HTMLLIElement) {
87
+ item.style.transform = `translateY(${offset}px)`;
88
+ const d = item.offsetHeight + toastGap;
89
+ if (toastPosition === 'top-right' ||
90
+ toastPosition === 'top-center' ||
91
+ toastPosition === 'top-left') {
92
+ offset += d;
93
+ }
94
+ else {
95
+ offset -= d;
96
+ }
97
+ }
98
+ }
99
+ }, [toasts, toastGap, toastPosition]);
100
+ return (jsxRuntime.jsx(portal.Portal, { children: jsxRuntime.jsx("ul", { ref: ref, className: reactHelpers.classNames({
101
+ 'dc-toasts-list': true,
102
+ [`dc-toasts-list_${toastPosition}`]: toastPosition,
103
+ }), children: toasts.map((toast$1) => {
104
+ const hideToast = () => toaster.hideToast(toast$1.id);
105
+ const actions = toast$1.actions?.map((action, index) => (jsxRuntime.jsx(toastButton.ToastButton, { onClick: () => {
106
+ action.onClick?.();
107
+ if (action.shouldHideAfterClick ?? true) {
108
+ hideToast();
109
+ }
110
+ }, children: action.content }, index)));
111
+ return (jsxRuntime.jsx("li", { children: jsxRuntime.jsx(toast.Toast, { className: "dc-toasts-list__toast", role: "alert", icon: toast$1.icon, message: toast$1.message, actions: actions, closeButtonAriaLabel: toastCloseButtonAriaLabel, onClickCloseButton: hideToast, children: toast$1.title }) }, toast$1.id));
112
+ }) }) }));
113
+ }
114
+
115
+ exports.Toaster = Toaster;
@@ -0,0 +1,75 @@
1
+ 'use strict';
2
+
3
+ const jsxRuntime = require('react/jsx-runtime');
4
+ const react = require('react');
5
+ const reactHelpers = require('../../lib/react-helpers.cjs');
6
+ const useMountTransition = require('../../hooks/use-mount-transition.cjs');
7
+ const positioner = require('../positioner/positioner.cjs');
8
+
9
+ function Tooltip({ anchorGap = 8, placement = 'top', alignment = 'center', style, className, content, children, ...props }) {
10
+ const [defaultShow, setDefaultShow] = react.useState(props.defaultIsShown ?? false);
11
+ const defaultId = react.useId();
12
+ const tooltipId = props.id || defaultId;
13
+ const isShown = props.isShown ?? defaultShow;
14
+ const durationMs = 100;
15
+ const { isMounted, className: transitionClass } = useMountTransition.useMountTransition({
16
+ isShown,
17
+ durationMs,
18
+ enterFrom: 'dc-tooltip_hidden',
19
+ enterTo: 'dc-tooltip_visible',
20
+ });
21
+ const { showTooltip, hideTooltip } = react.useMemo(() => ({
22
+ showTooltip: () => setDefaultShow(true),
23
+ hideTooltip: () => setDefaultShow(false),
24
+ }), []);
25
+ const renderAnchor = ({ setRef }) => {
26
+ if (typeof children === 'function') {
27
+ return children({
28
+ ref: setRef,
29
+ }, {
30
+ tooltipId,
31
+ showTooltip,
32
+ hideTooltip,
33
+ isShown: isShown || isMounted,
34
+ });
35
+ }
36
+ if (reactHelpers.isReactElementWithRef(children)) {
37
+ const props = children.props;
38
+ return react.cloneElement(children, {
39
+ 'ref': reactHelpers.mergeRefs(setRef, children.ref),
40
+ 'onFocus': (event) => {
41
+ showTooltip();
42
+ props.onFocus?.(event);
43
+ },
44
+ 'onBlur': (event) => {
45
+ hideTooltip();
46
+ props.onBlur?.(event);
47
+ },
48
+ 'onMouseEnter': (event) => {
49
+ showTooltip();
50
+ props.onMouseEnter?.(event);
51
+ },
52
+ 'onMouseLeave': (event) => {
53
+ hideTooltip();
54
+ props.onMouseLeave?.(event);
55
+ },
56
+ 'aria-describedby': props['aria-describedby'] || tooltipId,
57
+ });
58
+ }
59
+ return children;
60
+ };
61
+ const renderContent = ({ setRef: portalRef, style: portalStyle, }) => {
62
+ if (isShown || isMounted) {
63
+ delete props.defaultIsShown;
64
+ delete props.isShown;
65
+ return (jsxRuntime.jsx("div", { ...props, ref: portalRef, id: tooltipId, style: {
66
+ '--dc-tooltip-transition-duration': `${durationMs}ms`,
67
+ ...portalStyle,
68
+ ...style,
69
+ }, className: reactHelpers.classNames('dc-tooltip', transitionClass, className), role: "tooltip", children: content }));
70
+ }
71
+ };
72
+ return (jsxRuntime.jsx(positioner.Positioner, { placement: placement, alignment: alignment, anchorGap: anchorGap, renderAnchor: renderAnchor, renderContent: renderContent }));
73
+ }
74
+
75
+ exports.Tooltip = Tooltip;
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ const useMountTransition = require('./use-mount-transition.cjs');
4
+ const useDisableBodyScroll = require('./use-disable-body-scroll.cjs');
5
+ const useEscKeyDown = require('./use-esc-key-down.cjs');
6
+ const useFocusTrap = require('./use-focus-trap.cjs');
7
+
8
+
9
+
10
+ exports.useMountTransition = useMountTransition.useMountTransition;
11
+ exports.useDisableBodyScroll = useDisableBodyScroll.useDisableBodyScroll;
12
+ exports.useEscKeyDown = useEscKeyDown.useEscKeyDown;
13
+ exports.useFocusTrap = useFocusTrap.useFocusTrap;
@@ -1,16 +1,15 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useDisableBodyScroll = void 0;
4
- const react_1 = require("react");
5
- const helpers_1 = require("../lib/helpers");
1
+ 'use strict';
2
+
3
+ const react = require('react');
4
+ const helpers = require('../lib/helpers.cjs');
5
+
6
6
  function useDisableBodyScroll(options) {
7
- (0, react_1.useEffect)(() => {
7
+ react.useEffect(() => {
8
8
  if (options.isEnabled) {
9
9
  return disableBodyScroll();
10
10
  }
11
11
  }, [options.isEnabled]);
12
12
  }
13
- exports.useDisableBodyScroll = useDisableBodyScroll;
14
13
  let disableAttempts = 0;
15
14
  let initialOverflow = '';
16
15
  let initialPaddingRight = '';
@@ -24,7 +23,7 @@ function disableBodyScroll() {
24
23
  document.body.style.paddingRight = `${parseInt(initialPaddingRight, 10) + scrollbarWidth}px`;
25
24
  }
26
25
  disableAttempts += 1;
27
- return (0, helpers_1.once)(function enableBodyScroll() {
26
+ return helpers.once(function enableBodyScroll() {
28
27
  disableAttempts -= 1;
29
28
  if (!disableAttempts) {
30
29
  document.body.style.overflow = initialOverflow;
@@ -32,3 +31,5 @@ function disableBodyScroll() {
32
31
  }
33
32
  });
34
33
  }
34
+
35
+ exports.useDisableBodyScroll = useDisableBodyScroll;
@@ -1,8 +1,8 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useEscKeyDown = void 0;
4
- const react_1 = require("react");
5
- const keyboard_keys_1 = require("../lib/keyboard-keys");
1
+ 'use strict';
2
+
3
+ const react = require('react');
4
+ const keyboardKeys = require('../lib/keyboard-keys.cjs');
5
+
6
6
  const handlers = [];
7
7
  /**
8
8
  * Invokes a given handler when the `Esc` key was pressed.
@@ -16,12 +16,12 @@ const handlers = [];
16
16
  * the passed handler or not.
17
17
  */
18
18
  function useEscKeyDown(handler, options) {
19
- const handlerRef = (0, react_1.useRef)(handler);
19
+ const handlerRef = react.useRef(handler);
20
20
  const isEnabled = options.isEnabled;
21
- (0, react_1.useEffect)(() => {
21
+ react.useEffect(() => {
22
22
  handlerRef.current = handler;
23
23
  }, [handler]);
24
- (0, react_1.useEffect)(() => {
24
+ react.useEffect(() => {
25
25
  if (!isEnabled) {
26
26
  return;
27
27
  }
@@ -29,7 +29,7 @@ function useEscKeyDown(handler, options) {
29
29
  handlers.push(handler);
30
30
  const handleBodyKeyDown = (event) => {
31
31
  const eventHandler = handlers[handlers.length - 1];
32
- if (eventHandler && event.key === keyboard_keys_1.KeyboardKeys.Escape) {
32
+ if (eventHandler && event.key === keyboardKeys.KeyboardKeys.Escape) {
33
33
  eventHandler();
34
34
  }
35
35
  };
@@ -50,4 +50,5 @@ function useEscKeyDown(handler, options) {
50
50
  };
51
51
  }, [isEnabled]);
52
52
  }
53
+
53
54
  exports.useEscKeyDown = useEscKeyDown;
@@ -1,9 +1,9 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.useFocusTrap = void 0;
4
- const react_1 = require("react");
5
- const keyboard_keys_1 = require("../lib/keyboard-keys");
6
- const react_helpers_1 = require("../lib/react-helpers");
1
+ 'use strict';
2
+
3
+ const react = require('react');
4
+ const keyboardKeys = require('../lib/keyboard-keys.cjs');
5
+ const reactHelpers = require('../lib/react-helpers.cjs');
6
+
7
7
  const modals = [];
8
8
  const focusableElementsSelector = [
9
9
  'a[href]',
@@ -28,13 +28,13 @@ const focusableElementsSelector = [
28
28
  */
29
29
  function useFocusTrap(modalRef, options) {
30
30
  const isEnabled = options.isEnabled;
31
- (0, react_1.useEffect)(() => {
31
+ react.useEffect(() => {
32
32
  if (!isEnabled) {
33
33
  return;
34
34
  }
35
35
  modals.push(modalRef);
36
36
  const handleBodyKeyDown = (event) => {
37
- if (event.key !== keyboard_keys_1.KeyboardKeys.Tab) {
37
+ if (event.key !== keyboardKeys.KeyboardKeys.Tab) {
38
38
  return;
39
39
  }
40
40
  const activeModalRef = modals[modals.length - 1];
@@ -53,17 +53,17 @@ function useFocusTrap(modalRef, options) {
53
53
  const lastFocusableEl = focusableEls[focusableEls.length - 1];
54
54
  if (!activeModal.contains(document.activeElement)) {
55
55
  event.preventDefault();
56
- (0, react_helpers_1.focusElement)(firstFocusableEl);
56
+ reactHelpers.focusElement(firstFocusableEl);
57
57
  }
58
58
  else if (event.shiftKey) {
59
59
  if (document.activeElement === firstFocusableEl) {
60
60
  event.preventDefault();
61
- (0, react_helpers_1.focusElement)(lastFocusableEl);
61
+ reactHelpers.focusElement(lastFocusableEl);
62
62
  }
63
63
  }
64
64
  else if (document.activeElement === lastFocusableEl) {
65
65
  event.preventDefault();
66
- (0, react_helpers_1.focusElement)(firstFocusableEl);
66
+ reactHelpers.focusElement(firstFocusableEl);
67
67
  }
68
68
  };
69
69
  // Add only one global `body` key down handler.
@@ -83,4 +83,5 @@ function useFocusTrap(modalRef, options) {
83
83
  };
84
84
  }, [isEnabled, modalRef]);
85
85
  }
86
+
86
87
  exports.useFocusTrap = useFocusTrap;