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.
- package/cjs/components/alert/alert.cjs +18 -0
- package/cjs/components/avatar/avatar.cjs +31 -0
- package/cjs/components/avatar-group/avatar-group.cjs +10 -0
- package/cjs/components/badge/{badge.js → badge.cjs} +7 -6
- package/cjs/components/breadcrumbs/breadcrumbs-context.cjs +19 -0
- package/cjs/components/breadcrumbs/breadcrumbs-item.cjs +21 -0
- package/cjs/components/breadcrumbs/breadcrumbs.cjs +12 -0
- package/cjs/components/button/button.cjs +39 -0
- package/cjs/components/button/icon-button.cjs +12 -0
- package/cjs/components/button-group/button-group.cjs +10 -0
- package/cjs/components/caption/caption.cjs +27 -0
- package/cjs/components/caption/icons.cjs +21 -0
- package/cjs/components/checkbox/checkbox.cjs +16 -0
- package/cjs/components/date-picker/{calendar-day.js → calendar-day.cjs} +8 -7
- package/cjs/components/date-picker/calendar-grid-head.cjs +16 -0
- package/cjs/components/date-picker/calendar-grid.cjs +106 -0
- package/cjs/components/date-picker/calendar-header.cjs +48 -0
- package/cjs/components/date-picker/calendar.cjs +24 -0
- package/cjs/components/date-picker/{date-helpers.js → date-helpers.cjs} +30 -26
- package/cjs/components/date-picker/date-picker.cjs +20 -0
- package/cjs/components/date-picker/date-range-picker.cjs +61 -0
- package/cjs/components/date-picker/date-range.cjs +28 -0
- package/cjs/components/date-picker/icons.cjs +13 -0
- package/cjs/components/date-picker/{parse-min-max-props.js → parse-min-max-props.cjs} +7 -6
- package/cjs/components/date-picker-popover/date-picker-popover.cjs +24 -0
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.cjs +11 -0
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.cjs +35 -0
- package/cjs/components/date-range-picker-popover/date-range-picker-popover.cjs +59 -0
- package/cjs/components/date-range-picker-popover/{helpers.js → helpers.cjs} +3 -3
- package/cjs/components/date-range-picker-popover/{use-is-compact-view.js → use-is-compact-view.cjs} +8 -7
- package/cjs/components/dialog/{dialog-body.js → dialog-body.cjs} +17 -16
- package/cjs/components/dialog/{dialog-context.js → dialog-context.cjs} +10 -9
- package/cjs/components/dialog/dialog-footer.cjs +10 -0
- package/cjs/components/dialog/dialog-header.cjs +18 -0
- package/cjs/components/dialog/dialog.cjs +50 -0
- package/cjs/components/dialog/x-mark-icon.cjs +9 -0
- package/cjs/components/empty-state/empty-state.cjs +10 -0
- package/cjs/components/file-picker/file-picker.cjs +47 -0
- package/cjs/components/filter-buttons/filter-button.cjs +11 -0
- package/cjs/components/filter-buttons/filter-buttons.cjs +27 -0
- package/cjs/components/form-field/form-field.cjs +26 -0
- package/cjs/components/index.cjs +123 -0
- package/cjs/components/label/label.cjs +13 -0
- package/cjs/components/menu/menu-item.cjs +14 -0
- package/cjs/components/menu/menu-separator.cjs +10 -0
- package/cjs/components/menu/{menu.js → menu.cjs} +50 -52
- package/cjs/components/nav-list/nav-list-item.cjs +20 -0
- package/cjs/components/nav-list/nav-list-title.cjs +10 -0
- package/cjs/components/nav-list/nav-list.cjs +10 -0
- package/cjs/components/password-input/icons.cjs +13 -0
- package/cjs/components/password-input/password-input.cjs +30 -0
- package/cjs/components/popover/popover.cjs +97 -0
- package/cjs/components/popover/{use-page-click.js → use-page-click.cjs} +8 -7
- package/cjs/components/portal/portal-context.cjs +22 -0
- package/cjs/components/portal/portal.cjs +11 -0
- package/cjs/components/positioner/{calc-position.js → calc-position.cjs} +4 -4
- package/cjs/components/positioner/{positioner.js → positioner.cjs} +14 -13
- package/cjs/components/radio/radio.cjs +24 -0
- package/cjs/components/segmented-control/segmented-control-button.cjs +15 -0
- package/cjs/components/segmented-control/segmented-control.cjs +48 -0
- package/cjs/components/select/select.cjs +27 -0
- package/cjs/components/selection-control/selection-control.cjs +18 -0
- package/cjs/components/slider/slider-tick-marks.cjs +17 -0
- package/cjs/components/slider/{slider.js → slider.cjs} +16 -14
- package/cjs/components/spinner/spinner.cjs +11 -0
- package/cjs/components/switch/switch.cjs +15 -0
- package/cjs/components/table/icons.cjs +17 -0
- package/cjs/components/table/table-body.cjs +11 -0
- package/cjs/components/table/table-cell.cjs +11 -0
- package/cjs/components/table/table-container.cjs +23 -0
- package/cjs/components/table/table-head-cell.cjs +30 -0
- package/cjs/components/table/table-head.cjs +14 -0
- package/cjs/components/table/table-row.cjs +14 -0
- package/cjs/components/table/table.cjs +16 -0
- package/cjs/components/tabs/tab-list.cjs +67 -0
- package/cjs/components/tabs/tab-panel.cjs +16 -0
- package/cjs/components/tabs/tab.cjs +19 -0
- package/cjs/components/tabs/{tabs-context.js → tabs-context.cjs} +13 -12
- package/cjs/components/tabs/tabs.cjs +11 -0
- package/cjs/components/tag/{tag.js → tag.cjs} +7 -6
- package/cjs/components/text-input/text-input.cjs +26 -0
- package/cjs/components/textarea/textarea.cjs +40 -0
- package/cjs/components/toast/toast-button.cjs +11 -0
- package/cjs/components/toast/toast.cjs +11 -0
- package/cjs/components/toast/x-mark-icon.cjs +9 -0
- package/cjs/components/toaster/toaster.cjs +115 -0
- package/cjs/components/tooltip/tooltip.cjs +75 -0
- package/cjs/hooks/index.cjs +13 -0
- package/cjs/hooks/{use-disable-body-scroll.js → use-disable-body-scroll.cjs} +9 -8
- package/cjs/hooks/{use-esc-key-down.js → use-esc-key-down.cjs} +10 -9
- package/cjs/hooks/{use-focus-trap.js → use-focus-trap.cjs} +12 -11
- package/cjs/hooks/{use-mount-transition.js → use-mount-transition.cjs} +13 -12
- package/cjs/index.cjs +141 -0
- package/cjs/lib/{helpers.js → helpers.cjs} +4 -4
- package/cjs/lib/index.cjs +15 -0
- package/cjs/lib/{keyboard-keys.js → keyboard-keys.cjs} +5 -4
- package/cjs/lib/{react-helpers.js → react-helpers.cjs} +9 -8
- package/css/draft-components-utilities.css +4 -0
- package/css/draft-components.css +15 -1
- package/esm/components/alert/alert.js +9 -5
- package/esm/components/avatar/avatar.js +17 -14
- package/esm/components/avatar-group/avatar-group.js +7 -4
- package/esm/components/badge/badge.js +7 -4
- package/esm/components/breadcrumbs/breadcrumbs-context.js +7 -4
- package/esm/components/breadcrumbs/breadcrumbs-item.js +10 -7
- package/esm/components/breadcrumbs/breadcrumbs.js +9 -6
- package/esm/components/button/button.js +11 -8
- package/esm/components/button/icon-button.js +8 -5
- package/esm/components/button-group/button-group.js +7 -4
- package/esm/components/caption/caption.js +10 -7
- package/esm/components/caption/icons.js +12 -9
- package/esm/components/checkbox/checkbox.js +12 -9
- package/esm/components/date-picker/calendar-day.js +8 -5
- package/esm/components/date-picker/calendar-grid-head.js +8 -5
- package/esm/components/date-picker/calendar-grid.js +15 -12
- package/esm/components/date-picker/calendar-header.js +20 -16
- package/esm/components/date-picker/calendar.js +11 -8
- package/esm/components/date-picker/date-helpers.js +22 -20
- package/esm/components/date-picker/date-picker.js +10 -7
- package/esm/components/date-picker/date-range-picker.js +15 -12
- package/esm/components/date-picker/date-range.js +5 -2
- package/esm/components/date-picker/icons.js +8 -5
- package/esm/components/date-picker/parse-min-max-props.js +5 -2
- package/esm/components/date-picker-popover/date-picker-popover.js +14 -8
- package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.js +8 -4
- package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.js +12 -9
- package/esm/components/date-range-picker-popover/date-range-picker-popover.js +20 -13
- package/esm/components/date-range-picker-popover/helpers.js +3 -1
- package/esm/components/date-range-picker-popover/use-is-compact-view.js +6 -3
- package/esm/components/dialog/dialog-body.js +14 -11
- package/esm/components/dialog/dialog-context.js +7 -4
- package/esm/components/dialog/dialog-footer.js +7 -4
- package/esm/components/dialog/dialog-header.js +11 -7
- package/esm/components/dialog/dialog.js +18 -12
- package/esm/components/dialog/x-mark-icon.js +6 -3
- package/esm/components/empty-state/empty-state.js +7 -4
- package/esm/components/file-picker/file-picker.js +13 -9
- package/esm/components/filter-buttons/filter-button.js +7 -4
- package/esm/components/filter-buttons/filter-buttons.js +9 -6
- package/esm/components/form-field/form-field.js +11 -8
- package/esm/components/index.js +59 -37
- package/esm/components/label/label.js +7 -4
- package/esm/components/menu/menu-item.js +9 -6
- package/esm/components/menu/menu-separator.js +7 -4
- package/esm/components/menu/menu.js +24 -24
- package/esm/components/nav-list/nav-list-item.js +10 -7
- package/esm/components/nav-list/nav-list-title.js +7 -4
- package/esm/components/nav-list/nav-list.js +7 -4
- package/esm/components/password-input/icons.js +8 -5
- package/esm/components/password-input/password-input.js +12 -9
- package/esm/components/popover/popover.js +22 -21
- package/esm/components/popover/use-page-click.js +5 -2
- package/esm/components/portal/portal-context.js +5 -6
- package/esm/components/portal/portal.js +5 -2
- package/esm/components/positioner/calc-position.js +4 -2
- package/esm/components/positioner/positioner.js +9 -6
- package/esm/components/radio/radio.js +12 -9
- package/esm/components/segmented-control/segmented-control-button.js +7 -4
- package/esm/components/segmented-control/segmented-control.js +12 -9
- package/esm/components/select/select.js +12 -9
- package/esm/components/selection-control/selection-control.js +10 -7
- package/esm/components/slider/slider-tick-marks.js +8 -5
- package/esm/components/slider/slider.js +13 -10
- package/esm/components/spinner/spinner.js +7 -4
- package/esm/components/switch/switch.js +11 -8
- package/esm/components/table/icons.js +10 -7
- package/esm/components/table/table-body.js +7 -4
- package/esm/components/table/table-cell.js +7 -4
- package/esm/components/table/table-container.js +7 -4
- package/esm/components/table/table-head-cell.js +18 -15
- package/esm/components/table/table-head.js +7 -4
- package/esm/components/table/table-row.js +7 -4
- package/esm/components/table/table.js +7 -4
- package/esm/components/tabs/tab-list.js +14 -11
- package/esm/components/tabs/tab-panel.js +8 -5
- package/esm/components/tabs/tab.js +10 -7
- package/esm/components/tabs/tabs-context.js +8 -5
- package/esm/components/tabs/tabs.js +8 -5
- package/esm/components/tag/tag.js +7 -4
- package/esm/components/text-input/text-input.js +11 -8
- package/esm/components/textarea/textarea.js +20 -17
- package/esm/components/toast/toast-button.js +7 -4
- package/esm/components/toast/toast.js +8 -5
- package/esm/components/toast/x-mark-icon.js +6 -3
- package/esm/components/toaster/toaster.js +29 -46
- package/esm/components/tooltip/tooltip.js +22 -24
- package/esm/hooks/index.js +4 -4
- package/esm/hooks/use-disable-body-scroll.js +5 -2
- package/esm/hooks/use-esc-key-down.js +6 -3
- package/esm/hooks/use-focus-trap.js +6 -3
- package/esm/hooks/use-mount-transition.js +6 -3
- package/esm/index.js +66 -3
- package/esm/lib/helpers.js +4 -2
- package/esm/lib/index.js +3 -3
- package/esm/lib/keyboard-keys.js +3 -1
- package/esm/lib/react-helpers.js +8 -5
- package/package.json +21 -20
- package/{cjs → types}/components/alert/alert.d.ts +0 -0
- package/{cjs → types}/components/alert/index.d.ts +0 -0
- package/{cjs → types}/components/avatar/avatar.d.ts +0 -0
- package/{cjs → types}/components/avatar/index.d.ts +0 -0
- package/{cjs → types}/components/avatar-group/avatar-group.d.ts +0 -0
- package/{cjs → types}/components/avatar-group/index.d.ts +0 -0
- package/{cjs → types}/components/badge/badge.d.ts +0 -0
- package/{cjs → types}/components/badge/index.d.ts +0 -0
- package/{cjs → types}/components/breadcrumbs/breadcrumbs-context.d.ts +0 -0
- package/{cjs → types}/components/breadcrumbs/breadcrumbs-item.d.ts +0 -0
- package/{cjs → types}/components/breadcrumbs/breadcrumbs.d.ts +0 -0
- package/{cjs → types}/components/breadcrumbs/index.d.ts +0 -0
- package/{cjs → types}/components/button/button.d.ts +0 -0
- package/{cjs → types}/components/button/icon-button.d.ts +0 -0
- package/{cjs → types}/components/button/index.d.ts +0 -0
- package/{cjs → types}/components/button-group/button-group.d.ts +0 -0
- package/{cjs → types}/components/button-group/index.d.ts +0 -0
- package/{cjs → types}/components/caption/caption.d.ts +0 -0
- package/{cjs → types}/components/caption/icons.d.ts +0 -0
- package/{cjs → types}/components/caption/index.d.ts +0 -0
- package/{cjs → types}/components/checkbox/checkbox.d.ts +0 -0
- package/{cjs → types}/components/checkbox/index.d.ts +0 -0
- package/{cjs → types}/components/color-picker/color-picker-button.d.ts +0 -0
- package/{cjs → types}/components/color-picker/color-picker.d.ts +0 -0
- package/{cjs → types}/components/color-picker/index.d.ts +0 -0
- package/{cjs → types}/components/date-picker/calendar-day.d.ts +0 -0
- package/{cjs → types}/components/date-picker/calendar-grid-head.d.ts +0 -0
- package/{cjs → types}/components/date-picker/calendar-grid.d.ts +0 -0
- package/{cjs → types}/components/date-picker/calendar-header.d.ts +0 -0
- package/{cjs → types}/components/date-picker/calendar.d.ts +0 -0
- package/{cjs → types}/components/date-picker/date-helpers.d.ts +0 -0
- package/{cjs → types}/components/date-picker/date-picker.d.ts +0 -0
- package/{cjs → types}/components/date-picker/date-range-picker.d.ts +0 -0
- package/{cjs → types}/components/date-picker/date-range.d.ts +0 -0
- package/{cjs → types}/components/date-picker/icons.d.ts +0 -0
- package/{cjs → types}/components/date-picker/index.d.ts +0 -0
- package/{cjs → types}/components/date-picker/parse-min-max-props.d.ts +0 -0
- package/{cjs → types}/components/date-picker-popover/date-picker-popover.d.ts +0 -0
- package/{cjs → types}/components/date-picker-popover/index.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/helpers.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/index.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/types.d.ts +0 -0
- package/{cjs → types}/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -0
- package/{cjs → types}/components/dialog/dialog-body.d.ts +0 -0
- package/{cjs → types}/components/dialog/dialog-context.d.ts +0 -0
- package/{cjs → types}/components/dialog/dialog-footer.d.ts +0 -0
- package/{cjs → types}/components/dialog/dialog-header.d.ts +0 -0
- package/{cjs → types}/components/dialog/dialog.d.ts +0 -0
- package/{cjs → types}/components/dialog/index.d.ts +0 -0
- package/{cjs → types}/components/dialog/x-mark-icon.d.ts +0 -0
- package/{cjs → types}/components/empty-state/empty-state.d.ts +0 -0
- package/{cjs → types}/components/empty-state/index.d.ts +0 -0
- package/{cjs → types}/components/file-picker/file-picker.d.ts +0 -0
- package/{cjs → types}/components/file-picker/index.d.ts +0 -0
- package/{cjs → types}/components/filter-buttons/filter-button.d.ts +0 -0
- package/{cjs → types}/components/filter-buttons/filter-buttons.d.ts +0 -0
- package/{cjs → types}/components/filter-buttons/index.d.ts +0 -0
- package/{cjs → types}/components/form-field/form-field.d.ts +0 -0
- package/{cjs → types}/components/form-field/index.d.ts +0 -0
- package/{cjs → types}/components/index.d.ts +0 -0
- package/{cjs → types}/components/label/index.d.ts +0 -0
- package/{cjs → types}/components/label/label.d.ts +0 -0
- package/{cjs → types}/components/menu/index.d.ts +0 -0
- package/{cjs → types}/components/menu/menu-item.d.ts +0 -0
- package/{cjs → types}/components/menu/menu-separator.d.ts +0 -0
- package/{cjs → types}/components/menu/menu.d.ts +0 -0
- package/{cjs → types}/components/nav-list/index.d.ts +0 -0
- package/{cjs → types}/components/nav-list/nav-list-item.d.ts +0 -0
- package/{cjs → types}/components/nav-list/nav-list-title.d.ts +0 -0
- package/{cjs → types}/components/nav-list/nav-list.d.ts +0 -0
- package/{cjs → types}/components/password-input/icons.d.ts +0 -0
- package/{cjs → types}/components/password-input/index.d.ts +0 -0
- package/{cjs → types}/components/password-input/password-input.d.ts +0 -0
- package/{cjs → types}/components/popover/index.d.ts +0 -0
- package/{cjs → types}/components/popover/popover.d.ts +0 -0
- package/{cjs → types}/components/popover/use-page-click.d.ts +0 -0
- package/{cjs → types}/components/portal/index.d.ts +0 -0
- package/{cjs → types}/components/portal/portal-context.d.ts +0 -0
- package/{cjs → types}/components/portal/portal.d.ts +0 -0
- package/{cjs → types}/components/positioner/calc-position.d.ts +0 -0
- package/{cjs → types}/components/positioner/index.d.ts +0 -0
- package/{cjs → types}/components/positioner/positioner.d.ts +0 -0
- package/{cjs → types}/components/positioner/types.d.ts +0 -0
- package/{cjs → types}/components/radio/index.d.ts +0 -0
- package/{cjs → types}/components/radio/radio.d.ts +0 -0
- package/{cjs → types}/components/segmented-control/index.d.ts +0 -0
- package/{cjs → types}/components/segmented-control/segmented-control-button.d.ts +0 -0
- package/{cjs → types}/components/segmented-control/segmented-control.d.ts +0 -0
- package/{cjs → types}/components/select/index.d.ts +0 -0
- package/{cjs → types}/components/select/select.d.ts +1 -1
- package/{cjs → types}/components/selection-control/index.d.ts +0 -0
- package/{cjs → types}/components/selection-control/selection-control.d.ts +0 -0
- package/{cjs → types}/components/slider/index.d.ts +0 -0
- package/{cjs → types}/components/slider/slider-tick-marks.d.ts +0 -0
- package/{cjs → types}/components/slider/slider.d.ts +0 -0
- package/{cjs → types}/components/spinner/index.d.ts +0 -0
- package/{cjs → types}/components/spinner/spinner.d.ts +0 -0
- package/{cjs → types}/components/switch/index.d.ts +0 -0
- package/{cjs → types}/components/switch/switch.d.ts +0 -0
- package/{cjs → types}/components/table/icons.d.ts +0 -0
- package/{cjs → types}/components/table/index.d.ts +0 -0
- package/{cjs → types}/components/table/table-body.d.ts +0 -0
- package/{cjs → types}/components/table/table-cell.d.ts +0 -0
- package/{cjs → types}/components/table/table-container.d.ts +0 -0
- package/{cjs → types}/components/table/table-head-cell.d.ts +0 -0
- package/{cjs → types}/components/table/table-head.d.ts +0 -0
- package/{cjs → types}/components/table/table-row.d.ts +0 -0
- package/{cjs → types}/components/table/table.d.ts +0 -0
- package/{cjs → types}/components/tabs/index.d.ts +0 -0
- package/{cjs → types}/components/tabs/tab-list.d.ts +0 -0
- package/{cjs → types}/components/tabs/tab-panel.d.ts +0 -0
- package/{cjs → types}/components/tabs/tab.d.ts +0 -0
- package/{cjs → types}/components/tabs/tabs-context.d.ts +0 -0
- package/{cjs → types}/components/tabs/tabs.d.ts +0 -0
- package/{cjs → types}/components/tabs/types.d.ts +0 -0
- package/{cjs → types}/components/tag/index.d.ts +0 -0
- package/{cjs → types}/components/tag/tag.d.ts +0 -0
- package/{cjs → types}/components/text-input/index.d.ts +0 -0
- package/{cjs → types}/components/text-input/text-input.d.ts +0 -0
- package/{cjs → types}/components/textarea/index.d.ts +0 -0
- package/{cjs → types}/components/textarea/textarea.d.ts +0 -0
- package/{cjs → types}/components/toast/index.d.ts +0 -0
- package/{cjs → types}/components/toast/toast-button.d.ts +0 -0
- package/{cjs → types}/components/toast/toast.d.ts +0 -0
- package/{cjs → types}/components/toast/x-mark-icon.d.ts +0 -0
- package/{cjs → types}/components/toaster/index.d.ts +0 -0
- package/{esm → types}/components/toaster/toaster.d.ts +5 -1
- package/{cjs → types}/components/tooltip/index.d.ts +0 -0
- package/{cjs → types}/components/tooltip/tooltip.d.ts +0 -0
- package/{cjs → types}/hooks/index.d.ts +0 -0
- package/{cjs → types}/hooks/use-disable-body-scroll.d.ts +0 -0
- package/{cjs → types}/hooks/use-esc-key-down.d.ts +0 -0
- package/{cjs → types}/hooks/use-focus-trap.d.ts +0 -0
- package/{cjs → types}/hooks/use-mount-transition.d.ts +0 -0
- package/{cjs → types}/index.d.ts +0 -0
- package/types/lib/helpers.d.ts +4 -0
- package/{cjs → types}/lib/index.d.ts +0 -0
- package/{cjs → types}/lib/keyboard-keys.d.ts +0 -0
- package/{cjs → types}/lib/react-helpers.d.ts +0 -0
- package/cjs/components/alert/alert.js +0 -16
- package/cjs/components/alert/index.js +0 -17
- package/cjs/components/avatar/avatar.js +0 -29
- package/cjs/components/avatar/index.js +0 -17
- package/cjs/components/avatar-group/avatar-group.js +0 -9
- package/cjs/components/avatar-group/index.js +0 -17
- package/cjs/components/badge/index.js +0 -17
- package/cjs/components/breadcrumbs/breadcrumbs-context.js +0 -18
- package/cjs/components/breadcrumbs/breadcrumbs-item.js +0 -20
- package/cjs/components/breadcrumbs/breadcrumbs.js +0 -11
- package/cjs/components/breadcrumbs/index.js +0 -18
- package/cjs/components/button/button.js +0 -37
- package/cjs/components/button/icon-button.js +0 -10
- package/cjs/components/button/index.js +0 -18
- package/cjs/components/button-group/button-group.js +0 -9
- package/cjs/components/button-group/index.js +0 -17
- package/cjs/components/caption/caption.js +0 -25
- package/cjs/components/caption/icons.js +0 -20
- package/cjs/components/caption/index.js +0 -17
- package/cjs/components/checkbox/checkbox.js +0 -14
- package/cjs/components/checkbox/index.js +0 -17
- package/cjs/components/color-picker/color-picker-button.js +0 -15
- package/cjs/components/color-picker/color-picker.js +0 -13
- package/cjs/components/color-picker/index.js +0 -17
- package/cjs/components/date-picker/calendar-grid-head.js +0 -15
- package/cjs/components/date-picker/calendar-grid.js +0 -105
- package/cjs/components/date-picker/calendar-header.js +0 -46
- package/cjs/components/date-picker/calendar.js +0 -23
- package/cjs/components/date-picker/date-picker.js +0 -19
- package/cjs/components/date-picker/date-range-picker.js +0 -60
- package/cjs/components/date-picker/date-range.js +0 -27
- package/cjs/components/date-picker/icons.js +0 -12
- package/cjs/components/date-picker/index.js +0 -18
- package/cjs/components/date-picker-popover/date-picker-popover.js +0 -20
- package/cjs/components/date-picker-popover/index.js +0 -17
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.js +0 -9
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.js +0 -34
- package/cjs/components/date-range-picker-popover/date-range-picker-popover.js +0 -54
- package/cjs/components/date-range-picker-popover/index.js +0 -18
- package/cjs/components/date-range-picker-popover/types.js +0 -2
- package/cjs/components/dialog/dialog-footer.js +0 -9
- package/cjs/components/dialog/dialog-header.js +0 -16
- package/cjs/components/dialog/dialog.js +0 -46
- package/cjs/components/dialog/index.js +0 -20
- package/cjs/components/dialog/x-mark-icon.js +0 -8
- package/cjs/components/empty-state/empty-state.js +0 -9
- package/cjs/components/empty-state/index.js +0 -17
- package/cjs/components/file-picker/file-picker.js +0 -44
- package/cjs/components/file-picker/index.js +0 -17
- package/cjs/components/filter-buttons/filter-button.js +0 -9
- package/cjs/components/filter-buttons/filter-buttons.js +0 -26
- package/cjs/components/filter-buttons/index.js +0 -18
- package/cjs/components/form-field/form-field.js +0 -25
- package/cjs/components/form-field/index.js +0 -17
- package/cjs/components/index.js +0 -53
- package/cjs/components/label/index.js +0 -17
- package/cjs/components/label/label.js +0 -11
- package/cjs/components/menu/index.js +0 -19
- package/cjs/components/menu/menu-item.js +0 -12
- package/cjs/components/menu/menu-separator.js +0 -9
- package/cjs/components/nav-list/index.js +0 -19
- package/cjs/components/nav-list/nav-list-item.js +0 -19
- package/cjs/components/nav-list/nav-list-title.js +0 -9
- package/cjs/components/nav-list/nav-list.js +0 -9
- package/cjs/components/password-input/icons.js +0 -12
- package/cjs/components/password-input/index.js +0 -17
- package/cjs/components/password-input/password-input.js +0 -28
- package/cjs/components/popover/index.js +0 -17
- package/cjs/components/popover/popover.js +0 -97
- package/cjs/components/portal/index.js +0 -17
- package/cjs/components/portal/portal-context.js +0 -26
- package/cjs/components/portal/portal.js +0 -10
- package/cjs/components/positioner/index.js +0 -17
- package/cjs/components/positioner/types.js +0 -2
- package/cjs/components/radio/index.js +0 -17
- package/cjs/components/radio/radio.js +0 -22
- package/cjs/components/segmented-control/index.js +0 -17
- package/cjs/components/segmented-control/segmented-control-button.js +0 -14
- package/cjs/components/segmented-control/segmented-control.js +0 -47
- package/cjs/components/select/index.js +0 -17
- package/cjs/components/select/select.js +0 -25
- package/cjs/components/selection-control/index.js +0 -17
- package/cjs/components/selection-control/selection-control.js +0 -17
- package/cjs/components/slider/index.js +0 -20
- package/cjs/components/slider/slider-tick-marks.js +0 -16
- package/cjs/components/spinner/index.js +0 -17
- package/cjs/components/spinner/spinner.js +0 -9
- package/cjs/components/switch/index.js +0 -17
- package/cjs/components/switch/switch.js +0 -13
- package/cjs/components/table/icons.js +0 -16
- package/cjs/components/table/index.js +0 -23
- package/cjs/components/table/table-body.js +0 -9
- package/cjs/components/table/table-cell.js +0 -9
- package/cjs/components/table/table-container.js +0 -21
- package/cjs/components/table/table-head-cell.js +0 -28
- package/cjs/components/table/table-head.js +0 -12
- package/cjs/components/table/table-row.js +0 -12
- package/cjs/components/table/table.js +0 -14
- package/cjs/components/tabs/index.js +0 -20
- package/cjs/components/tabs/tab-list.js +0 -66
- package/cjs/components/tabs/tab-panel.js +0 -15
- package/cjs/components/tabs/tab.js +0 -18
- package/cjs/components/tabs/tabs.js +0 -10
- package/cjs/components/tabs/types.js +0 -2
- package/cjs/components/tag/index.js +0 -17
- package/cjs/components/text-input/index.js +0 -17
- package/cjs/components/text-input/text-input.js +0 -24
- package/cjs/components/textarea/index.js +0 -17
- package/cjs/components/textarea/textarea.js +0 -38
- package/cjs/components/toast/index.js +0 -18
- package/cjs/components/toast/toast-button.js +0 -9
- package/cjs/components/toast/toast.js +0 -10
- package/cjs/components/toast/x-mark-icon.js +0 -8
- package/cjs/components/toaster/index.js +0 -17
- package/cjs/components/toaster/toaster.d.ts +0 -40
- package/cjs/components/toaster/toaster.js +0 -134
- package/cjs/components/tooltip/index.js +0 -17
- package/cjs/components/tooltip/tooltip.js +0 -79
- package/cjs/hooks/index.js +0 -20
- package/cjs/index.js +0 -19
- package/cjs/lib/helpers.d.ts +0 -2
- package/cjs/lib/index.js +0 -19
- package/css/draft-components-utilities.min.css +0 -1
- package/css/draft-components.dark.min.css +0 -1
- package/css/draft-components.min.css +0 -1
- package/esm/components/alert/alert.d.ts +0 -10
- package/esm/components/alert/index.d.ts +0 -1
- package/esm/components/alert/index.js +0 -1
- package/esm/components/avatar/avatar.d.ts +0 -13
- package/esm/components/avatar/index.d.ts +0 -1
- package/esm/components/avatar/index.js +0 -1
- package/esm/components/avatar-group/avatar-group.d.ts +0 -7
- package/esm/components/avatar-group/index.d.ts +0 -1
- package/esm/components/avatar-group/index.js +0 -1
- package/esm/components/badge/badge.d.ts +0 -8
- package/esm/components/badge/index.d.ts +0 -1
- package/esm/components/badge/index.js +0 -1
- package/esm/components/breadcrumbs/breadcrumbs-context.d.ts +0 -9
- package/esm/components/breadcrumbs/breadcrumbs-item.d.ts +0 -12
- package/esm/components/breadcrumbs/breadcrumbs.d.ts +0 -7
- package/esm/components/breadcrumbs/index.d.ts +0 -2
- package/esm/components/breadcrumbs/index.js +0 -2
- package/esm/components/button/button.d.ts +0 -19
- package/esm/components/button/icon-button.d.ts +0 -6
- package/esm/components/button/index.d.ts +0 -2
- package/esm/components/button/index.js +0 -2
- package/esm/components/button-group/button-group.d.ts +0 -7
- package/esm/components/button-group/index.d.ts +0 -1
- package/esm/components/button-group/index.js +0 -1
- package/esm/components/caption/caption.d.ts +0 -7
- package/esm/components/caption/icons.d.ts +0 -5
- package/esm/components/caption/index.d.ts +0 -1
- package/esm/components/caption/index.js +0 -1
- package/esm/components/checkbox/checkbox.d.ts +0 -10
- package/esm/components/checkbox/index.d.ts +0 -1
- package/esm/components/checkbox/index.js +0 -1
- package/esm/components/color-picker/color-picker-button.d.ts +0 -12
- package/esm/components/color-picker/color-picker-button.js +0 -11
- package/esm/components/color-picker/color-picker.d.ts +0 -13
- package/esm/components/color-picker/color-picker.js +0 -9
- package/esm/components/color-picker/index.d.ts +0 -1
- package/esm/components/color-picker/index.js +0 -1
- package/esm/components/date-picker/calendar-day.d.ts +0 -17
- package/esm/components/date-picker/calendar-grid-head.d.ts +0 -7
- package/esm/components/date-picker/calendar-grid.d.ts +0 -17
- package/esm/components/date-picker/calendar-header.d.ts +0 -12
- package/esm/components/date-picker/calendar.d.ts +0 -11
- package/esm/components/date-picker/date-helpers.d.ts +0 -22
- package/esm/components/date-picker/date-picker.d.ts +0 -13
- package/esm/components/date-picker/date-range-picker.d.ts +0 -14
- package/esm/components/date-picker/date-range.d.ts +0 -13
- package/esm/components/date-picker/icons.d.ts +0 -3
- package/esm/components/date-picker/index.d.ts +0 -2
- package/esm/components/date-picker/index.js +0 -2
- package/esm/components/date-picker/parse-min-max-props.d.ts +0 -8
- package/esm/components/date-picker-popover/date-picker-popover.d.ts +0 -13
- package/esm/components/date-picker-popover/index.d.ts +0 -1
- package/esm/components/date-picker-popover/index.js +0 -1
- package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -9
- package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +0 -10
- package/esm/components/date-range-picker-popover/date-range-picker-popover.d.ts +0 -26
- package/esm/components/date-range-picker-popover/helpers.d.ts +0 -2
- package/esm/components/date-range-picker-popover/index.d.ts +0 -2
- package/esm/components/date-range-picker-popover/index.js +0 -2
- package/esm/components/date-range-picker-popover/types.d.ts +0 -10
- package/esm/components/date-range-picker-popover/types.js +0 -1
- package/esm/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -1
- package/esm/components/dialog/dialog-body.d.ts +0 -8
- package/esm/components/dialog/dialog-context.d.ts +0 -15
- package/esm/components/dialog/dialog-footer.d.ts +0 -5
- package/esm/components/dialog/dialog-header.d.ts +0 -8
- package/esm/components/dialog/dialog.d.ts +0 -12
- package/esm/components/dialog/index.d.ts +0 -4
- package/esm/components/dialog/index.js +0 -4
- package/esm/components/dialog/x-mark-icon.d.ts +0 -2
- package/esm/components/empty-state/empty-state.d.ts +0 -11
- package/esm/components/empty-state/index.d.ts +0 -1
- package/esm/components/empty-state/index.js +0 -1
- package/esm/components/file-picker/file-picker.d.ts +0 -13
- package/esm/components/file-picker/index.d.ts +0 -1
- package/esm/components/file-picker/index.js +0 -1
- package/esm/components/filter-buttons/filter-button.d.ts +0 -7
- package/esm/components/filter-buttons/filter-buttons.d.ts +0 -5
- package/esm/components/filter-buttons/index.d.ts +0 -2
- package/esm/components/filter-buttons/index.js +0 -2
- package/esm/components/form-field/form-field.d.ts +0 -15
- package/esm/components/form-field/index.d.ts +0 -1
- package/esm/components/form-field/index.js +0 -1
- package/esm/components/index.d.ts +0 -37
- package/esm/components/label/index.d.ts +0 -1
- package/esm/components/label/index.js +0 -1
- package/esm/components/label/label.d.ts +0 -5
- package/esm/components/menu/index.d.ts +0 -3
- package/esm/components/menu/index.js +0 -3
- package/esm/components/menu/menu-item.d.ts +0 -11
- package/esm/components/menu/menu-separator.d.ts +0 -6
- package/esm/components/menu/menu.d.ts +0 -31
- package/esm/components/nav-list/index.d.ts +0 -3
- package/esm/components/nav-list/index.js +0 -3
- package/esm/components/nav-list/nav-list-item.d.ts +0 -13
- package/esm/components/nav-list/nav-list-title.d.ts +0 -8
- package/esm/components/nav-list/nav-list.d.ts +0 -5
- package/esm/components/password-input/icons.d.ts +0 -3
- package/esm/components/password-input/index.d.ts +0 -1
- package/esm/components/password-input/index.js +0 -1
- package/esm/components/password-input/password-input.d.ts +0 -10
- package/esm/components/popover/index.d.ts +0 -1
- package/esm/components/popover/index.js +0 -1
- package/esm/components/popover/popover.d.ts +0 -49
- package/esm/components/popover/use-page-click.d.ts +0 -16
- package/esm/components/portal/index.d.ts +0 -1
- package/esm/components/portal/index.js +0 -1
- package/esm/components/portal/portal-context.d.ts +0 -6
- package/esm/components/portal/portal.d.ts +0 -5
- package/esm/components/positioner/calc-position.d.ts +0 -32
- package/esm/components/positioner/index.d.ts +0 -1
- package/esm/components/positioner/index.js +0 -1
- package/esm/components/positioner/positioner.d.ts +0 -20
- package/esm/components/positioner/types.d.ts +0 -14
- package/esm/components/positioner/types.js +0 -1
- package/esm/components/radio/index.d.ts +0 -1
- package/esm/components/radio/index.js +0 -1
- package/esm/components/radio/radio.d.ts +0 -11
- package/esm/components/segmented-control/index.d.ts +0 -1
- package/esm/components/segmented-control/index.js +0 -1
- package/esm/components/segmented-control/segmented-control-button.d.ts +0 -10
- package/esm/components/segmented-control/segmented-control.d.ts +0 -15
- package/esm/components/select/index.d.ts +0 -1
- package/esm/components/select/index.js +0 -1
- package/esm/components/select/select.d.ts +0 -46
- package/esm/components/selection-control/index.d.ts +0 -1
- package/esm/components/selection-control/index.js +0 -1
- package/esm/components/selection-control/selection-control.d.ts +0 -14
- package/esm/components/slider/index.d.ts +0 -2
- package/esm/components/slider/index.js +0 -2
- package/esm/components/slider/slider-tick-marks.d.ts +0 -7
- package/esm/components/slider/slider.d.ts +0 -17
- package/esm/components/spinner/index.d.ts +0 -1
- package/esm/components/spinner/index.js +0 -1
- package/esm/components/spinner/spinner.d.ts +0 -7
- package/esm/components/switch/index.d.ts +0 -1
- package/esm/components/switch/index.js +0 -1
- package/esm/components/switch/switch.d.ts +0 -10
- package/esm/components/table/icons.d.ts +0 -4
- package/esm/components/table/index.d.ts +0 -7
- package/esm/components/table/index.js +0 -7
- package/esm/components/table/table-body.d.ts +0 -5
- package/esm/components/table/table-cell.d.ts +0 -5
- package/esm/components/table/table-container.d.ts +0 -13
- package/esm/components/table/table-head-cell.d.ts +0 -10
- package/esm/components/table/table-head.d.ts +0 -7
- package/esm/components/table/table-row.d.ts +0 -7
- package/esm/components/table/table.d.ts +0 -11
- package/esm/components/tabs/index.d.ts +0 -4
- package/esm/components/tabs/index.js +0 -4
- package/esm/components/tabs/tab-list.d.ts +0 -3
- package/esm/components/tabs/tab-panel.d.ts +0 -6
- package/esm/components/tabs/tab.d.ts +0 -7
- package/esm/components/tabs/tabs-context.d.ts +0 -20
- package/esm/components/tabs/tabs.d.ts +0 -7
- package/esm/components/tabs/types.d.ts +0 -2
- package/esm/components/tabs/types.js +0 -1
- package/esm/components/tag/index.d.ts +0 -1
- package/esm/components/tag/index.js +0 -1
- package/esm/components/tag/tag.d.ts +0 -13
- package/esm/components/text-input/index.d.ts +0 -1
- package/esm/components/text-input/index.js +0 -1
- package/esm/components/text-input/text-input.d.ts +0 -21
- package/esm/components/textarea/index.d.ts +0 -1
- package/esm/components/textarea/index.js +0 -1
- package/esm/components/textarea/textarea.d.ts +0 -20
- package/esm/components/toast/index.d.ts +0 -2
- package/esm/components/toast/index.js +0 -2
- package/esm/components/toast/toast-button.d.ts +0 -5
- package/esm/components/toast/toast.d.ts +0 -11
- package/esm/components/toast/x-mark-icon.d.ts +0 -2
- package/esm/components/toaster/index.d.ts +0 -1
- package/esm/components/toaster/index.js +0 -1
- package/esm/components/tooltip/index.d.ts +0 -1
- package/esm/components/tooltip/index.js +0 -1
- package/esm/components/tooltip/tooltip.d.ts +0 -25
- package/esm/hooks/index.d.ts +0 -4
- package/esm/hooks/use-disable-body-scroll.d.ts +0 -5
- package/esm/hooks/use-esc-key-down.d.ts +0 -17
- package/esm/hooks/use-focus-trap.d.ts +0 -15
- package/esm/hooks/use-mount-transition.d.ts +0 -32
- package/esm/index.d.ts +0 -3
- package/esm/lib/helpers.d.ts +0 -2
- package/esm/lib/index.d.ts +0 -3
- package/esm/lib/keyboard-keys.d.ts +0 -14
- 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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
const TabsContext =
|
|
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] =
|
|
9
|
-
const id =
|
|
10
|
-
const getTabProps =
|
|
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 (
|
|
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 =
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
|
|
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 (
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const react = require('react');
|
|
4
|
+
const helpers = require('../lib/helpers.cjs');
|
|
5
|
+
|
|
6
6
|
function useDisableBodyScroll(options) {
|
|
7
|
-
|
|
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
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
|
|
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 =
|
|
19
|
+
const handlerRef = react.useRef(handler);
|
|
20
20
|
const isEnabled = options.isEnabled;
|
|
21
|
-
|
|
21
|
+
react.useEffect(() => {
|
|
22
22
|
handlerRef.current = handler;
|
|
23
23
|
}, [handler]);
|
|
24
|
-
|
|
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 ===
|
|
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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
|
|
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
|
-
|
|
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 !==
|
|
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
|
-
|
|
56
|
+
reactHelpers.focusElement(firstFocusableEl);
|
|
57
57
|
}
|
|
58
58
|
else if (event.shiftKey) {
|
|
59
59
|
if (document.activeElement === firstFocusableEl) {
|
|
60
60
|
event.preventDefault();
|
|
61
|
-
|
|
61
|
+
reactHelpers.focusElement(lastFocusableEl);
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
else if (document.activeElement === lastFocusableEl) {
|
|
65
65
|
event.preventDefault();
|
|
66
|
-
|
|
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;
|