draft-components 1.0.0-beta.1 → 1.0.0-beta.11

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/{dist/components/badge/badge.js → cjs/components/badge/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 +41 -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/color-picker/color-picker-button.cjs +16 -0
  15. package/cjs/components/color-picker/color-picker.cjs +14 -0
  16. package/{dist/components/date-picker/calendar-day.js → cjs/components/date-picker/calendar-day.cjs} +8 -7
  17. package/cjs/components/date-picker/calendar-grid-head.cjs +16 -0
  18. package/cjs/components/date-picker/calendar-grid.cjs +106 -0
  19. package/cjs/components/date-picker/calendar-header.cjs +48 -0
  20. package/cjs/components/date-picker/calendar.cjs +24 -0
  21. package/{dist/components/date-picker/date-helpers.js → cjs/components/date-picker/date-helpers.cjs} +30 -26
  22. package/cjs/components/date-picker/date-picker.cjs +20 -0
  23. package/cjs/components/date-picker/date-range-picker.cjs +61 -0
  24. package/cjs/components/date-picker/date-range.cjs +28 -0
  25. package/cjs/components/date-picker/icons.cjs +13 -0
  26. package/{dist/components/date-picker/parse-min-max-props.js → cjs/components/date-picker/parse-min-max-props.cjs} +7 -6
  27. package/cjs/components/date-picker-popover/date-picker-popover.cjs +24 -0
  28. package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.cjs +11 -0
  29. package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.cjs +35 -0
  30. package/cjs/components/date-range-picker-popover/date-range-picker-popover.cjs +59 -0
  31. package/{dist/components/date-range-picker-popover/helpers.js → cjs/components/date-range-picker-popover/helpers.cjs} +3 -3
  32. package/{dist/components/date-range-picker-popover/use-is-compact-view.js → cjs/components/date-range-picker-popover/use-is-compact-view.cjs} +8 -7
  33. package/{dist/components/dialog/dialog-body.js → cjs/components/dialog/dialog-body.cjs} +17 -16
  34. package/{dist/components/dialog/dialog-context.js → cjs/components/dialog/dialog-context.cjs} +10 -9
  35. package/cjs/components/dialog/dialog-footer.cjs +10 -0
  36. package/cjs/components/dialog/dialog-header.cjs +18 -0
  37. package/cjs/components/dialog/dialog.cjs +50 -0
  38. package/cjs/components/dialog/x-mark-icon.cjs +9 -0
  39. package/cjs/components/empty-state/empty-state.cjs +10 -0
  40. package/cjs/components/file-picker/file-picker.cjs +47 -0
  41. package/cjs/components/filter-buttons/filter-button.cjs +11 -0
  42. package/cjs/components/filter-buttons/filter-buttons.cjs +27 -0
  43. package/cjs/components/form-field/form-field.cjs +26 -0
  44. package/cjs/components/index.cjs +129 -0
  45. package/cjs/components/label/label.cjs +13 -0
  46. package/cjs/components/menu/menu-item.cjs +21 -0
  47. package/cjs/components/menu/menu-separator.cjs +10 -0
  48. package/{dist/components/menu/menu.js → cjs/components/menu/menu.cjs} +52 -55
  49. package/cjs/components/nav-list/nav-list-item.cjs +20 -0
  50. package/cjs/components/nav-list/nav-list-title.cjs +10 -0
  51. package/cjs/components/nav-list/nav-list.cjs +10 -0
  52. package/cjs/components/password-input/icons.cjs +13 -0
  53. package/cjs/components/password-input/password-input.cjs +30 -0
  54. package/cjs/components/popover/popover.cjs +97 -0
  55. package/{dist/components/popover/use-page-click.js → cjs/components/popover/use-page-click.cjs} +8 -7
  56. package/cjs/components/portal/portal-context.cjs +22 -0
  57. package/cjs/components/portal/portal.cjs +11 -0
  58. package/{dist/components/positioner/calc-position.js → cjs/components/positioner/calc-position.cjs} +4 -4
  59. package/{dist/components/positioner/positioner.js → cjs/components/positioner/positioner.cjs} +14 -13
  60. package/cjs/components/radio/radio.cjs +24 -0
  61. package/cjs/components/segmented-control/segmented-control-button.cjs +15 -0
  62. package/cjs/components/segmented-control/segmented-control.cjs +48 -0
  63. package/cjs/components/select/select.cjs +27 -0
  64. package/cjs/components/selection-control/selection-control.cjs +18 -0
  65. package/cjs/components/slider/slider-tick-marks.cjs +17 -0
  66. package/{dist/components/slider/slider.js → cjs/components/slider/slider.cjs} +16 -14
  67. package/cjs/components/spinner/spinner.cjs +11 -0
  68. package/cjs/components/switch/switch.cjs +15 -0
  69. package/cjs/components/table/icons.cjs +17 -0
  70. package/cjs/components/table/table-body.cjs +11 -0
  71. package/cjs/components/table/table-cell.cjs +11 -0
  72. package/cjs/components/table/table-container.cjs +23 -0
  73. package/cjs/components/table/table-head-cell.cjs +30 -0
  74. package/cjs/components/table/table-head.cjs +14 -0
  75. package/cjs/components/table/table-row.cjs +14 -0
  76. package/cjs/components/table/table.cjs +16 -0
  77. package/cjs/components/tabs/tab-list.cjs +67 -0
  78. package/cjs/components/tabs/tab-panel.cjs +16 -0
  79. package/cjs/components/tabs/tab.cjs +19 -0
  80. package/{dist/components/tabs/tabs-context.js → cjs/components/tabs/tabs-context.cjs} +13 -12
  81. package/cjs/components/tabs/tabs.cjs +11 -0
  82. package/cjs/components/tag/tag.cjs +15 -0
  83. package/cjs/components/text-input/text-input.cjs +26 -0
  84. package/cjs/components/textarea/textarea.cjs +40 -0
  85. package/cjs/components/toast/toast-button.cjs +11 -0
  86. package/cjs/components/toast/toast.cjs +11 -0
  87. package/cjs/components/toast/x-mark-icon.cjs +9 -0
  88. package/cjs/components/toaster/toaster.cjs +115 -0
  89. package/cjs/components/tooltip/tooltip.cjs +75 -0
  90. package/cjs/hooks/index.cjs +13 -0
  91. package/{dist/hooks/use-disable-body-scroll.js → cjs/hooks/use-disable-body-scroll.cjs} +9 -8
  92. package/{dist/hooks/use-esc-key-down.js → cjs/hooks/use-esc-key-down.cjs} +10 -9
  93. package/{dist/hooks/use-focus-trap.js → cjs/hooks/use-focus-trap.cjs} +12 -11
  94. package/{dist/hooks/use-mount-transition.js → cjs/hooks/use-mount-transition.cjs} +13 -12
  95. package/cjs/index.cjs +147 -0
  96. package/{dist/shared/util.js → cjs/lib/helpers.cjs} +4 -4
  97. package/cjs/lib/index.cjs +15 -0
  98. package/{dist/shared/keyboard-keys.js → cjs/lib/keyboard-keys.cjs} +5 -4
  99. package/{dist/shared/react-helpers.js → cjs/lib/react-helpers.cjs} +9 -8
  100. package/css/draft-components-utilities.css +4 -0
  101. package/css/draft-components.css +500 -464
  102. package/esm/components/alert/alert.js +9 -5
  103. package/esm/components/avatar/avatar.js +17 -14
  104. package/esm/components/avatar-group/avatar-group.js +7 -4
  105. package/esm/components/badge/badge.js +7 -4
  106. package/esm/components/breadcrumbs/breadcrumbs-context.js +7 -4
  107. package/esm/components/breadcrumbs/breadcrumbs-item.js +10 -7
  108. package/esm/components/breadcrumbs/breadcrumbs.js +9 -6
  109. package/esm/components/button/button.js +19 -14
  110. package/esm/components/button/icon-button.js +8 -5
  111. package/esm/components/button-group/button-group.js +7 -4
  112. package/esm/components/caption/caption.js +10 -7
  113. package/esm/components/caption/icons.js +12 -9
  114. package/esm/components/checkbox/checkbox.js +12 -9
  115. package/esm/components/color-picker/color-picker-button.js +8 -5
  116. package/esm/components/color-picker/color-picker.js +9 -6
  117. package/esm/components/date-picker/calendar-day.js +8 -5
  118. package/esm/components/date-picker/calendar-grid-head.js +8 -5
  119. package/esm/components/date-picker/calendar-grid.js +15 -12
  120. package/esm/components/date-picker/calendar-header.js +20 -16
  121. package/esm/components/date-picker/calendar.js +11 -8
  122. package/esm/components/date-picker/date-helpers.js +22 -20
  123. package/esm/components/date-picker/date-picker.js +10 -7
  124. package/esm/components/date-picker/date-range-picker.js +15 -12
  125. package/esm/components/date-picker/date-range.js +5 -2
  126. package/esm/components/date-picker/icons.js +8 -5
  127. package/esm/components/date-picker/parse-min-max-props.js +5 -2
  128. package/esm/components/date-picker-popover/date-picker-popover.js +14 -8
  129. package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.js +8 -4
  130. package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.js +12 -9
  131. package/esm/components/date-range-picker-popover/date-range-picker-popover.js +20 -13
  132. package/esm/components/date-range-picker-popover/helpers.js +3 -1
  133. package/esm/components/date-range-picker-popover/use-is-compact-view.js +6 -3
  134. package/esm/components/dialog/dialog-body.js +14 -11
  135. package/esm/components/dialog/dialog-context.js +7 -4
  136. package/esm/components/dialog/dialog-footer.js +7 -4
  137. package/esm/components/dialog/dialog-header.js +11 -7
  138. package/esm/components/dialog/dialog.js +18 -12
  139. package/esm/components/dialog/x-mark-icon.js +6 -3
  140. package/esm/components/empty-state/empty-state.js +7 -4
  141. package/esm/components/file-picker/file-picker.js +13 -9
  142. package/esm/components/filter-buttons/filter-button.js +7 -4
  143. package/esm/components/filter-buttons/filter-buttons.js +9 -6
  144. package/esm/components/form-field/form-field.js +11 -8
  145. package/esm/components/index.js +62 -0
  146. package/esm/components/label/label.js +7 -4
  147. package/esm/components/menu/menu-item.js +17 -7
  148. package/esm/components/menu/menu-separator.js +7 -4
  149. package/esm/components/menu/menu.js +26 -27
  150. package/esm/components/nav-list/nav-list-item.js +10 -7
  151. package/esm/components/nav-list/nav-list-title.js +7 -4
  152. package/esm/components/nav-list/nav-list.js +7 -4
  153. package/esm/components/password-input/icons.js +8 -5
  154. package/esm/components/password-input/password-input.js +12 -9
  155. package/esm/components/popover/popover.js +22 -21
  156. package/esm/components/popover/use-page-click.js +5 -2
  157. package/esm/components/portal/portal-context.js +5 -6
  158. package/esm/components/portal/portal.js +5 -2
  159. package/esm/components/positioner/calc-position.js +4 -2
  160. package/esm/components/positioner/positioner.js +9 -6
  161. package/esm/components/radio/radio.js +12 -9
  162. package/esm/components/segmented-control/segmented-control-button.js +7 -4
  163. package/esm/components/segmented-control/segmented-control.js +12 -9
  164. package/esm/components/select/select.js +13 -10
  165. package/esm/components/selection-control/selection-control.js +11 -8
  166. package/esm/components/slider/slider-tick-marks.js +8 -5
  167. package/esm/components/slider/slider.js +13 -10
  168. package/esm/components/spinner/spinner.js +7 -4
  169. package/esm/components/switch/switch.js +11 -8
  170. package/esm/components/table/icons.js +10 -7
  171. package/esm/components/table/table-body.js +7 -4
  172. package/esm/components/table/table-cell.js +7 -4
  173. package/esm/components/table/table-container.js +7 -4
  174. package/esm/components/table/table-head-cell.js +18 -15
  175. package/esm/components/table/table-head.js +7 -4
  176. package/esm/components/table/table-row.js +7 -4
  177. package/esm/components/table/table.js +7 -4
  178. package/esm/components/tabs/tab-list.js +14 -11
  179. package/esm/components/tabs/tab-panel.js +8 -5
  180. package/esm/components/tabs/tab.js +10 -7
  181. package/esm/components/tabs/tabs-context.js +8 -5
  182. package/esm/components/tabs/tabs.js +8 -5
  183. package/esm/components/tag/tag.js +7 -4
  184. package/esm/components/text-input/text-input.js +11 -8
  185. package/esm/components/textarea/textarea.js +20 -17
  186. package/esm/components/toast/toast-button.js +7 -4
  187. package/esm/components/toast/toast.js +8 -5
  188. package/esm/components/toast/x-mark-icon.js +6 -3
  189. package/esm/components/toaster/toaster.js +29 -46
  190. package/esm/components/tooltip/tooltip.js +22 -24
  191. package/esm/hooks/index.js +4 -4
  192. package/esm/hooks/use-disable-body-scroll.js +5 -2
  193. package/esm/hooks/use-esc-key-down.js +6 -3
  194. package/esm/hooks/use-focus-trap.js +6 -3
  195. package/esm/hooks/use-mount-transition.js +6 -3
  196. package/esm/index.js +69 -37
  197. package/esm/{shared/util.js → lib/helpers.js} +4 -2
  198. package/esm/lib/index.js +3 -0
  199. package/esm/{shared → lib}/keyboard-keys.js +3 -1
  200. package/esm/{shared → lib}/react-helpers.js +8 -5
  201. package/package.json +29 -25
  202. package/{dist → types}/components/alert/alert.d.ts +0 -0
  203. package/{dist → types}/components/alert/index.d.ts +0 -0
  204. package/{dist → types}/components/avatar/avatar.d.ts +0 -0
  205. package/{dist → types}/components/avatar/index.d.ts +0 -0
  206. package/{dist → types}/components/avatar-group/avatar-group.d.ts +0 -0
  207. package/{dist → types}/components/avatar-group/index.d.ts +0 -0
  208. package/{dist → types}/components/badge/badge.d.ts +0 -0
  209. package/{dist → types}/components/badge/index.d.ts +0 -0
  210. package/{dist → types}/components/breadcrumbs/breadcrumbs-context.d.ts +0 -0
  211. package/{dist → types}/components/breadcrumbs/breadcrumbs-item.d.ts +0 -0
  212. package/{dist → types}/components/breadcrumbs/breadcrumbs.d.ts +0 -0
  213. package/{dist → types}/components/breadcrumbs/index.d.ts +0 -0
  214. package/{esm → types}/components/button/button.d.ts +5 -4
  215. package/{dist → types}/components/button/icon-button.d.ts +4 -3
  216. package/{dist → types}/components/button/index.d.ts +0 -0
  217. package/{dist → types}/components/button-group/button-group.d.ts +0 -0
  218. package/{dist → types}/components/button-group/index.d.ts +0 -0
  219. package/{dist → types}/components/caption/caption.d.ts +0 -0
  220. package/{dist → types}/components/caption/icons.d.ts +0 -0
  221. package/{dist → types}/components/caption/index.d.ts +0 -0
  222. package/{dist → types}/components/checkbox/checkbox.d.ts +1 -1
  223. package/{dist → types}/components/checkbox/index.d.ts +0 -0
  224. package/{dist → types}/components/color-picker/color-picker-button.d.ts +0 -0
  225. package/{dist → types}/components/color-picker/color-picker.d.ts +0 -0
  226. package/{dist → types}/components/color-picker/index.d.ts +0 -0
  227. package/{dist → types}/components/date-picker/calendar-day.d.ts +0 -0
  228. package/{dist → types}/components/date-picker/calendar-grid-head.d.ts +0 -0
  229. package/{dist → types}/components/date-picker/calendar-grid.d.ts +0 -0
  230. package/{dist → types}/components/date-picker/calendar-header.d.ts +0 -0
  231. package/{dist → types}/components/date-picker/calendar.d.ts +0 -0
  232. package/{dist → types}/components/date-picker/date-helpers.d.ts +0 -0
  233. package/{dist → types}/components/date-picker/date-picker.d.ts +0 -0
  234. package/{dist → types}/components/date-picker/date-range-picker.d.ts +0 -0
  235. package/{dist → types}/components/date-picker/date-range.d.ts +0 -0
  236. package/{dist → types}/components/date-picker/icons.d.ts +0 -0
  237. package/{dist → types}/components/date-picker/index.d.ts +0 -0
  238. package/{dist → types}/components/date-picker/parse-min-max-props.d.ts +0 -0
  239. package/{dist → types}/components/date-picker-popover/date-picker-popover.d.ts +0 -0
  240. package/{dist → types}/components/date-picker-popover/index.d.ts +0 -0
  241. package/{dist → types}/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -0
  242. package/{dist → types}/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -0
  243. package/{dist → types}/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -0
  244. package/{dist → types}/components/date-range-picker-popover/helpers.d.ts +0 -0
  245. package/{dist → types}/components/date-range-picker-popover/index.d.ts +0 -0
  246. package/{dist → types}/components/date-range-picker-popover/types.d.ts +0 -0
  247. package/{dist → types}/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -0
  248. package/{dist → types}/components/dialog/dialog-body.d.ts +0 -0
  249. package/{dist → types}/components/dialog/dialog-context.d.ts +0 -0
  250. package/{dist → types}/components/dialog/dialog-footer.d.ts +0 -0
  251. package/{dist → types}/components/dialog/dialog-header.d.ts +0 -0
  252. package/{dist → types}/components/dialog/dialog.d.ts +0 -0
  253. package/{dist → types}/components/dialog/index.d.ts +0 -0
  254. package/{dist → types}/components/dialog/x-mark-icon.d.ts +0 -0
  255. package/{dist → types}/components/empty-state/empty-state.d.ts +0 -0
  256. package/{dist → types}/components/empty-state/index.d.ts +0 -0
  257. package/{esm → types}/components/file-picker/file-picker.d.ts +1 -1
  258. package/{dist → types}/components/file-picker/index.d.ts +0 -0
  259. package/{dist → types}/components/filter-buttons/filter-button.d.ts +0 -0
  260. package/{dist → types}/components/filter-buttons/filter-buttons.d.ts +0 -0
  261. package/{dist → types}/components/filter-buttons/index.d.ts +0 -0
  262. package/{dist → types}/components/form-field/form-field.d.ts +0 -0
  263. package/{dist → types}/components/form-field/index.d.ts +0 -0
  264. package/types/components/index.d.ts +40 -0
  265. package/{dist → types}/components/label/index.d.ts +0 -0
  266. package/{dist → types}/components/label/label.d.ts +0 -0
  267. package/{dist → types}/components/menu/index.d.ts +0 -0
  268. package/{esm → types}/components/menu/menu-item.d.ts +6 -3
  269. package/{dist → types}/components/menu/menu-separator.d.ts +1 -1
  270. package/{esm → types}/components/menu/menu.d.ts +4 -3
  271. package/{dist → types}/components/nav-list/index.d.ts +0 -0
  272. package/{dist → types}/components/nav-list/nav-list-item.d.ts +0 -0
  273. package/{dist → types}/components/nav-list/nav-list-title.d.ts +0 -0
  274. package/{dist → types}/components/nav-list/nav-list.d.ts +0 -0
  275. package/{dist → types}/components/password-input/icons.d.ts +0 -0
  276. package/{dist → types}/components/password-input/index.d.ts +0 -0
  277. package/{esm → types}/components/password-input/password-input.d.ts +1 -1
  278. package/{dist → types}/components/popover/index.d.ts +0 -0
  279. package/{dist → types}/components/popover/popover.d.ts +0 -0
  280. package/{dist → types}/components/popover/use-page-click.d.ts +0 -0
  281. package/{dist → types}/components/portal/index.d.ts +0 -0
  282. package/{dist → types}/components/portal/portal-context.d.ts +0 -0
  283. package/{dist → types}/components/portal/portal.d.ts +0 -0
  284. package/{dist → types}/components/positioner/calc-position.d.ts +0 -0
  285. package/{dist → types}/components/positioner/index.d.ts +0 -0
  286. package/{dist → types}/components/positioner/positioner.d.ts +0 -0
  287. package/{dist → types}/components/positioner/types.d.ts +0 -0
  288. package/{dist → types}/components/radio/index.d.ts +0 -0
  289. package/{dist → types}/components/radio/radio.d.ts +1 -1
  290. package/{dist → types}/components/segmented-control/index.d.ts +0 -0
  291. package/{dist → types}/components/segmented-control/segmented-control-button.d.ts +0 -0
  292. package/{dist → types}/components/segmented-control/segmented-control.d.ts +0 -0
  293. package/{dist → types}/components/select/index.d.ts +0 -0
  294. package/{dist → types}/components/select/select.d.ts +3 -3
  295. package/{dist → types}/components/selection-control/index.d.ts +0 -0
  296. package/{dist → types}/components/selection-control/selection-control.d.ts +2 -2
  297. package/{dist → types}/components/slider/index.d.ts +0 -0
  298. package/{dist → types}/components/slider/slider-tick-marks.d.ts +0 -0
  299. package/{esm → types}/components/slider/slider.d.ts +1 -1
  300. package/{dist → types}/components/spinner/index.d.ts +0 -0
  301. package/{dist → types}/components/spinner/spinner.d.ts +0 -0
  302. package/{dist → types}/components/switch/index.d.ts +0 -0
  303. package/{esm → types}/components/switch/switch.d.ts +1 -1
  304. package/{dist → types}/components/table/icons.d.ts +0 -0
  305. package/{dist → types}/components/table/index.d.ts +0 -0
  306. package/{dist → types}/components/table/table-body.d.ts +0 -0
  307. package/{dist → types}/components/table/table-cell.d.ts +0 -0
  308. package/{dist → types}/components/table/table-container.d.ts +0 -0
  309. package/{dist → types}/components/table/table-head-cell.d.ts +0 -0
  310. package/{dist → types}/components/table/table-head.d.ts +0 -0
  311. package/{dist → types}/components/table/table-row.d.ts +0 -0
  312. package/{dist → types}/components/table/table.d.ts +0 -0
  313. package/{dist → types}/components/tabs/index.d.ts +0 -0
  314. package/{dist → types}/components/tabs/tab-list.d.ts +0 -0
  315. package/{dist → types}/components/tabs/tab-panel.d.ts +0 -0
  316. package/{dist → types}/components/tabs/tab.d.ts +0 -0
  317. package/{dist → types}/components/tabs/tabs-context.d.ts +0 -0
  318. package/{dist → types}/components/tabs/tabs.d.ts +0 -0
  319. package/{dist → types}/components/tabs/types.d.ts +0 -0
  320. package/{dist → types}/components/tag/index.d.ts +0 -0
  321. package/{dist → types}/components/tag/tag.d.ts +0 -0
  322. package/{dist → types}/components/text-input/index.d.ts +0 -0
  323. package/{dist → types}/components/text-input/text-input.d.ts +1 -1
  324. package/{dist → types}/components/textarea/index.d.ts +0 -0
  325. package/{esm → types}/components/textarea/textarea.d.ts +1 -1
  326. package/{dist → types}/components/toast/index.d.ts +0 -0
  327. package/{dist → types}/components/toast/toast-button.d.ts +0 -0
  328. package/{dist → types}/components/toast/toast.d.ts +0 -0
  329. package/{dist → types}/components/toast/x-mark-icon.d.ts +0 -0
  330. package/{dist → types}/components/toaster/index.d.ts +0 -0
  331. package/{esm → types}/components/toaster/toaster.d.ts +5 -1
  332. package/{dist → types}/components/tooltip/index.d.ts +0 -0
  333. package/{dist → types}/components/tooltip/tooltip.d.ts +0 -0
  334. package/{dist → types}/hooks/index.d.ts +0 -0
  335. package/{dist → types}/hooks/use-disable-body-scroll.d.ts +0 -0
  336. package/{dist → types}/hooks/use-esc-key-down.d.ts +0 -0
  337. package/{dist → types}/hooks/use-focus-trap.d.ts +0 -0
  338. package/{dist → types}/hooks/use-mount-transition.d.ts +0 -0
  339. package/types/index.d.ts +3 -0
  340. package/types/lib/helpers.d.ts +4 -0
  341. package/types/lib/index.d.ts +3 -0
  342. package/{dist/shared → types/lib}/keyboard-keys.d.ts +0 -0
  343. package/{dist/shared → types/lib}/react-helpers.d.ts +0 -0
  344. package/css/draft-components-utilities.min.css +0 -1
  345. package/css/draft-components.dark.min.css +0 -1
  346. package/css/draft-components.min.css +0 -1
  347. package/dist/components/alert/alert.js +0 -16
  348. package/dist/components/alert/index.js +0 -17
  349. package/dist/components/avatar/avatar.js +0 -29
  350. package/dist/components/avatar/index.js +0 -17
  351. package/dist/components/avatar-group/avatar-group.js +0 -9
  352. package/dist/components/avatar-group/index.js +0 -17
  353. package/dist/components/badge/index.js +0 -17
  354. package/dist/components/breadcrumbs/breadcrumbs-context.js +0 -18
  355. package/dist/components/breadcrumbs/breadcrumbs-item.js +0 -20
  356. package/dist/components/breadcrumbs/breadcrumbs.js +0 -11
  357. package/dist/components/breadcrumbs/index.js +0 -18
  358. package/dist/components/button/button.d.ts +0 -19
  359. package/dist/components/button/button.js +0 -37
  360. package/dist/components/button/icon-button.js +0 -10
  361. package/dist/components/button/index.js +0 -18
  362. package/dist/components/button-group/button-group.js +0 -9
  363. package/dist/components/button-group/index.js +0 -17
  364. package/dist/components/caption/caption.js +0 -25
  365. package/dist/components/caption/icons.js +0 -20
  366. package/dist/components/caption/index.js +0 -17
  367. package/dist/components/checkbox/checkbox.js +0 -14
  368. package/dist/components/checkbox/index.js +0 -17
  369. package/dist/components/color-picker/color-picker-button.js +0 -15
  370. package/dist/components/color-picker/color-picker.js +0 -13
  371. package/dist/components/color-picker/index.js +0 -17
  372. package/dist/components/date-picker/calendar-grid-head.js +0 -15
  373. package/dist/components/date-picker/calendar-grid.js +0 -105
  374. package/dist/components/date-picker/calendar-header.js +0 -46
  375. package/dist/components/date-picker/calendar.js +0 -23
  376. package/dist/components/date-picker/date-picker.js +0 -19
  377. package/dist/components/date-picker/date-range-picker.js +0 -60
  378. package/dist/components/date-picker/date-range.js +0 -27
  379. package/dist/components/date-picker/icons.js +0 -12
  380. package/dist/components/date-picker/index.js +0 -18
  381. package/dist/components/date-picker-popover/date-picker-popover.js +0 -20
  382. package/dist/components/date-picker-popover/index.js +0 -17
  383. package/dist/components/date-range-picker-popover/date-range-picker-popover-footer.js +0 -9
  384. package/dist/components/date-range-picker-popover/date-range-picker-popover-presets.js +0 -34
  385. package/dist/components/date-range-picker-popover/date-range-picker-popover.js +0 -54
  386. package/dist/components/date-range-picker-popover/index.js +0 -18
  387. package/dist/components/date-range-picker-popover/types.js +0 -2
  388. package/dist/components/dialog/dialog-footer.js +0 -9
  389. package/dist/components/dialog/dialog-header.js +0 -16
  390. package/dist/components/dialog/dialog.js +0 -46
  391. package/dist/components/dialog/index.js +0 -20
  392. package/dist/components/dialog/x-mark-icon.js +0 -8
  393. package/dist/components/empty-state/empty-state.js +0 -9
  394. package/dist/components/empty-state/index.js +0 -17
  395. package/dist/components/file-picker/file-picker.d.ts +0 -13
  396. package/dist/components/file-picker/file-picker.js +0 -44
  397. package/dist/components/file-picker/index.js +0 -17
  398. package/dist/components/filter-buttons/filter-button.js +0 -9
  399. package/dist/components/filter-buttons/filter-buttons.js +0 -26
  400. package/dist/components/filter-buttons/index.js +0 -18
  401. package/dist/components/form-field/form-field.js +0 -25
  402. package/dist/components/form-field/index.js +0 -17
  403. package/dist/components/label/index.js +0 -17
  404. package/dist/components/label/label.js +0 -11
  405. package/dist/components/menu/index.js +0 -19
  406. package/dist/components/menu/menu-item.d.ts +0 -11
  407. package/dist/components/menu/menu-item.js +0 -12
  408. package/dist/components/menu/menu-separator.js +0 -9
  409. package/dist/components/menu/menu.d.ts +0 -31
  410. package/dist/components/nav-list/index.js +0 -19
  411. package/dist/components/nav-list/nav-list-item.js +0 -19
  412. package/dist/components/nav-list/nav-list-title.js +0 -9
  413. package/dist/components/nav-list/nav-list.js +0 -9
  414. package/dist/components/password-input/icons.js +0 -12
  415. package/dist/components/password-input/index.js +0 -17
  416. package/dist/components/password-input/password-input.d.ts +0 -10
  417. package/dist/components/password-input/password-input.js +0 -28
  418. package/dist/components/popover/index.js +0 -17
  419. package/dist/components/popover/popover.js +0 -97
  420. package/dist/components/portal/index.js +0 -17
  421. package/dist/components/portal/portal-context.js +0 -26
  422. package/dist/components/portal/portal.js +0 -10
  423. package/dist/components/positioner/index.js +0 -17
  424. package/dist/components/positioner/types.js +0 -2
  425. package/dist/components/radio/index.js +0 -17
  426. package/dist/components/radio/radio.js +0 -22
  427. package/dist/components/segmented-control/index.js +0 -17
  428. package/dist/components/segmented-control/segmented-control-button.js +0 -14
  429. package/dist/components/segmented-control/segmented-control.js +0 -47
  430. package/dist/components/select/index.js +0 -17
  431. package/dist/components/select/select.js +0 -25
  432. package/dist/components/selection-control/index.js +0 -17
  433. package/dist/components/selection-control/selection-control.js +0 -17
  434. package/dist/components/slider/index.js +0 -20
  435. package/dist/components/slider/slider-tick-marks.js +0 -16
  436. package/dist/components/slider/slider.d.ts +0 -17
  437. package/dist/components/spinner/index.js +0 -17
  438. package/dist/components/spinner/spinner.js +0 -9
  439. package/dist/components/switch/index.js +0 -17
  440. package/dist/components/switch/switch.d.ts +0 -10
  441. package/dist/components/switch/switch.js +0 -13
  442. package/dist/components/table/icons.js +0 -16
  443. package/dist/components/table/index.js +0 -23
  444. package/dist/components/table/table-body.js +0 -9
  445. package/dist/components/table/table-cell.js +0 -9
  446. package/dist/components/table/table-container.js +0 -21
  447. package/dist/components/table/table-head-cell.js +0 -28
  448. package/dist/components/table/table-head.js +0 -12
  449. package/dist/components/table/table-row.js +0 -12
  450. package/dist/components/table/table.js +0 -14
  451. package/dist/components/tabs/index.js +0 -20
  452. package/dist/components/tabs/tab-list.js +0 -66
  453. package/dist/components/tabs/tab-panel.js +0 -15
  454. package/dist/components/tabs/tab.js +0 -18
  455. package/dist/components/tabs/tabs.js +0 -10
  456. package/dist/components/tabs/types.js +0 -2
  457. package/dist/components/tag/index.js +0 -17
  458. package/dist/components/tag/tag.js +0 -14
  459. package/dist/components/text-input/index.js +0 -17
  460. package/dist/components/text-input/text-input.js +0 -24
  461. package/dist/components/textarea/index.js +0 -17
  462. package/dist/components/textarea/textarea.d.ts +0 -20
  463. package/dist/components/textarea/textarea.js +0 -38
  464. package/dist/components/toast/index.js +0 -18
  465. package/dist/components/toast/toast-button.js +0 -9
  466. package/dist/components/toast/toast.js +0 -10
  467. package/dist/components/toast/x-mark-icon.js +0 -8
  468. package/dist/components/toaster/index.js +0 -17
  469. package/dist/components/toaster/toaster.d.ts +0 -40
  470. package/dist/components/toaster/toaster.js +0 -134
  471. package/dist/components/tooltip/index.js +0 -17
  472. package/dist/components/tooltip/tooltip.js +0 -79
  473. package/dist/hooks/index.js +0 -20
  474. package/dist/index.d.ts +0 -37
  475. package/dist/index.js +0 -53
  476. package/dist/shared/util.d.ts +0 -2
  477. package/esm/components/alert/alert.d.ts +0 -10
  478. package/esm/components/alert/index.d.ts +0 -1
  479. package/esm/components/alert/index.js +0 -1
  480. package/esm/components/avatar/avatar.d.ts +0 -13
  481. package/esm/components/avatar/index.d.ts +0 -1
  482. package/esm/components/avatar/index.js +0 -1
  483. package/esm/components/avatar-group/avatar-group.d.ts +0 -7
  484. package/esm/components/avatar-group/index.d.ts +0 -1
  485. package/esm/components/avatar-group/index.js +0 -1
  486. package/esm/components/badge/badge.d.ts +0 -8
  487. package/esm/components/badge/index.d.ts +0 -1
  488. package/esm/components/badge/index.js +0 -1
  489. package/esm/components/breadcrumbs/breadcrumbs-context.d.ts +0 -9
  490. package/esm/components/breadcrumbs/breadcrumbs-item.d.ts +0 -12
  491. package/esm/components/breadcrumbs/breadcrumbs.d.ts +0 -7
  492. package/esm/components/breadcrumbs/index.d.ts +0 -2
  493. package/esm/components/breadcrumbs/index.js +0 -2
  494. package/esm/components/button/icon-button.d.ts +0 -6
  495. package/esm/components/button/index.d.ts +0 -2
  496. package/esm/components/button/index.js +0 -2
  497. package/esm/components/button-group/button-group.d.ts +0 -7
  498. package/esm/components/button-group/index.d.ts +0 -1
  499. package/esm/components/button-group/index.js +0 -1
  500. package/esm/components/caption/caption.d.ts +0 -7
  501. package/esm/components/caption/icons.d.ts +0 -5
  502. package/esm/components/caption/index.d.ts +0 -1
  503. package/esm/components/caption/index.js +0 -1
  504. package/esm/components/checkbox/checkbox.d.ts +0 -10
  505. package/esm/components/checkbox/index.d.ts +0 -1
  506. package/esm/components/checkbox/index.js +0 -1
  507. package/esm/components/color-picker/color-picker-button.d.ts +0 -12
  508. package/esm/components/color-picker/color-picker.d.ts +0 -13
  509. package/esm/components/color-picker/index.d.ts +0 -1
  510. package/esm/components/color-picker/index.js +0 -1
  511. package/esm/components/date-picker/calendar-day.d.ts +0 -17
  512. package/esm/components/date-picker/calendar-grid-head.d.ts +0 -7
  513. package/esm/components/date-picker/calendar-grid.d.ts +0 -17
  514. package/esm/components/date-picker/calendar-header.d.ts +0 -12
  515. package/esm/components/date-picker/calendar.d.ts +0 -11
  516. package/esm/components/date-picker/date-helpers.d.ts +0 -22
  517. package/esm/components/date-picker/date-picker.d.ts +0 -13
  518. package/esm/components/date-picker/date-range-picker.d.ts +0 -14
  519. package/esm/components/date-picker/date-range.d.ts +0 -13
  520. package/esm/components/date-picker/icons.d.ts +0 -3
  521. package/esm/components/date-picker/index.d.ts +0 -2
  522. package/esm/components/date-picker/index.js +0 -2
  523. package/esm/components/date-picker/parse-min-max-props.d.ts +0 -8
  524. package/esm/components/date-picker-popover/date-picker-popover.d.ts +0 -13
  525. package/esm/components/date-picker-popover/index.d.ts +0 -1
  526. package/esm/components/date-picker-popover/index.js +0 -1
  527. package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -9
  528. package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -10
  529. package/esm/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -26
  530. package/esm/components/date-range-picker-popover/helpers.d.ts +0 -2
  531. package/esm/components/date-range-picker-popover/index.d.ts +0 -2
  532. package/esm/components/date-range-picker-popover/index.js +0 -2
  533. package/esm/components/date-range-picker-popover/types.d.ts +0 -10
  534. package/esm/components/date-range-picker-popover/types.js +0 -1
  535. package/esm/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -1
  536. package/esm/components/dialog/dialog-body.d.ts +0 -8
  537. package/esm/components/dialog/dialog-context.d.ts +0 -15
  538. package/esm/components/dialog/dialog-footer.d.ts +0 -5
  539. package/esm/components/dialog/dialog-header.d.ts +0 -8
  540. package/esm/components/dialog/dialog.d.ts +0 -12
  541. package/esm/components/dialog/index.d.ts +0 -4
  542. package/esm/components/dialog/index.js +0 -4
  543. package/esm/components/dialog/x-mark-icon.d.ts +0 -2
  544. package/esm/components/empty-state/empty-state.d.ts +0 -11
  545. package/esm/components/empty-state/index.d.ts +0 -1
  546. package/esm/components/empty-state/index.js +0 -1
  547. package/esm/components/file-picker/index.d.ts +0 -1
  548. package/esm/components/file-picker/index.js +0 -1
  549. package/esm/components/filter-buttons/filter-button.d.ts +0 -7
  550. package/esm/components/filter-buttons/filter-buttons.d.ts +0 -5
  551. package/esm/components/filter-buttons/index.d.ts +0 -2
  552. package/esm/components/filter-buttons/index.js +0 -2
  553. package/esm/components/form-field/form-field.d.ts +0 -15
  554. package/esm/components/form-field/index.d.ts +0 -1
  555. package/esm/components/form-field/index.js +0 -1
  556. package/esm/components/label/index.d.ts +0 -1
  557. package/esm/components/label/index.js +0 -1
  558. package/esm/components/label/label.d.ts +0 -5
  559. package/esm/components/menu/index.d.ts +0 -3
  560. package/esm/components/menu/index.js +0 -3
  561. package/esm/components/menu/menu-separator.d.ts +0 -6
  562. package/esm/components/nav-list/index.d.ts +0 -3
  563. package/esm/components/nav-list/index.js +0 -3
  564. package/esm/components/nav-list/nav-list-item.d.ts +0 -13
  565. package/esm/components/nav-list/nav-list-title.d.ts +0 -8
  566. package/esm/components/nav-list/nav-list.d.ts +0 -5
  567. package/esm/components/password-input/icons.d.ts +0 -3
  568. package/esm/components/password-input/index.d.ts +0 -1
  569. package/esm/components/password-input/index.js +0 -1
  570. package/esm/components/popover/index.d.ts +0 -1
  571. package/esm/components/popover/index.js +0 -1
  572. package/esm/components/popover/popover.d.ts +0 -49
  573. package/esm/components/popover/use-page-click.d.ts +0 -16
  574. package/esm/components/portal/index.d.ts +0 -1
  575. package/esm/components/portal/index.js +0 -1
  576. package/esm/components/portal/portal-context.d.ts +0 -6
  577. package/esm/components/portal/portal.d.ts +0 -5
  578. package/esm/components/positioner/calc-position.d.ts +0 -32
  579. package/esm/components/positioner/index.d.ts +0 -1
  580. package/esm/components/positioner/index.js +0 -1
  581. package/esm/components/positioner/positioner.d.ts +0 -20
  582. package/esm/components/positioner/types.d.ts +0 -14
  583. package/esm/components/positioner/types.js +0 -1
  584. package/esm/components/radio/index.d.ts +0 -1
  585. package/esm/components/radio/index.js +0 -1
  586. package/esm/components/radio/radio.d.ts +0 -11
  587. package/esm/components/segmented-control/index.d.ts +0 -1
  588. package/esm/components/segmented-control/index.js +0 -1
  589. package/esm/components/segmented-control/segmented-control-button.d.ts +0 -10
  590. package/esm/components/segmented-control/segmented-control.d.ts +0 -15
  591. package/esm/components/select/index.d.ts +0 -1
  592. package/esm/components/select/index.js +0 -1
  593. package/esm/components/select/select.d.ts +0 -46
  594. package/esm/components/selection-control/index.d.ts +0 -1
  595. package/esm/components/selection-control/index.js +0 -1
  596. package/esm/components/selection-control/selection-control.d.ts +0 -14
  597. package/esm/components/slider/index.d.ts +0 -2
  598. package/esm/components/slider/index.js +0 -2
  599. package/esm/components/slider/slider-tick-marks.d.ts +0 -7
  600. package/esm/components/spinner/index.d.ts +0 -1
  601. package/esm/components/spinner/index.js +0 -1
  602. package/esm/components/spinner/spinner.d.ts +0 -7
  603. package/esm/components/switch/index.d.ts +0 -1
  604. package/esm/components/switch/index.js +0 -1
  605. package/esm/components/table/icons.d.ts +0 -4
  606. package/esm/components/table/index.d.ts +0 -7
  607. package/esm/components/table/index.js +0 -7
  608. package/esm/components/table/table-body.d.ts +0 -5
  609. package/esm/components/table/table-cell.d.ts +0 -5
  610. package/esm/components/table/table-container.d.ts +0 -13
  611. package/esm/components/table/table-head-cell.d.ts +0 -10
  612. package/esm/components/table/table-head.d.ts +0 -7
  613. package/esm/components/table/table-row.d.ts +0 -7
  614. package/esm/components/table/table.d.ts +0 -11
  615. package/esm/components/tabs/index.d.ts +0 -4
  616. package/esm/components/tabs/index.js +0 -4
  617. package/esm/components/tabs/tab-list.d.ts +0 -3
  618. package/esm/components/tabs/tab-panel.d.ts +0 -6
  619. package/esm/components/tabs/tab.d.ts +0 -7
  620. package/esm/components/tabs/tabs-context.d.ts +0 -20
  621. package/esm/components/tabs/tabs.d.ts +0 -7
  622. package/esm/components/tabs/types.d.ts +0 -2
  623. package/esm/components/tabs/types.js +0 -1
  624. package/esm/components/tag/index.d.ts +0 -1
  625. package/esm/components/tag/index.js +0 -1
  626. package/esm/components/tag/tag.d.ts +0 -13
  627. package/esm/components/text-input/index.d.ts +0 -1
  628. package/esm/components/text-input/index.js +0 -1
  629. package/esm/components/text-input/text-input.d.ts +0 -21
  630. package/esm/components/textarea/index.d.ts +0 -1
  631. package/esm/components/textarea/index.js +0 -1
  632. package/esm/components/toast/index.d.ts +0 -2
  633. package/esm/components/toast/index.js +0 -2
  634. package/esm/components/toast/toast-button.d.ts +0 -5
  635. package/esm/components/toast/toast.d.ts +0 -11
  636. package/esm/components/toast/x-mark-icon.d.ts +0 -2
  637. package/esm/components/toaster/index.d.ts +0 -1
  638. package/esm/components/toaster/index.js +0 -1
  639. package/esm/components/tooltip/index.d.ts +0 -1
  640. package/esm/components/tooltip/index.js +0 -1
  641. package/esm/components/tooltip/tooltip.d.ts +0 -25
  642. package/esm/hooks/index.d.ts +0 -4
  643. package/esm/hooks/use-disable-body-scroll.d.ts +0 -5
  644. package/esm/hooks/use-esc-key-down.d.ts +0 -17
  645. package/esm/hooks/use-focus-trap.d.ts +0 -15
  646. package/esm/hooks/use-mount-transition.d.ts +0 -32
  647. package/esm/index.d.ts +0 -37
  648. package/esm/shared/keyboard-keys.d.ts +0 -14
  649. package/esm/shared/react-helpers.d.ts +0 -13
  650. package/esm/shared/util.d.ts +0 -2
@@ -1,12 +1,13 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
2
  import { useState } from 'react';
3
- import { classNames } from '../../shared/react-helpers';
4
- import { getStartOfDay } from './date-helpers';
5
- import { CalendarHeader } from './calendar-header';
6
- import { CalendarGrid } from './calendar-grid';
7
- export function Calendar({ className, defaultFocusDay, minDate, maxDate, locale, weekStartsOn, nextMonthButtonLabel, prevMonthButtonLabel, getDayProps, onHoverDay, onFocusDay, onSelectDay, }) {
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+ import { getStartOfDay } from './date-helpers.js';
5
+ import { CalendarHeader } from './calendar-header.js';
6
+ import { CalendarGrid } from './calendar-grid.js';
7
+
8
+ function Calendar({ className, defaultFocusDay, minDate, maxDate, locale, weekStartsOn, nextMonthButtonLabel, prevMonthButtonLabel, getDayProps, onHoverDay, onFocusDay, onSelectDay, }) {
8
9
  const [focusDay, setFocusDay] = useState(() => {
9
- const focusDate = getStartOfDay(defaultFocusDay !== null && defaultFocusDay !== void 0 ? defaultFocusDay : new Date());
10
+ const focusDate = getStartOfDay(defaultFocusDay ?? new Date());
10
11
  if (minDate && focusDate < minDate) {
11
12
  return minDate;
12
13
  }
@@ -15,5 +16,7 @@ export function Calendar({ className, defaultFocusDay, minDate, maxDate, locale,
15
16
  }
16
17
  return focusDate;
17
18
  });
18
- return (_jsxs("div", { className: classNames('dc-calendar', className), children: [_jsx(CalendarHeader, { focusDay: focusDay, onChangeFocusDay: setFocusDay, locale: locale, nextMonthButtonLabel: nextMonthButtonLabel, prevMonthButtonLabel: prevMonthButtonLabel }), _jsx(CalendarGrid, { focusDay: focusDay, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, getDayProps: getDayProps, onHoverDay: onHoverDay, onFocusDay: onFocusDay, onSelectDay: onSelectDay, onChangeFocusDay: setFocusDay })] }));
19
+ return (jsxs("div", { className: classNames('dc-calendar', className), children: [jsx(CalendarHeader, { focusDay: focusDay, onChangeFocusDay: setFocusDay, locale: locale, nextMonthButtonLabel: nextMonthButtonLabel, prevMonthButtonLabel: prevMonthButtonLabel }), jsx(CalendarGrid, { focusDay: focusDay, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, getDayProps: getDayProps, onHoverDay: onHoverDay, onFocusDay: onFocusDay, onSelectDay: onSelectDay, onChangeFocusDay: setFocusDay })] }));
19
20
  }
21
+
22
+ export { Calendar };
@@ -1,58 +1,58 @@
1
- export const MONTHS_IN_YEAR = 12;
2
- export const DAYS_IN_WEEK = 7;
3
- export const LAST_WEEKDAY = 6;
4
- export const DATE_ISO_REGEX = /^([0-9]{4})-?(1[0-2]|0[1-9])-?(3[0-1]|0[1-9]|[1-2][0-9])$/;
5
- export function addYears(date, amount) {
1
+ const MONTHS_IN_YEAR = 12;
2
+ const DAYS_IN_WEEK = 7;
3
+ const LAST_WEEKDAY = 6;
4
+ const DATE_ISO_REGEX = /^([0-9]{4})-?(1[0-2]|0[1-9])-?(3[0-1]|0[1-9]|[1-2][0-9])$/;
5
+ function addYears(date, amount) {
6
6
  // Use ISO date string to deal with years less than 100.
7
7
  return parseDateISO(formatDateISOComponents(date.getFullYear() + amount, date.getMonth(), date.getDate()));
8
8
  }
9
- export function setDateYear(date, year) {
9
+ function setDateYear(date, year) {
10
10
  // Use ISO date string to deal with years less than 100.
11
11
  return parseDateISO(formatDateISOComponents(year, date.getMonth(), date.getDate()));
12
12
  }
13
- export function addMonths(date, amount) {
13
+ function addMonths(date, amount) {
14
14
  date = new Date(date);
15
15
  date.setMonth(date.getMonth() + amount);
16
16
  return date;
17
17
  }
18
- export function setDateMonth(date, month) {
18
+ function setDateMonth(date, month) {
19
19
  date = new Date(date);
20
20
  date.setMonth(month);
21
21
  return date;
22
22
  }
23
- export function addDays(date, amount) {
23
+ function addDays(date, amount) {
24
24
  date = new Date(date);
25
25
  date.setDate(date.getDate() + amount);
26
26
  return date;
27
27
  }
28
- export function getStartOfMonth(date) {
28
+ function getStartOfMonth(date) {
29
29
  date = new Date(date);
30
30
  date.setDate(1);
31
31
  return date;
32
32
  }
33
- export function getEndOfMonth(date) {
33
+ function getEndOfMonth(date) {
34
34
  date = new Date(date);
35
35
  date.setDate(1);
36
36
  date.setMonth(date.getMonth() + 1);
37
37
  date.setDate(0);
38
38
  return date;
39
39
  }
40
- export function getWeekday(date, weekStartsOn = 0) {
40
+ function getWeekday(date, weekStartsOn = 0) {
41
41
  let day = date.getDay() - weekStartsOn;
42
42
  if (day < 0) {
43
43
  day += DAYS_IN_WEEK;
44
44
  }
45
45
  return day;
46
46
  }
47
- export function getStartOfWeek(date, weekStartsOn = 0) {
47
+ function getStartOfWeek(date, weekStartsOn = 0) {
48
48
  const weekday = getWeekday(date, weekStartsOn);
49
49
  return addDays(date, -weekday);
50
50
  }
51
- export function getEndOfWeek(date, weekStartsOn = 0) {
51
+ function getEndOfWeek(date, weekStartsOn = 0) {
52
52
  const weekday = getWeekday(date, weekStartsOn);
53
53
  return addDays(date, LAST_WEEKDAY - weekday);
54
54
  }
55
- export function getStartOfDay(date) {
55
+ function getStartOfDay(date) {
56
56
  date = new Date(date);
57
57
  date.setHours(0);
58
58
  date.setMinutes(0);
@@ -60,24 +60,24 @@ export function getStartOfDay(date) {
60
60
  date.setMilliseconds(0);
61
61
  return date;
62
62
  }
63
- export function isValidDateISO(value) {
63
+ function isValidDateISO(value) {
64
64
  return DATE_ISO_REGEX.test(value);
65
65
  }
66
- export function isSameDay(a, b) {
66
+ function isSameDay(a, b) {
67
67
  return (a.getFullYear() === b.getFullYear() &&
68
68
  a.getMonth() === b.getMonth() &&
69
69
  a.getDate() === b.getDate());
70
70
  }
71
- export function isWeekend(date) {
71
+ function isWeekend(date) {
72
72
  return date.getDay() === 6 || date.getDay() === 0;
73
73
  }
74
- export function parseDateISO(date, error = 'The argument must be a date in the ISO format.') {
74
+ function parseDateISO(date, error = 'The argument must be a date in the ISO format.') {
75
75
  if (!isValidDateISO(date)) {
76
76
  throw new RangeError(error);
77
77
  }
78
78
  return getStartOfDay(new Date(date));
79
79
  }
80
- export function toDateISO(date) {
80
+ function toDateISO(date) {
81
81
  return formatDateISOComponents(date.getFullYear(), date.getMonth(), date.getDate());
82
82
  }
83
83
  function formatDateISOComponents(year, month, day) {
@@ -87,3 +87,5 @@ function formatDateISOComponents(year, month, day) {
87
87
  String(day).padStart(2, '0'),
88
88
  ].join('-');
89
89
  }
90
+
91
+ export { DATE_ISO_REGEX, DAYS_IN_WEEK, LAST_WEEKDAY, MONTHS_IN_YEAR, addDays, addMonths, addYears, getEndOfMonth, getEndOfWeek, getStartOfDay, getStartOfMonth, getStartOfWeek, getWeekday, isSameDay, isValidDateISO, isWeekend, parseDateISO, setDateMonth, setDateYear, toDateISO };
@@ -1,9 +1,10 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { isSameDay, isValidDateISO, parseDateISO, toDateISO, } from './date-helpers';
3
- import { classNames } from '../../shared/react-helpers';
4
- import { parseMinMaxProps } from './parse-min-max-props';
5
- import { Calendar } from './calendar';
6
- export function DatePicker({ value, onChangeValue, weekStartsOn = 1, min, max, locale, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, className, ...props }) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { isValidDateISO, parseDateISO, toDateISO, isSameDay } from './date-helpers.js';
3
+ import { classNames } from '../../lib/react-helpers.js';
4
+ import { parseMinMaxProps } from './parse-min-max-props.js';
5
+ import { Calendar } from './calendar.js';
6
+
7
+ function DatePicker({ value, onChangeValue, weekStartsOn = 1, min, max, locale, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, className, ...props }) {
7
8
  const { minDate, maxDate } = parseMinMaxProps({ min, max });
8
9
  const selectedDay = value && isValidDateISO(value)
9
10
  ? parseDateISO(value)
@@ -11,5 +12,7 @@ export function DatePicker({ value, onChangeValue, weekStartsOn = 1, min, max, l
11
12
  const getDayProps = (date) => ({
12
13
  isSelected: selectedDay != null && isSameDay(selectedDay, date),
13
14
  });
14
- return (_jsx("div", { ...props, className: classNames('dc-datepicker', className), children: _jsx(Calendar, { defaultFocusDay: selectedDay, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, getDayProps: getDayProps, onSelectDay: (date) => onChangeValue(toDateISO(date)) }) }));
15
+ return (jsx("div", { ...props, className: classNames('dc-datepicker', className), children: jsx(Calendar, { defaultFocusDay: selectedDay, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, getDayProps: getDayProps, onSelectDay: (date) => onChangeValue(toDateISO(date)) }) }));
15
16
  }
17
+
18
+ export { DatePicker };
@@ -1,11 +1,12 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { DateRange } from './date-range';
3
- import { isSameDay, isValidDateISO, parseDateISO, } from './date-helpers';
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { DateRange } from './date-range.js';
3
+ import { isValidDateISO, parseDateISO, isSameDay } from './date-helpers.js';
4
+ import { classNames } from '../../lib/react-helpers.js';
5
+ import { parseMinMaxProps } from './parse-min-max-props.js';
4
6
  import { useState } from 'react';
5
- import { Calendar } from './calendar';
6
- import { parseMinMaxProps } from './parse-min-max-props';
7
- import { classNames } from '../../shared/react-helpers';
8
- export function DateRangePicker({ value, onChangeValue, weekStartsOn = 1, min, max, locale, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, className, ...props }) {
7
+ import { Calendar } from './calendar.js';
8
+
9
+ function DateRangePicker({ value, onChangeValue, weekStartsOn = 1, min, max, locale, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, className, ...props }) {
9
10
  const { minDate, maxDate } = parseMinMaxProps({ min, max });
10
11
  const selectedRange = parseValue(value);
11
12
  const [start, setStart] = useState(null);
@@ -37,15 +38,15 @@ export function DateRangePicker({ value, onChangeValue, weekStartsOn = 1, min, m
37
38
  setEnd(date);
38
39
  }
39
40
  };
40
- return (_jsx("div", { ...props, className: classNames('dc-datepicker', className), children: _jsx(Calendar, { defaultFocusDay: selectedRange === null || selectedRange === void 0 ? void 0 : selectedRange.start, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, getDayProps: getCalendarDayProps, onHoverDay: updateRange, onFocusDay: updateRange, onSelectDay: (date) => {
41
- if (!start) {
42
- setStart(date);
43
- }
44
- else {
41
+ return (jsx("div", { ...props, className: classNames('dc-datepicker', className), children: jsx(Calendar, { defaultFocusDay: selectedRange?.start, minDate: minDate, maxDate: maxDate, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, getDayProps: getCalendarDayProps, onHoverDay: updateRange, onFocusDay: updateRange, onSelectDay: (date) => {
42
+ if (start) {
45
43
  setStart(null);
46
44
  setEnd(null);
47
45
  onChangeValue(DateRange.create(start, date).toDateISORange());
48
46
  }
47
+ else {
48
+ setStart(date);
49
+ }
49
50
  } }) }));
50
51
  }
51
52
  function parseValue(value) {
@@ -54,3 +55,5 @@ function parseValue(value) {
54
55
  }
55
56
  return null;
56
57
  }
58
+
59
+ export { DateRangePicker };
@@ -1,5 +1,6 @@
1
- import { isSameDay, toDateISO } from './date-helpers';
2
- export class DateRange {
1
+ import { isSameDay, toDateISO } from './date-helpers.js';
2
+
3
+ class DateRange {
3
4
  constructor(start, end) {
4
5
  if (start > end) {
5
6
  [start, end] = [end, start];
@@ -21,3 +22,5 @@ export class DateRange {
21
22
  };
22
23
  }
23
24
  }
25
+
26
+ export { DateRange };
@@ -1,7 +1,10 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- export function ChevronLeftIcon(props) {
3
- return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "1em", height: "1em", ...props, children: _jsx("path", { fill: "none", stroke: "currentColor", strokeWidth: 3, strokeLinecap: "round", strokeLinejoin: "round", d: "M15.75 19.5L8.25 12l7.5-7.5" }) }));
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ function ChevronLeftIcon(props) {
4
+ return (jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "1em", height: "1em", ...props, children: jsx("path", { fill: "none", stroke: "currentColor", strokeWidth: 3, strokeLinecap: "round", strokeLinejoin: "round", d: "M15.75 19.5L8.25 12l7.5-7.5" }) }));
4
5
  }
5
- export function ChevronRightIcon(props) {
6
- return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "1em", height: "1em", ...props, children: _jsx("path", { fill: "none", stroke: "currentColor", strokeWidth: 3, strokeLinecap: "round", strokeLinejoin: "round", d: "M8.25 4.5l7.5 7.5-7.5 7.5" }) }));
6
+ function ChevronRightIcon(props) {
7
+ return (jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "1em", height: "1em", ...props, children: jsx("path", { fill: "none", stroke: "currentColor", strokeWidth: 3, strokeLinecap: "round", strokeLinejoin: "round", d: "M8.25 4.5l7.5 7.5-7.5 7.5" }) }));
7
8
  }
9
+
10
+ export { ChevronLeftIcon, ChevronRightIcon };
@@ -1,5 +1,6 @@
1
- import { parseDateISO } from './date-helpers';
2
- export function parseMinMaxProps(props) {
1
+ import { parseDateISO } from './date-helpers.js';
2
+
3
+ function parseMinMaxProps(props) {
3
4
  const min = props.min;
4
5
  const max = props.max;
5
6
  const minDate = min
@@ -13,3 +14,5 @@ export function parseMinMaxProps(props) {
13
14
  }
14
15
  return { minDate, maxDate };
15
16
  }
17
+
18
+ export { parseMinMaxProps };
@@ -1,16 +1,22 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { classNames } from '../../shared/react-helpers';
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
3
  import { useRef } from 'react';
4
- import { Popover } from '../popover';
5
- import { DatePicker } from '../date-picker';
6
- export function DatePickerPopover({ defaultIsOpen = false, footer, className, children, value, onChangeValue,
4
+ import { Popover } from '../popover/popover.js';
5
+ import { DatePicker } from '../date-picker/date-picker.js';
6
+ import '../button/button.js';
7
+ import '../button/icon-button.js';
8
+ import '../select/select.js';
9
+ import '../text-input/text-input.js';
10
+
11
+ function DatePickerPopover({ defaultIsOpen = false, footer, className, children, value, onChangeValue,
7
12
  // DatePickerProps
8
13
  min, max, locale, weekStartsOn, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, }) {
9
14
  const popoverRef = useRef(null);
10
15
  const handleChangeValue = (value) => {
11
- var _a;
12
16
  onChangeValue(value);
13
- (_a = popoverRef.current) === null || _a === void 0 ? void 0 : _a.close();
17
+ popoverRef.current?.close();
14
18
  };
15
- return (_jsxs(Popover, { ref: popoverRef, className: classNames('dc-date-picker-popover', className), defaultIsOpen: defaultIsOpen, anchor: children, children: [_jsx(DatePicker, { min: min, max: max, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, value: value, onChangeValue: handleChangeValue }), footer] }));
19
+ return (jsxs(Popover, { ref: popoverRef, className: classNames('dc-date-picker-popover', className), defaultIsOpen: defaultIsOpen, anchor: children, children: [jsx(DatePicker, { min: min, max: max, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, value: value, onChangeValue: handleChangeValue }), footer] }));
16
20
  }
21
+
22
+ export { DatePickerPopover };
@@ -1,5 +1,9 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Button } from '../button';
3
- export function DateRangePickerPopoverFooter({ children, cancelButtonLabel, confirmButtonLabel, onClickCancelButton, onClickConfirmButton, }) {
4
- return (_jsxs("div", { className: "dc-date-range-picker-popover__footer", children: [Boolean(children) && (_jsx("div", { className: "dc-date-range-picker-popover__footer-content", children: children })), _jsx(Button, { className: "dc-date-range-picker-popover__footer-cancel", variant: "tinted", onClick: onClickCancelButton, children: cancelButtonLabel }), _jsx(Button, { className: "dc-date-range-picker-popover__footer-confirm", appearance: "primary", onClick: onClickConfirmButton, children: confirmButtonLabel })] }));
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { Button } from '../button/button.js';
3
+ import '../button/icon-button.js';
4
+
5
+ function DateRangePickerPopoverFooter({ children, cancelButtonLabel, confirmButtonLabel, onClickCancelButton, onClickConfirmButton, }) {
6
+ return (jsxs("div", { className: "dc-date-range-picker-popover__footer", children: [Boolean(children) && (jsx("div", { className: "dc-date-range-picker-popover__footer-content", children: children })), jsx(Button, { className: "dc-date-range-picker-popover__footer-cancel", variant: "tinted", onClick: onClickCancelButton, children: cancelButtonLabel }), jsx(Button, { className: "dc-date-range-picker-popover__footer-confirm", appearance: "primary", onClick: onClickConfirmButton, children: confirmButtonLabel })] }));
5
7
  }
8
+
9
+ export { DateRangePickerPopoverFooter };
@@ -1,10 +1,11 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
2
  import { useId } from 'react';
3
- import { findSelectedOption } from './helpers';
4
- import { Select } from '../select';
5
- import { Radio } from '../radio';
6
- import { SelectionControl } from '../selection-control';
7
- export function DateRangePickerPopoverPresets({ isCompactView, customPresetLabel, options, value, onChangeValue, }) {
3
+ import { findSelectedOption } from './helpers.js';
4
+ import { Select } from '../select/select.js';
5
+ import { Radio } from '../radio/radio.js';
6
+ import { SelectionControl } from '../selection-control/selection-control.js';
7
+
8
+ function DateRangePickerPopoverPresets({ isCompactView, customPresetLabel, options, value, onChangeValue, }) {
8
9
  const id = useId();
9
10
  const name = `${id}-date-preset`;
10
11
  const selectedOption = findSelectedOption(value, options);
@@ -20,11 +21,13 @@ export function DateRangePickerPopoverPresets({ isCompactView, customPresetLabel
20
21
  }
21
22
  }
22
23
  if (isCompactView) {
23
- return (_jsx("div", { className: "dc-date-range-picker-popover__presets", children: _jsxs(Select, { size: "md", isBlock: true, value: selectedPreset, onChange: handleChange, children: [_jsx("option", { value: "", disabled: true, children: customPresetLabel }), options.map((option) => (_jsx("option", { value: option.preset, children: option.label }, option.preset)))] }) }));
24
+ return (jsx("div", { className: "dc-date-range-picker-popover__presets", children: jsxs(Select, { size: "md", isBlock: true, value: selectedPreset, onChange: handleChange, children: [jsx("option", { value: "", disabled: true, children: customPresetLabel }), options.map((option) => (jsx("option", { value: option.preset, children: option.label }, option.preset)))] }) }));
24
25
  }
25
- return (_jsx("ul", { className: "dc-date-range-picker-popover__presets", children: options.map((option) => {
26
+ return (jsx("ul", { className: "dc-date-range-picker-popover__presets", children: options.map((option) => {
26
27
  const preset = option.preset;
27
28
  const id = `${name}-${preset}`;
28
- return (_jsx("li", { children: _jsx(SelectionControl, { label: option.label, labelFor: id, children: _jsx(Radio, { icon: "check", id: id, name: name, value: preset, checked: preset === selectedPreset, onChange: handleChange }) }) }, option.preset));
29
+ return (jsx("li", { children: jsx(SelectionControl, { label: option.label, labelFor: id, children: jsx(Radio, { icon: "check", id: id, name: name, value: preset, checked: preset === selectedPreset, onChange: handleChange }) }) }, option.preset));
29
30
  }) }));
30
31
  }
32
+
33
+ export { DateRangePickerPopoverPresets };
@@ -1,14 +1,19 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { classNames } from '../../shared/react-helpers';
3
- import { assertIfNullable } from '../../shared/util';
4
- import { findSelectedOption } from './helpers';
5
- import { useRef, useState } from 'react';
6
- import { useIsCompactView } from './use-is-compact-view';
7
- import { Popover, } from '../popover';
8
- import { DateRangePicker } from '../date-picker';
9
- import { DateRangePickerPopoverFooter } from './date-range-picker-popover-footer';
10
- import { DateRangePickerPopoverPresets } from './date-range-picker-popover-presets';
11
- export function DateRangePickerPopover({ defaultIsOpen = false, compactViewBreakpoint = '(max-width: 599px)', customPreset = 'custom', customPresetLabel = 'Custom date preset', placement = 'bottom', alignment = 'start', cancelButtonLabel = 'Cancel', confirmButtonLabel = 'Confirm', footer = null, className, options = [], children, value, onChangeValue,
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+ import { assertIfNullable } from '../../lib/helpers.js';
4
+ import { findSelectedOption } from './helpers.js';
5
+ import { useState, useRef } from 'react';
6
+ import { useIsCompactView } from './use-is-compact-view.js';
7
+ import { Popover } from '../popover/popover.js';
8
+ import '../button/button.js';
9
+ import '../button/icon-button.js';
10
+ import '../select/select.js';
11
+ import '../text-input/text-input.js';
12
+ import { DateRangePicker } from '../date-picker/date-range-picker.js';
13
+ import { DateRangePickerPopoverFooter } from './date-range-picker-popover-footer.js';
14
+ import { DateRangePickerPopoverPresets } from './date-range-picker-popover-presets.js';
15
+
16
+ function DateRangePickerPopover({ defaultIsOpen = false, compactViewBreakpoint = '(max-width: 599px)', customPreset = 'custom', customPresetLabel = 'Custom date preset', placement = 'bottom', alignment = 'start', cancelButtonLabel = 'Cancel', confirmButtonLabel = 'Confirm', footer = null, className, options = [], children, value, onChangeValue,
12
17
  // DateRangePickerProps
13
18
  min, max, locale, weekStartsOn, prevMonthButtonLabel, nextMonthButtonLabel, monthSelectLabel, yearInputLabel, }) {
14
19
  const [selection, setSelection] = useState(value);
@@ -41,10 +46,12 @@ min, max, locale, weekStartsOn, prevMonthButtonLabel, nextMonthButtonLabel, mont
41
46
  setSelection(selection);
42
47
  }
43
48
  }
44
- return (_jsxs(Popover, { className: classNames(className, {
49
+ return (jsxs(Popover, { className: classNames(className, {
45
50
  'dc-date-range-picker-popover': true,
46
51
  'dc-date-range-picker-popover_compact': isCompactView,
47
- }), ref: popoverRef, placement: placement, alignment: alignment, anchor: children, defaultIsOpen: defaultIsOpen, onOpen: () => setSelection(value), children: [options.length > 0 && (_jsx(DateRangePickerPopoverPresets, { isCompactView: isCompactView, customPresetLabel: customPresetLabel, options: options, value: selection, onChangeValue: setSelection })), _jsx(DateRangePicker, { className: "dc-date-range-picker-popover__calendar", min: min, max: max, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, value: selection && selection.range, onChangeValue: handleChangeDateRange }), _jsx(DateRangePickerPopoverFooter, { cancelButtonLabel: cancelButtonLabel, confirmButtonLabel: confirmButtonLabel, onClickCancelButton: handleClickCancelButton, onClickConfirmButton: handleClickConfirmButton, children: typeof footer === 'function'
52
+ }), ref: popoverRef, placement: placement, alignment: alignment, anchor: children, defaultIsOpen: defaultIsOpen, onOpen: () => setSelection(value), children: [options.length > 0 && (jsx(DateRangePickerPopoverPresets, { isCompactView: isCompactView, customPresetLabel: customPresetLabel, options: options, value: selection, onChangeValue: setSelection })), jsx(DateRangePicker, { className: "dc-date-range-picker-popover__calendar", min: min, max: max, locale: locale, weekStartsOn: weekStartsOn, prevMonthButtonLabel: prevMonthButtonLabel, nextMonthButtonLabel: nextMonthButtonLabel, monthSelectLabel: monthSelectLabel, yearInputLabel: yearInputLabel, value: selection && selection.range, onChangeValue: handleChangeDateRange }), jsx(DateRangePickerPopoverFooter, { cancelButtonLabel: cancelButtonLabel, confirmButtonLabel: confirmButtonLabel, onClickCancelButton: handleClickCancelButton, onClickConfirmButton: handleClickConfirmButton, children: typeof footer === 'function'
48
53
  ? footer({ selection })
49
54
  : footer })] }));
50
55
  }
56
+
57
+ export { DateRangePickerPopover };
@@ -1,4 +1,4 @@
1
- export function findSelectedOption(selection, options) {
1
+ function findSelectedOption(selection, options) {
2
2
  if (!selection) {
3
3
  return null;
4
4
  }
@@ -9,3 +9,5 @@ export function findSelectedOption(selection, options) {
9
9
  });
10
10
  return selectedOption || null;
11
11
  }
12
+
13
+ export { findSelectedOption };
@@ -1,12 +1,13 @@
1
- import { useEffect, useMemo, useState } from 'react';
2
- export function useIsCompactView(breakpoint) {
1
+ import { useMemo, useState, useEffect } from 'react';
2
+
3
+ function useIsCompactView(breakpoint) {
3
4
  const compactViewMediaQuery = useMemo(() => {
4
5
  if (typeof document !== 'undefined') {
5
6
  return window.matchMedia(breakpoint);
6
7
  }
7
8
  return null;
8
9
  }, [breakpoint]);
9
- const [isCompactView, setIsCompactView] = useState(() => (compactViewMediaQuery === null || compactViewMediaQuery === void 0 ? void 0 : compactViewMediaQuery.matches) || false);
10
+ const [isCompactView, setIsCompactView] = useState(() => compactViewMediaQuery?.matches || false);
10
11
  useEffect(() => {
11
12
  if (compactViewMediaQuery) {
12
13
  const handleChange = () => {
@@ -20,3 +21,5 @@ export function useIsCompactView(breakpoint) {
20
21
  }, [compactViewMediaQuery]);
21
22
  return isCompactView;
22
23
  }
24
+
25
+ export { useIsCompactView };
@@ -1,8 +1,9 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { useEffect, useRef } from 'react';
3
- import { assertIfNullable } from '../../shared/util';
4
- import { classNames } from '../../shared/react-helpers';
5
- export function DialogBody({ scrollShadowTop = false, scrollShadowBottom = false, className, children, }) {
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { useRef, useEffect } from 'react';
3
+ import { assertIfNullable } from '../../lib/helpers.js';
4
+ import { classNames } from '../../lib/react-helpers.js';
5
+
6
+ function DialogBody({ scrollShadowTop = false, scrollShadowBottom = false, className, children, }) {
6
7
  const ref = useRef(null);
7
8
  useEffect(() => {
8
9
  if (!scrollShadowTop && !scrollShadowBottom) {
@@ -33,15 +34,17 @@ export function DialogBody({ scrollShadowTop = false, scrollShadowBottom = false
33
34
  }
34
35
  }
35
36
  };
36
- const resizeObserver = typeof ResizeObserver !== 'undefined'
37
- ? new ResizeObserver(changeShadowsVisibility)
38
- : null;
39
- resizeObserver === null || resizeObserver === void 0 ? void 0 : resizeObserver.observe(el);
37
+ const resizeObserver = typeof ResizeObserver === 'undefined'
38
+ ? null
39
+ : new ResizeObserver(changeShadowsVisibility);
40
+ resizeObserver?.observe(el);
40
41
  el.addEventListener('scroll', changeShadowsVisibility);
41
42
  return () => {
42
- resizeObserver === null || resizeObserver === void 0 ? void 0 : resizeObserver.unobserve(el);
43
+ resizeObserver?.unobserve(el);
43
44
  el.removeEventListener('scroll', changeShadowsVisibility);
44
45
  };
45
46
  }, [scrollShadowTop, scrollShadowBottom]);
46
- return (_jsx("div", { ref: ref, className: classNames('dc-dialog-body', className), children: children }));
47
+ return (jsx("div", { ref: ref, className: classNames('dc-dialog-body', className), children: children }));
47
48
  }
49
+
50
+ export { DialogBody };
@@ -1,18 +1,21 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
1
+ import { jsx } from 'react/jsx-runtime';
2
2
  import { createContext, useContext } from 'react';
3
+
3
4
  const DialogContext = createContext(null);
4
- export function useDialogContext() {
5
+ function useDialogContext() {
5
6
  const context = useContext(DialogContext);
6
7
  if (!context) {
7
8
  throw new Error('useDialogContext must be used within DialogProvider');
8
9
  }
9
10
  return context;
10
11
  }
11
- export function DialogContextProvider(props) {
12
- return (_jsx(DialogContext.Provider, { value: {
12
+ function DialogContextProvider(props) {
13
+ return (jsx(DialogContext.Provider, { value: {
13
14
  titleId: props.titleId,
14
15
  descriptionId: props.descriptionId,
15
16
  isOpen: props.isOpen,
16
17
  onClose: props.onClose,
17
18
  }, children: props.children }));
18
19
  }
20
+
21
+ export { DialogContextProvider, useDialogContext };
@@ -1,5 +1,8 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { classNames } from '../../shared/react-helpers';
3
- export function DialogFooter({ className, children, }) {
4
- return (_jsx("div", { className: classNames('dc-dialog-footer', className), children: children }));
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+
4
+ function DialogFooter({ className, children, }) {
5
+ return (jsx("div", { className: classNames('dc-dialog-footer', className), children: children }));
5
6
  }
7
+
8
+ export { DialogFooter };
@@ -1,12 +1,16 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { classNames } from '../../shared/react-helpers';
3
- import { useDialogContext } from './dialog-context';
4
- import { IconButton } from '../button';
5
- import { XMarkIcon } from './x-mark-icon';
6
- export function DialogHeader({ heading, subheading, className, children, }) {
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { classNames } from '../../lib/react-helpers.js';
3
+ import { useDialogContext } from './dialog-context.js';
4
+ import '../button/button.js';
5
+ import { IconButton } from '../button/icon-button.js';
6
+ import { XMarkIcon } from './x-mark-icon.js';
7
+
8
+ function DialogHeader({ heading, subheading, className, children, }) {
7
9
  const { titleId, descriptionId, onClose, } = useDialogContext();
8
10
  const shouldRenderHeading = Boolean(heading);
9
11
  const shouldRenderDescription = Boolean(subheading);
10
12
  const shouldRenderChildren = Boolean(children);
11
- return (_jsxs("div", { className: classNames(className, 'dc-dialog-header'), children: [_jsxs("div", { className: "dc-dialog-header__title-bar", children: [shouldRenderHeading && (_jsx("h2", { id: titleId, className: "dc-dialog-header__heading", children: heading })), _jsx(IconButton, { icon: _jsx(XMarkIcon, { width: 18, height: 18, strokeWidth: 2 }), variant: "plain", className: "dc-dialog-header__close-btn", onClick: () => onClose() })] }), shouldRenderDescription && (_jsx("div", { id: descriptionId, className: "dc-dialog-header__subheading", children: subheading })), shouldRenderChildren && (_jsx("div", { className: "dc-dialog-header__body", children: children }))] }));
13
+ return (jsxs("div", { className: classNames(className, 'dc-dialog-header'), children: [jsxs("div", { className: "dc-dialog-header__title-bar", children: [shouldRenderHeading && (jsx("h2", { id: titleId, className: "dc-dialog-header__heading", children: heading })), jsx(IconButton, { icon: jsx(XMarkIcon, { width: 18, height: 18, strokeWidth: 2 }), variant: "plain", className: "dc-dialog-header__close-btn", onClick: () => onClose() })] }), shouldRenderDescription && (jsx("div", { id: descriptionId, className: "dc-dialog-header__subheading", children: subheading })), shouldRenderChildren && (jsx("div", { className: "dc-dialog-header__body", children: children }))] }));
12
14
  }
15
+
16
+ export { DialogHeader };
@@ -1,10 +1,14 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useEffect, useId, useRef, } from 'react';
3
- import { classNames, focusElement } from '../../shared/react-helpers';
4
- import { useDisableBodyScroll, useEscKeyDown, useFocusTrap, useMountTransition, } from '../../hooks';
5
- import { Portal } from '../portal';
6
- import { DialogContextProvider } from './dialog-context';
7
- export function Dialog({ width = 'md', isOpen = false, openFocusRef, closeFocusRef, onClose, className, children, ...props }) {
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { useId, useRef, useEffect } from 'react';
3
+ import { focusElement, classNames } from '../../lib/react-helpers.js';
4
+ import { useMountTransition } from '../../hooks/use-mount-transition.js';
5
+ import { useDisableBodyScroll } from '../../hooks/use-disable-body-scroll.js';
6
+ import { useEscKeyDown } from '../../hooks/use-esc-key-down.js';
7
+ import { useFocusTrap } from '../../hooks/use-focus-trap.js';
8
+ import { Portal } from '../portal/portal.js';
9
+ import { DialogContextProvider } from './dialog-context.js';
10
+
11
+ function Dialog({ width = 'md', isOpen = false, openFocusRef, closeFocusRef, onClose, className, children, ...props }) {
8
12
  const defaultId = useId();
9
13
  const dialogRef = useRef(null);
10
14
  const durationMs = 200;
@@ -16,8 +20,8 @@ export function Dialog({ width = 'md', isOpen = false, openFocusRef, closeFocusR
16
20
  });
17
21
  useEffect(() => {
18
22
  if (isOpen) {
19
- const openFocus = openFocusRef === null || openFocusRef === void 0 ? void 0 : openFocusRef.current;
20
- const closeFocus = closeFocusRef === null || closeFocusRef === void 0 ? void 0 : closeFocusRef.current;
23
+ const openFocus = openFocusRef?.current;
24
+ const closeFocus = closeFocusRef?.current;
21
25
  focusElement(openFocus);
22
26
  return () => focusElement(closeFocus);
23
27
  }
@@ -33,10 +37,12 @@ export function Dialog({ width = 'md', isOpen = false, openFocusRef, closeFocusR
33
37
  const id = props.id || defaultId;
34
38
  const titleId = `dialog-title-${id}`;
35
39
  const descriptionId = `dialog-description-${id}`;
36
- return (_jsx(Portal, { children: _jsxs("div", { style: {
40
+ return (jsx(Portal, { children: jsxs("div", { style: {
37
41
  '--dc-dialog-transition-duration': `${durationMs}ms`,
38
- }, className: classNames('dc-dialog', transitionClass), children: [_jsx("div", { className: "dc-dialog-backdrop" }), _jsx("div", { ...props, ref: dialogRef, className: classNames(className, {
42
+ }, className: classNames('dc-dialog', transitionClass), children: [jsx("div", { className: "dc-dialog-backdrop" }), jsx("div", { ...props, ref: dialogRef, className: classNames(className, {
39
43
  'dc-dialog-modal': true,
40
44
  [`dc-dialog-modal_${width}`]: width,
41
- }), role: "dialog", id: id, "aria-labelledby": titleId, "aria-describedby": descriptionId, "aria-modal": true, children: _jsx(DialogContextProvider, { titleId: titleId, descriptionId: descriptionId, isOpen: isOpen, onClose: onClose, children: children }) })] }) }));
45
+ }), role: "dialog", id: id, "aria-labelledby": titleId, "aria-describedby": descriptionId, "aria-modal": true, children: jsx(DialogContextProvider, { titleId: titleId, descriptionId: descriptionId, isOpen: isOpen, onClose: onClose, children: children }) })] }) }));
42
46
  }
47
+
48
+ export { Dialog };
@@ -1,4 +1,7 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- export function XMarkIcon(props) {
3
- return (_jsx("svg", { width: 24, height: 24, fill: "none", stroke: "currentColor", strokeWidth: 1.5, ...props, xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" }) }));
1
+ import { jsx } from 'react/jsx-runtime';
2
+
3
+ function XMarkIcon(props) {
4
+ return (jsx("svg", { width: 24, height: 24, fill: "none", stroke: "currentColor", strokeWidth: 1.5, ...props, xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M6 18L18 6M6 6l12 12" }) }));
4
5
  }
6
+
7
+ export { XMarkIcon };