draft-components 1.12.0 → 2.0.0
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/{css → dist/css}/draft-components.css +553 -558
- package/{css → dist/css}/draft-components.dark.css +185 -113
- package/dist/esm/components/alert/alert.d.ts +15 -0
- package/dist/esm/components/alert/alert.js +12 -0
- package/dist/esm/components/alert/index.d.ts +1 -0
- package/dist/esm/components/alert/index.js +1 -0
- package/{types → dist/esm}/components/avatar/avatar.d.ts +8 -7
- package/dist/esm/components/avatar/avatar.js +41 -0
- package/dist/esm/components/avatar/index.d.ts +1 -0
- package/dist/esm/components/avatar/index.js +1 -0
- package/dist/esm/components/avatar-group/avatar-group.js +5 -0
- package/dist/esm/components/avatar-group/index.d.ts +1 -0
- package/dist/esm/components/avatar-group/index.js +1 -0
- package/{esm → dist/esm}/components/badge/badge.js +3 -6
- package/dist/esm/components/badge/index.d.ts +1 -0
- package/dist/esm/components/badge/index.js +1 -0
- package/dist/esm/components/breadcrumbs/breadcrumbs-context.js +13 -0
- package/dist/esm/components/breadcrumbs/breadcrumbs-item.js +16 -0
- package/dist/esm/components/breadcrumbs/breadcrumbs.js +7 -0
- package/dist/esm/components/breadcrumbs/index.d.ts +2 -0
- package/dist/esm/components/breadcrumbs/index.js +2 -0
- package/{types → dist/esm}/components/button/button.d.ts +12 -10
- package/dist/esm/components/button/button.js +22 -0
- package/dist/esm/components/button/icon-button.d.ts +4 -0
- package/dist/esm/components/button/icon-button.js +7 -0
- package/dist/esm/components/button/index.d.ts +2 -0
- package/dist/esm/components/button/index.js +2 -0
- package/dist/esm/components/button-group/button-group.js +5 -0
- package/dist/esm/components/button-group/index.d.ts +1 -0
- package/dist/esm/components/button-group/index.js +1 -0
- package/dist/esm/components/caption/caption.d.ts +10 -0
- package/dist/esm/components/caption/caption.js +10 -0
- package/dist/esm/components/caption/index.d.ts +1 -0
- package/dist/esm/components/caption/index.js +1 -0
- package/dist/esm/components/checkbox/checkbox.js +15 -0
- package/dist/esm/components/checkbox/index.d.ts +1 -0
- package/dist/esm/components/checkbox/index.js +1 -0
- package/dist/esm/components/color-picker/color-picker-button.js +11 -0
- package/{esm → dist/esm}/components/color-picker/color-picker.js +4 -7
- package/dist/esm/components/color-picker/index.d.ts +1 -0
- package/dist/esm/components/color-picker/index.js +1 -0
- package/{esm → dist/esm}/components/date-picker/calendar-day.js +4 -7
- package/{types → dist/esm}/components/date-picker/calendar-grid-head.d.ts +1 -1
- package/dist/esm/components/date-picker/calendar-grid-head.js +11 -0
- package/{types → dist/esm}/components/date-picker/calendar-grid.d.ts +2 -2
- package/{esm → dist/esm}/components/date-picker/calendar-grid.js +7 -10
- package/dist/esm/components/date-picker/calendar-header.js +43 -0
- package/{types → dist/esm}/components/date-picker/calendar.d.ts +3 -3
- package/dist/esm/components/date-picker/calendar.js +19 -0
- package/{esm → dist/esm}/components/date-picker/date-helpers.js +20 -22
- package/{types → dist/esm}/components/date-picker/date-picker.d.ts +2 -2
- package/dist/esm/components/date-picker/date-picker.js +15 -0
- package/{types → dist/esm}/components/date-picker/date-range-picker.d.ts +3 -3
- package/{esm → dist/esm}/components/date-picker/date-range-picker.js +4 -7
- package/{types → dist/esm}/components/date-picker/date-range.d.ts +1 -1
- package/{esm → dist/esm}/components/date-picker/date-range.js +1 -4
- package/dist/esm/components/date-picker/index.d.ts +2 -0
- package/dist/esm/components/date-picker/index.js +2 -0
- package/{types → dist/esm}/components/date-picker/parse-min-max-props.d.ts +1 -1
- package/{esm → dist/esm}/components/date-picker/parse-min-max-props.js +1 -4
- package/{types → dist/esm}/components/date-picker-popover/date-picker-popover.d.ts +2 -2
- package/dist/esm/components/date-picker-popover/date-picker-popover.js +15 -0
- package/dist/esm/components/date-picker-popover/index.d.ts +1 -0
- package/dist/esm/components/date-picker-popover/index.js +1 -0
- package/dist/esm/components/date-range-picker-popover/date-range-picker-popover-footer.js +5 -0
- package/{types → dist/esm}/components/date-range-picker-popover/date-range-picker-popover-presets.d.ts +1 -1
- package/dist/esm/components/date-range-picker-popover/date-range-picker-popover-presets.js +30 -0
- package/{types → dist/esm}/components/date-range-picker-popover/date-range-picker-popover.d.ts +3 -3
- package/{esm → dist/esm}/components/date-range-picker-popover/date-range-picker-popover.js +7 -14
- package/{types → dist/esm}/components/date-range-picker-popover/helpers.d.ts +1 -1
- package/{esm → dist/esm}/components/date-range-picker-popover/helpers.js +1 -3
- package/dist/esm/components/date-range-picker-popover/index.d.ts +2 -0
- package/dist/esm/components/date-range-picker-popover/index.js +2 -0
- package/{types → dist/esm}/components/date-range-picker-popover/types.d.ts +1 -1
- package/dist/esm/components/date-range-picker-popover/types.js +1 -0
- package/{esm → dist/esm}/components/date-range-picker-popover/use-is-compact-view.js +2 -5
- package/dist/esm/components/dialog/dialog-body.js +7 -0
- package/{esm → dist/esm}/components/dialog/dialog-context.js +4 -7
- package/dist/esm/components/dialog/dialog-footer.js +8 -0
- package/dist/esm/components/dialog/dialog-header.js +15 -0
- package/{esm → dist/esm}/components/dialog/dialog.js +9 -15
- package/dist/esm/components/dialog/index.d.ts +4 -0
- package/dist/esm/components/dialog/index.js +4 -0
- package/dist/esm/components/empty-state/empty-state.d.ts +12 -0
- package/dist/esm/components/empty-state/empty-state.js +17 -0
- package/dist/esm/components/empty-state/index.d.ts +1 -0
- package/dist/esm/components/empty-state/index.js +1 -0
- package/{esm → dist/esm}/components/file-picker/file-picker.js +6 -10
- package/dist/esm/components/file-picker/index.d.ts +1 -0
- package/dist/esm/components/file-picker/index.js +1 -0
- package/dist/esm/components/filter-buttons/filter-button.js +6 -0
- package/{esm → dist/esm}/components/filter-buttons/filter-buttons.js +4 -7
- package/dist/esm/components/filter-buttons/index.d.ts +2 -0
- package/dist/esm/components/filter-buttons/index.js +2 -0
- package/{types → dist/esm}/components/filtered-search/filter-item.d.ts +1 -1
- package/dist/esm/components/filtered-search/filter-item.js +17 -0
- package/dist/esm/components/filtered-search/filter-operator-select.js +12 -0
- package/dist/esm/components/filtered-search/filter-token.js +12 -0
- package/dist/esm/components/filtered-search/filter-value-list.js +15 -0
- package/{types → dist/esm}/components/filtered-search/filtered-search.d.ts +1 -1
- package/{esm → dist/esm}/components/filtered-search/filtered-search.js +11 -16
- package/{types → dist/esm}/components/filtered-search/index.d.ts +4 -4
- package/dist/esm/components/filtered-search/index.js +3 -0
- package/dist/esm/components/filtered-search/model/abstract-filter.js +2 -0
- package/{types → dist/esm}/components/filtered-search/model/string-filter.d.ts +2 -2
- package/{esm → dist/esm}/components/filtered-search/model/string-filter.js +1 -4
- package/{types → dist/esm}/components/filtered-search/model/string-set-filter.d.ts +1 -1
- package/{esm → dist/esm}/components/filtered-search/model/string-set-filter.js +1 -4
- package/dist/esm/components/filtered-search/model/validation-result.js +1 -0
- package/dist/esm/components/filtered-search/string-filter-input.js +15 -0
- package/{types → dist/esm}/components/filtered-search/string-filter-item.d.ts +1 -1
- package/{esm → dist/esm}/components/filtered-search/string-filter-item.js +6 -10
- package/{types → dist/esm}/components/filtered-search/string-set-filter-item.d.ts +1 -1
- package/{esm → dist/esm}/components/filtered-search/string-set-filter-item.js +6 -10
- package/{types → dist/esm}/components/filtered-search/types.d.ts +2 -2
- package/dist/esm/components/filtered-search/types.js +1 -0
- package/{esm → dist/esm}/components/filtered-search/use-combobox-ids.js +2 -5
- package/{esm → dist/esm}/components/filtered-search/use-translations.js +4 -7
- package/{types → dist/esm}/components/form-field/form-field.d.ts +7 -3
- package/dist/esm/components/form-field/form-field.js +37 -0
- package/dist/esm/components/form-field/index.d.ts +1 -0
- package/dist/esm/components/form-field/index.js +1 -0
- package/dist/esm/components/hero-icons/24/outline/arrow-small-down-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/arrow-small-down-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/arrow-small-up-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/arrow-small-up-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/arrows-up-down-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/arrows-up-down-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/chevron-left-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/chevron-left-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/chevron-right-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/chevron-right-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/eye-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/eye-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/eye-slash-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/eye-slash-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/magnifying-glass-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/magnifying-glass-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/trash-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/trash-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/outline/x-mark-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/outline/x-mark-icon.js +5 -0
- package/dist/esm/components/hero-icons/24/solid/exclamation-triangle-icon.d.ts +4 -0
- package/dist/esm/components/hero-icons/24/solid/exclamation-triangle-icon.js +5 -0
- package/dist/esm/components/index.d.ts +42 -0
- package/dist/esm/components/index.js +42 -0
- package/dist/esm/components/label/index.d.ts +1 -0
- package/dist/esm/components/label/index.js +1 -0
- package/dist/esm/components/label/label.js +8 -0
- package/dist/esm/components/menu/index.d.ts +3 -0
- package/dist/esm/components/menu/index.js +3 -0
- package/{types → dist/esm}/components/menu/menu-item.d.ts +4 -6
- package/dist/esm/components/menu/menu-item.js +16 -0
- package/dist/esm/components/menu/menu-separator.js +5 -0
- package/{types → dist/esm}/components/menu/menu.d.ts +6 -5
- package/{esm → dist/esm}/components/menu/menu.js +7 -11
- package/dist/esm/components/nav-list/index.d.ts +3 -0
- package/dist/esm/components/nav-list/index.js +3 -0
- package/dist/esm/components/nav-list/nav-list-item.js +15 -0
- package/dist/esm/components/nav-list/nav-list-title.js +5 -0
- package/dist/esm/components/nav-list/nav-list.js +5 -0
- package/dist/esm/components/password-input/index.d.ts +1 -0
- package/dist/esm/components/password-input/index.js +1 -0
- package/dist/esm/components/password-input/password-input.d.ts +9 -0
- package/dist/esm/components/password-input/password-input.js +17 -0
- package/dist/esm/components/popover/index.d.ts +1 -0
- package/dist/esm/components/popover/index.js +1 -0
- package/{types → dist/esm}/components/popover/popover.d.ts +1 -1
- package/{esm → dist/esm}/components/popover/popover.js +8 -11
- package/{esm → dist/esm}/components/popover/use-page-click.js +2 -5
- package/dist/esm/components/portal/index.d.ts +1 -0
- package/dist/esm/components/portal/index.js +1 -0
- package/{esm → dist/esm}/components/portal/portal-context.js +6 -5
- package/{esm → dist/esm}/components/portal/portal.js +1 -4
- package/{types → dist/esm}/components/positioner/calc-position.d.ts +1 -1
- package/{esm → dist/esm}/components/positioner/calc-position.js +2 -4
- package/dist/esm/components/positioner/index.d.ts +1 -0
- package/dist/esm/components/positioner/index.js +1 -0
- package/{types → dist/esm}/components/positioner/positioner.d.ts +1 -1
- package/{esm → dist/esm}/components/positioner/positioner.js +5 -8
- package/dist/esm/components/positioner/types.js +1 -0
- package/dist/esm/components/radio/index.d.ts +1 -0
- package/dist/esm/components/radio/index.js +1 -0
- package/dist/esm/components/radio/radio.js +23 -0
- package/dist/esm/components/segmented-control/index.d.ts +1 -0
- package/dist/esm/components/segmented-control/index.js +1 -0
- package/dist/esm/components/segmented-control/segmented-button.d.ts +11 -0
- package/dist/esm/components/segmented-control/segmented-button.js +10 -0
- package/{types → dist/esm}/components/segmented-control/segmented-control.d.ts +5 -3
- package/dist/esm/components/segmented-control/segmented-control.js +15 -0
- package/dist/esm/components/select/index.d.ts +1 -0
- package/dist/esm/components/select/index.js +1 -0
- package/{types → dist/esm}/components/select/select.d.ts +9 -9
- package/dist/esm/components/select/select.js +34 -0
- package/dist/esm/components/selection-control/index.d.ts +1 -0
- package/dist/esm/components/selection-control/index.js +1 -0
- package/dist/esm/components/selection-control/selection-control.js +15 -0
- package/dist/esm/components/slide-over/index.d.ts +4 -0
- package/dist/esm/components/slide-over/index.js +3 -0
- package/dist/esm/components/slide-over/slide-over-body.js +5 -0
- package/{types → dist/esm}/components/slide-over/slide-over-context.d.ts +1 -1
- package/{esm → dist/esm}/components/slide-over/slide-over-context.js +4 -7
- package/dist/esm/components/slide-over/slide-over-header.js +13 -0
- package/dist/esm/components/slide-over/slide-over.d.ts +25 -0
- package/{esm → dist/esm}/components/slide-over/slide-over.js +19 -17
- package/dist/esm/components/slide-over/types.d.ts +1 -0
- package/dist/esm/components/slide-over/types.js +1 -0
- package/dist/esm/components/slider/index.d.ts +2 -0
- package/dist/esm/components/slider/index.js +2 -0
- package/dist/esm/components/slider/slider-tick-marks.js +12 -0
- package/{types → dist/esm}/components/slider/slider.d.ts +1 -1
- package/{esm → dist/esm}/components/slider/slider.js +5 -8
- package/dist/esm/components/spinner/index.d.ts +1 -0
- package/dist/esm/components/spinner/index.js +1 -0
- package/dist/esm/components/spinner/spinner.js +6 -0
- package/dist/esm/components/switch/index.d.ts +1 -0
- package/dist/esm/components/switch/index.js +1 -0
- package/dist/esm/components/switch/switch.js +12 -0
- package/dist/esm/components/table/index.d.ts +7 -0
- package/dist/esm/components/table/index.js +7 -0
- package/dist/esm/components/table/table-body.js +6 -0
- package/dist/esm/components/table/table-cell.js +6 -0
- package/{esm → dist/esm}/components/table/table-container.js +3 -6
- package/{types → dist/esm}/components/table/table-head-cell.d.ts +1 -1
- package/dist/esm/components/table/table-head-cell.js +27 -0
- package/dist/esm/components/table/table-head.js +9 -0
- package/dist/esm/components/table/table-row.js +9 -0
- package/{esm → dist/esm}/components/table/table.js +3 -6
- package/dist/esm/components/tabs/index.d.ts +4 -0
- package/dist/esm/components/tabs/index.js +4 -0
- package/{esm → dist/esm}/components/tabs/tab-list.js +3 -6
- package/{types → dist/esm}/components/tabs/tab-panel.d.ts +1 -1
- package/dist/esm/components/tabs/tab-panel.js +11 -0
- package/dist/esm/components/tabs/tab.js +14 -0
- package/{types → dist/esm}/components/tabs/tabs-context.d.ts +1 -1
- package/{esm → dist/esm}/components/tabs/tabs-context.js +5 -8
- package/{types → dist/esm}/components/tabs/tabs.d.ts +1 -1
- package/dist/esm/components/tabs/tabs.js +6 -0
- package/dist/esm/components/tabs/types.js +1 -0
- package/dist/esm/components/tag/index.d.ts +1 -0
- package/dist/esm/components/tag/index.js +1 -0
- package/dist/esm/components/tag/tag.d.ts +15 -0
- package/dist/esm/components/tag/tag.js +11 -0
- package/dist/esm/components/text-input/index.d.ts +1 -0
- package/dist/esm/components/text-input/index.js +1 -0
- package/{types → dist/esm}/components/text-input/text-input.d.ts +12 -13
- package/dist/esm/components/text-input/text-input.js +42 -0
- package/dist/esm/components/textarea/index.d.ts +1 -0
- package/dist/esm/components/textarea/index.js +1 -0
- package/dist/esm/components/textarea/textarea.d.ts +12 -0
- package/dist/esm/components/textarea/textarea.js +19 -0
- package/dist/esm/components/toast/index.d.ts +2 -0
- package/dist/esm/components/toast/index.js +2 -0
- package/dist/esm/components/toast/toast-button.js +6 -0
- package/dist/esm/components/toast/toast.js +6 -0
- package/dist/esm/components/toaster/index.d.ts +1 -0
- package/dist/esm/components/toaster/index.js +1 -0
- package/{esm → dist/esm}/components/toaster/toaster.js +9 -13
- package/dist/esm/components/tooltip/index.d.ts +1 -0
- package/dist/esm/components/tooltip/index.js +1 -0
- package/{types → dist/esm}/components/tooltip/tooltip.d.ts +1 -1
- package/{esm → dist/esm}/components/tooltip/tooltip.js +8 -11
- package/dist/esm/hooks/index.d.ts +4 -0
- package/dist/esm/hooks/index.js +4 -0
- package/{esm → dist/esm}/hooks/use-disable-body-scroll.js +1 -4
- package/{esm → dist/esm}/hooks/use-esc-key-down.js +2 -5
- package/{esm → dist/esm}/hooks/use-focus-trap.js +1 -4
- package/{esm → dist/esm}/hooks/use-mount-transition.js +2 -5
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.js +3 -0
- package/{esm → dist/esm}/lib/helpers.js +3 -5
- package/dist/esm/lib/index.d.ts +3 -0
- package/dist/esm/lib/index.js +3 -0
- package/{esm → dist/esm}/lib/keyboard-keys.js +1 -3
- package/{esm → dist/esm}/lib/react-helpers.js +6 -9
- package/package.json +41 -55
- package/cjs/components/alert/alert.cjs +0 -19
- package/cjs/components/avatar/avatar.cjs +0 -31
- package/cjs/components/avatar-group/avatar-group.cjs +0 -10
- package/cjs/components/badge/badge.cjs +0 -23
- package/cjs/components/breadcrumbs/breadcrumbs-context.cjs +0 -19
- package/cjs/components/breadcrumbs/breadcrumbs-item.cjs +0 -21
- package/cjs/components/breadcrumbs/breadcrumbs.cjs +0 -12
- package/cjs/components/button/button.cjs +0 -41
- package/cjs/components/button/icon-button.cjs +0 -12
- package/cjs/components/button-group/button-group.cjs +0 -10
- package/cjs/components/caption/caption.cjs +0 -27
- package/cjs/components/caption/icons.cjs +0 -21
- package/cjs/components/checkbox/checkbox.cjs +0 -20
- package/cjs/components/color-picker/color-picker-button.cjs +0 -16
- package/cjs/components/color-picker/color-picker.cjs +0 -24
- package/cjs/components/date-picker/calendar-day.cjs +0 -17
- package/cjs/components/date-picker/calendar-grid-head.cjs +0 -16
- package/cjs/components/date-picker/calendar-grid.cjs +0 -106
- package/cjs/components/date-picker/calendar-header.cjs +0 -48
- package/cjs/components/date-picker/calendar.cjs +0 -24
- package/cjs/components/date-picker/date-helpers.cjs +0 -112
- package/cjs/components/date-picker/date-picker.cjs +0 -20
- package/cjs/components/date-picker/date-range-picker.cjs +0 -61
- package/cjs/components/date-picker/date-range.cjs +0 -28
- package/cjs/components/date-picker/icons.cjs +0 -13
- package/cjs/components/date-picker/parse-min-max-props.cjs +0 -20
- package/cjs/components/date-picker-popover/date-picker-popover.cjs +0 -24
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-footer.cjs +0 -11
- package/cjs/components/date-range-picker-popover/date-range-picker-popover-presets.cjs +0 -35
- package/cjs/components/date-range-picker-popover/date-range-picker-popover.cjs +0 -59
- package/cjs/components/date-range-picker-popover/helpers.cjs +0 -15
- package/cjs/components/date-range-picker-popover/use-is-compact-view.cjs +0 -27
- package/cjs/components/dialog/dialog-body.cjs +0 -12
- package/cjs/components/dialog/dialog-context.cjs +0 -24
- package/cjs/components/dialog/dialog-footer.cjs +0 -13
- package/cjs/components/dialog/dialog-header.cjs +0 -21
- package/cjs/components/dialog/dialog.cjs +0 -50
- package/cjs/components/dialog/x-mark-icon.cjs +0 -9
- package/cjs/components/empty-state/empty-state.cjs +0 -10
- package/cjs/components/file-picker/file-picker.cjs +0 -47
- package/cjs/components/filter-buttons/filter-button.cjs +0 -11
- package/cjs/components/filter-buttons/filter-buttons.cjs +0 -27
- package/cjs/components/filtered-search/filter-item.cjs +0 -23
- package/cjs/components/filtered-search/filter-operator-select.cjs +0 -17
- package/cjs/components/filtered-search/filter-token.cjs +0 -17
- package/cjs/components/filtered-search/filter-value-list.cjs +0 -20
- package/cjs/components/filtered-search/filtered-search.cjs +0 -225
- package/cjs/components/filtered-search/icons.cjs +0 -21
- package/cjs/components/filtered-search/model/abstract-filter.cjs +0 -6
- package/cjs/components/filtered-search/model/string-filter.cjs +0 -46
- package/cjs/components/filtered-search/model/string-set-filter.cjs +0 -44
- package/cjs/components/filtered-search/string-filter-input.cjs +0 -17
- package/cjs/components/filtered-search/string-filter-item.cjs +0 -68
- package/cjs/components/filtered-search/string-set-filter-item.cjs +0 -77
- package/cjs/components/filtered-search/use-combobox-ids.cjs +0 -17
- package/cjs/components/filtered-search/use-translations.cjs +0 -24
- package/cjs/components/form-field/form-field.cjs +0 -26
- package/cjs/components/index.cjs +0 -141
- package/cjs/components/label/label.cjs +0 -13
- package/cjs/components/menu/menu-item.cjs +0 -21
- package/cjs/components/menu/menu-separator.cjs +0 -10
- package/cjs/components/menu/menu.cjs +0 -191
- package/cjs/components/nav-list/nav-list-item.cjs +0 -20
- package/cjs/components/nav-list/nav-list-title.cjs +0 -10
- package/cjs/components/nav-list/nav-list.cjs +0 -10
- package/cjs/components/password-input/icons.cjs +0 -13
- package/cjs/components/password-input/password-input.cjs +0 -30
- package/cjs/components/popover/popover.cjs +0 -96
- package/cjs/components/popover/use-page-click.cjs +0 -51
- package/cjs/components/portal/portal-context.cjs +0 -22
- package/cjs/components/portal/portal.cjs +0 -11
- package/cjs/components/positioner/calc-position.cjs +0 -117
- package/cjs/components/positioner/positioner.cjs +0 -64
- package/cjs/components/radio/radio.cjs +0 -28
- package/cjs/components/segmented-control/segmented-control-button.cjs +0 -15
- package/cjs/components/segmented-control/segmented-control.cjs +0 -48
- package/cjs/components/select/select.cjs +0 -39
- package/cjs/components/selection-control/selection-control.cjs +0 -18
- package/cjs/components/slide-over/slide-over-body.cjs +0 -10
- package/cjs/components/slide-over/slide-over-context.cjs +0 -24
- package/cjs/components/slide-over/slide-over-header.cjs +0 -21
- package/cjs/components/slide-over/slide-over.cjs +0 -106
- package/cjs/components/slider/slider-tick-marks.cjs +0 -17
- package/cjs/components/slider/slider.cjs +0 -41
- package/cjs/components/spinner/spinner.cjs +0 -11
- package/cjs/components/switch/switch.cjs +0 -17
- package/cjs/components/table/icons.cjs +0 -17
- package/cjs/components/table/table-body.cjs +0 -11
- package/cjs/components/table/table-cell.cjs +0 -11
- package/cjs/components/table/table-container.cjs +0 -23
- package/cjs/components/table/table-head-cell.cjs +0 -30
- package/cjs/components/table/table-head.cjs +0 -14
- package/cjs/components/table/table-row.cjs +0 -14
- package/cjs/components/table/table.cjs +0 -16
- package/cjs/components/tabs/tab-list.cjs +0 -67
- package/cjs/components/tabs/tab-panel.cjs +0 -16
- package/cjs/components/tabs/tab.cjs +0 -19
- package/cjs/components/tabs/tabs-context.cjs +0 -31
- package/cjs/components/tabs/tabs.cjs +0 -11
- package/cjs/components/tag/tag.cjs +0 -16
- package/cjs/components/text-input/text-input.cjs +0 -42
- package/cjs/components/textarea/textarea.cjs +0 -40
- package/cjs/components/toast/toast-button.cjs +0 -11
- package/cjs/components/toast/toast.cjs +0 -11
- package/cjs/components/toast/x-mark-icon.cjs +0 -9
- package/cjs/components/toaster/toaster.cjs +0 -115
- package/cjs/components/tooltip/tooltip.cjs +0 -75
- package/cjs/hooks/index.cjs +0 -13
- package/cjs/hooks/use-disable-body-scroll.cjs +0 -37
- package/cjs/hooks/use-esc-key-down.cjs +0 -56
- package/cjs/hooks/use-focus-trap.cjs +0 -89
- package/cjs/hooks/use-mount-transition.cjs +0 -41
- package/cjs/index.cjs +0 -161
- package/cjs/lib/helpers.cjs +0 -25
- package/cjs/lib/index.cjs +0 -17
- package/cjs/lib/keyboard-keys.cjs +0 -19
- package/cjs/lib/react-helpers.cjs +0 -58
- package/esm/components/alert/alert.js +0 -17
- package/esm/components/avatar/avatar.js +0 -29
- package/esm/components/avatar-group/avatar-group.js +0 -8
- package/esm/components/breadcrumbs/breadcrumbs-context.js +0 -16
- package/esm/components/breadcrumbs/breadcrumbs-item.js +0 -19
- package/esm/components/breadcrumbs/breadcrumbs.js +0 -10
- package/esm/components/button/button.js +0 -39
- package/esm/components/button/icon-button.js +0 -10
- package/esm/components/button-group/button-group.js +0 -8
- package/esm/components/caption/caption.js +0 -25
- package/esm/components/caption/icons.js +0 -16
- package/esm/components/checkbox/checkbox.js +0 -18
- package/esm/components/color-picker/color-picker-button.js +0 -14
- package/esm/components/date-picker/calendar-grid-head.js +0 -14
- package/esm/components/date-picker/calendar-header.js +0 -46
- package/esm/components/date-picker/calendar.js +0 -22
- package/esm/components/date-picker/date-picker.js +0 -18
- package/esm/components/date-picker/icons.js +0 -10
- package/esm/components/date-picker-popover/date-picker-popover.js +0 -22
- package/esm/components/date-range-picker-popover/date-range-picker-popover-footer.js +0 -9
- package/esm/components/date-range-picker-popover/date-range-picker-popover-presets.js +0 -33
- package/esm/components/dialog/dialog-body.js +0 -10
- package/esm/components/dialog/dialog-footer.js +0 -11
- package/esm/components/dialog/dialog-header.js +0 -19
- package/esm/components/dialog/x-mark-icon.js +0 -7
- package/esm/components/empty-state/empty-state.js +0 -8
- package/esm/components/filter-buttons/filter-button.js +0 -9
- package/esm/components/filtered-search/filter-item.js +0 -21
- package/esm/components/filtered-search/filter-operator-select.js +0 -15
- package/esm/components/filtered-search/filter-token.js +0 -15
- package/esm/components/filtered-search/filter-value-list.js +0 -18
- package/esm/components/filtered-search/icons.js +0 -16
- package/esm/components/filtered-search/model/abstract-filter.js +0 -4
- package/esm/components/filtered-search/string-filter-input.js +0 -15
- package/esm/components/form-field/form-field.js +0 -24
- package/esm/components/index.js +0 -68
- package/esm/components/label/label.js +0 -11
- package/esm/components/menu/menu-item.js +0 -19
- package/esm/components/menu/menu-separator.js +0 -8
- package/esm/components/nav-list/nav-list-item.js +0 -18
- package/esm/components/nav-list/nav-list-title.js +0 -8
- package/esm/components/nav-list/nav-list.js +0 -8
- package/esm/components/password-input/icons.js +0 -10
- package/esm/components/password-input/password-input.js +0 -28
- package/esm/components/radio/radio.js +0 -26
- package/esm/components/segmented-control/segmented-control-button.js +0 -13
- package/esm/components/segmented-control/segmented-control.js +0 -46
- package/esm/components/select/select.js +0 -37
- package/esm/components/selection-control/selection-control.js +0 -16
- package/esm/components/slide-over/slide-over-body.js +0 -8
- package/esm/components/slide-over/slide-over-header.js +0 -19
- package/esm/components/slider/slider-tick-marks.js +0 -15
- package/esm/components/spinner/spinner.js +0 -9
- package/esm/components/switch/switch.js +0 -15
- package/esm/components/table/icons.js +0 -13
- package/esm/components/table/table-body.js +0 -9
- package/esm/components/table/table-cell.js +0 -9
- package/esm/components/table/table-head-cell.js +0 -28
- package/esm/components/table/table-head.js +0 -12
- package/esm/components/table/table-row.js +0 -12
- package/esm/components/tabs/tab-panel.js +0 -14
- package/esm/components/tabs/tab.js +0 -17
- package/esm/components/tabs/tabs.js +0 -9
- package/esm/components/tag/tag.js +0 -14
- package/esm/components/text-input/text-input.js +0 -40
- package/esm/components/textarea/textarea.js +0 -38
- package/esm/components/toast/toast-button.js +0 -9
- package/esm/components/toast/toast.js +0 -9
- package/esm/components/toast/x-mark-icon.js +0 -7
- package/esm/hooks/index.js +0 -4
- package/esm/index.js +0 -75
- package/esm/lib/index.js +0 -3
- package/types/components/alert/alert.d.ts +0 -12
- package/types/components/alert/index.d.ts +0 -1
- package/types/components/avatar/index.d.ts +0 -1
- package/types/components/avatar-group/index.d.ts +0 -1
- package/types/components/badge/index.d.ts +0 -1
- package/types/components/breadcrumbs/index.d.ts +0 -2
- package/types/components/button/icon-button.d.ts +0 -7
- package/types/components/button/index.d.ts +0 -2
- package/types/components/button-group/index.d.ts +0 -1
- package/types/components/caption/caption.d.ts +0 -7
- package/types/components/caption/icons.d.ts +0 -5
- package/types/components/caption/index.d.ts +0 -1
- package/types/components/checkbox/index.d.ts +0 -1
- package/types/components/color-picker/index.d.ts +0 -1
- package/types/components/date-picker/icons.d.ts +0 -3
- package/types/components/date-picker/index.d.ts +0 -2
- package/types/components/date-picker-popover/index.d.ts +0 -1
- package/types/components/date-range-picker-popover/index.d.ts +0 -2
- package/types/components/dialog/index.d.ts +0 -4
- package/types/components/dialog/x-mark-icon.d.ts +0 -2
- package/types/components/empty-state/empty-state.d.ts +0 -11
- package/types/components/empty-state/index.d.ts +0 -1
- package/types/components/file-picker/index.d.ts +0 -1
- package/types/components/filter-buttons/index.d.ts +0 -2
- package/types/components/filtered-search/icons.d.ts +0 -5
- package/types/components/form-field/index.d.ts +0 -1
- package/types/components/index.d.ts +0 -42
- package/types/components/label/index.d.ts +0 -1
- package/types/components/menu/index.d.ts +0 -3
- package/types/components/nav-list/index.d.ts +0 -3
- package/types/components/password-input/icons.d.ts +0 -3
- package/types/components/password-input/index.d.ts +0 -1
- package/types/components/password-input/password-input.d.ts +0 -10
- package/types/components/popover/index.d.ts +0 -1
- package/types/components/portal/index.d.ts +0 -1
- package/types/components/positioner/index.d.ts +0 -1
- package/types/components/radio/index.d.ts +0 -1
- package/types/components/segmented-control/index.d.ts +0 -1
- package/types/components/segmented-control/segmented-control-button.d.ts +0 -10
- package/types/components/select/index.d.ts +0 -1
- package/types/components/selection-control/index.d.ts +0 -1
- package/types/components/slide-over/index.d.ts +0 -4
- package/types/components/slide-over/slide-over.d.ts +0 -15
- package/types/components/slide-over/types.d.ts +0 -1
- package/types/components/slider/index.d.ts +0 -2
- package/types/components/spinner/index.d.ts +0 -1
- package/types/components/switch/index.d.ts +0 -1
- package/types/components/table/icons.d.ts +0 -4
- package/types/components/table/index.d.ts +0 -7
- package/types/components/tabs/index.d.ts +0 -4
- package/types/components/tag/index.d.ts +0 -1
- package/types/components/tag/tag.d.ts +0 -18
- package/types/components/text-input/index.d.ts +0 -1
- package/types/components/textarea/index.d.ts +0 -1
- package/types/components/textarea/textarea.d.ts +0 -20
- package/types/components/toast/index.d.ts +0 -2
- package/types/components/toast/x-mark-icon.d.ts +0 -2
- package/types/components/toaster/index.d.ts +0 -1
- package/types/components/tooltip/index.d.ts +0 -1
- package/types/hooks/index.d.ts +0 -4
- package/types/index.d.ts +0 -3
- package/types/lib/index.d.ts +0 -3
- /package/{css → dist/css}/draft-components-utilities.css +0 -0
- /package/{types → dist/esm}/components/avatar-group/avatar-group.d.ts +0 -0
- /package/{types → dist/esm}/components/badge/badge.d.ts +0 -0
- /package/{types → dist/esm}/components/breadcrumbs/breadcrumbs-context.d.ts +0 -0
- /package/{types → dist/esm}/components/breadcrumbs/breadcrumbs-item.d.ts +0 -0
- /package/{types → dist/esm}/components/breadcrumbs/breadcrumbs.d.ts +0 -0
- /package/{types → dist/esm}/components/button-group/button-group.d.ts +0 -0
- /package/{types → dist/esm}/components/checkbox/checkbox.d.ts +0 -0
- /package/{types → dist/esm}/components/color-picker/color-picker-button.d.ts +0 -0
- /package/{types → dist/esm}/components/color-picker/color-picker.d.ts +0 -0
- /package/{types → dist/esm}/components/date-picker/calendar-day.d.ts +0 -0
- /package/{types → dist/esm}/components/date-picker/calendar-header.d.ts +0 -0
- /package/{types → dist/esm}/components/date-picker/date-helpers.d.ts +0 -0
- /package/{types → dist/esm}/components/date-range-picker-popover/date-range-picker-popover-footer.d.ts +0 -0
- /package/{types → dist/esm}/components/date-range-picker-popover/use-is-compact-view.d.ts +0 -0
- /package/{types → dist/esm}/components/dialog/dialog-body.d.ts +0 -0
- /package/{types → dist/esm}/components/dialog/dialog-context.d.ts +0 -0
- /package/{types → dist/esm}/components/dialog/dialog-footer.d.ts +0 -0
- /package/{types → dist/esm}/components/dialog/dialog-header.d.ts +0 -0
- /package/{types → dist/esm}/components/dialog/dialog.d.ts +0 -0
- /package/{types → dist/esm}/components/file-picker/file-picker.d.ts +0 -0
- /package/{types → dist/esm}/components/filter-buttons/filter-button.d.ts +0 -0
- /package/{types → dist/esm}/components/filter-buttons/filter-buttons.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/filter-operator-select.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/filter-token.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/filter-value-list.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/model/abstract-filter.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/model/validation-result.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/string-filter-input.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/use-combobox-ids.d.ts +0 -0
- /package/{types → dist/esm}/components/filtered-search/use-translations.d.ts +0 -0
- /package/{types → dist/esm}/components/label/label.d.ts +0 -0
- /package/{types → dist/esm}/components/menu/menu-separator.d.ts +0 -0
- /package/{types → dist/esm}/components/nav-list/nav-list-item.d.ts +0 -0
- /package/{types → dist/esm}/components/nav-list/nav-list-title.d.ts +0 -0
- /package/{types → dist/esm}/components/nav-list/nav-list.d.ts +0 -0
- /package/{types → dist/esm}/components/popover/use-page-click.d.ts +0 -0
- /package/{types → dist/esm}/components/portal/portal-context.d.ts +0 -0
- /package/{types → dist/esm}/components/portal/portal.d.ts +0 -0
- /package/{types → dist/esm}/components/positioner/types.d.ts +0 -0
- /package/{types → dist/esm}/components/radio/radio.d.ts +0 -0
- /package/{types → dist/esm}/components/selection-control/selection-control.d.ts +0 -0
- /package/{types → dist/esm}/components/slide-over/slide-over-body.d.ts +0 -0
- /package/{types → dist/esm}/components/slide-over/slide-over-header.d.ts +0 -0
- /package/{types → dist/esm}/components/slider/slider-tick-marks.d.ts +0 -0
- /package/{types → dist/esm}/components/spinner/spinner.d.ts +0 -0
- /package/{types → dist/esm}/components/switch/switch.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table-body.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table-cell.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table-container.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table-head.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table-row.d.ts +0 -0
- /package/{types → dist/esm}/components/table/table.d.ts +0 -0
- /package/{types → dist/esm}/components/tabs/tab-list.d.ts +0 -0
- /package/{types → dist/esm}/components/tabs/tab.d.ts +0 -0
- /package/{types → dist/esm}/components/tabs/types.d.ts +0 -0
- /package/{types → dist/esm}/components/toast/toast-button.d.ts +0 -0
- /package/{types → dist/esm}/components/toast/toast.d.ts +0 -0
- /package/{types → dist/esm}/components/toaster/toaster.d.ts +0 -0
- /package/{types → dist/esm}/hooks/use-disable-body-scroll.d.ts +0 -0
- /package/{types → dist/esm}/hooks/use-esc-key-down.d.ts +0 -0
- /package/{types → dist/esm}/hooks/use-focus-trap.d.ts +0 -0
- /package/{types → dist/esm}/hooks/use-mount-transition.d.ts +0 -0
- /package/{types → dist/esm}/lib/helpers.d.ts +0 -0
- /package/{types → dist/esm}/lib/keyboard-keys.d.ts +0 -0
- /package/{types → dist/esm}/lib/react-helpers.d.ts +0 -0
|
@@ -1,14 +1,12 @@
|
|
|
1
|
-
import { jsx } from
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { KeyboardKeys } from '../../lib/keyboard-keys.js';
|
|
3
|
-
import {
|
|
3
|
+
import { Children, cloneElement, isValidElement, useId, useState, } from 'react';
|
|
4
4
|
import { classNames, focusElement } from '../../lib/react-helpers.js';
|
|
5
5
|
import { assertIfNullable } from '../../lib/helpers.js';
|
|
6
|
-
import { Button } from '../button/
|
|
7
|
-
import '../
|
|
8
|
-
import { Popover } from '../popover/popover.js';
|
|
6
|
+
import { Button } from '../button/index.js';
|
|
7
|
+
import { Popover } from '../popover/index.js';
|
|
9
8
|
import { MenuItem } from './menu-item.js';
|
|
10
|
-
|
|
11
|
-
function Menu({ defaultIsOpen = false, placement = 'bottom', alignment = 'start', buttonClassName = '', buttonAppearance = 'default', buttonVariant = 'filled', button, className, children, onOpen, onClose, onKeyDown, ...props }) {
|
|
9
|
+
export function Menu({ defaultIsOpen = false, placement = 'bottom', alignment = 'start', buttonClassName = '', buttonStyle = 'filled', buttonSize = 'sm', buttonTint = 'gray', button, className, children, onOpen, onClose, onKeyDown, ...props }) {
|
|
12
10
|
const id = useId();
|
|
13
11
|
const menuId = props.id || id;
|
|
14
12
|
const buttonId = `menu-button-${menuId}`;
|
|
@@ -156,9 +154,9 @@ function Menu({ defaultIsOpen = false, placement = 'bottom', alignment = 'start'
|
|
|
156
154
|
closeMenu,
|
|
157
155
|
});
|
|
158
156
|
}
|
|
159
|
-
return (
|
|
157
|
+
return (_jsx(Button, { "data-testid": "menu-button", ref: ref, id: buttonId, "aria-haspopup": true, "aria-expanded": isOpen, "aria-controls": menuId, className: buttonClassName, buttonStyle: buttonStyle, size: buttonSize, tint: buttonTint, onClick: handleButtonClick, onKeyDown: handleButtonKeyDown, children: button }));
|
|
160
158
|
};
|
|
161
|
-
return (
|
|
159
|
+
return (_jsx(Popover, { className: "dc-menu__container", placement: placement, alignment: alignment, anchor: renderAnchor, isOpen: isOpen, onClose: closeMenu, children: _jsx("ul", { ...props, className: classNames('dc-menu', className), role: "menu", id: menuId, "aria-labelledby": buttonId, onKeyDown: handleMenuKeyDown, children: Children.map(children, (child) => {
|
|
162
160
|
if (isMenuItem(child)) {
|
|
163
161
|
const props = child.props;
|
|
164
162
|
const onClick = (event) => {
|
|
@@ -185,5 +183,3 @@ function getMenuItems(menuId) {
|
|
|
185
183
|
const nodes = menuEl.querySelectorAll('button[role="menuitem"], button[role="menuitemradio"]');
|
|
186
184
|
return Array.from(nodes);
|
|
187
185
|
}
|
|
188
|
-
|
|
189
|
-
export { Menu };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
3
|
+
import { Badge } from '../badge/index.js';
|
|
4
|
+
export function NavListItem({ className, icon, badge, children, renderAs, ...props }) {
|
|
5
|
+
className = classNames(className, 'dc-nav-link');
|
|
6
|
+
children = (_jsxs(_Fragment, { children: [icon != null && _jsxs("div", { className: "dc-nav-link__icon", children: [icon, " "] }), _jsx("div", { className: "dc-nav-link__text", children: children }), badge != null && _jsxs(_Fragment, { children: ["\u00A0", _jsx(Badge, { className: "dc-nav-link__badge", children: badge })] })] }));
|
|
7
|
+
let content;
|
|
8
|
+
if (typeof renderAs === 'function') {
|
|
9
|
+
content = renderAs({ className, children });
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
content = _jsx("a", { ...props, className: className, children: children });
|
|
13
|
+
}
|
|
14
|
+
return _jsx("li", { className: "dc-nav-list__item", children: content });
|
|
15
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
3
|
+
export function NavListTitle({ className, children, ...props }) {
|
|
4
|
+
return (_jsx("li", { ...props, className: classNames('dc-nav-list__title', className), children: children }));
|
|
5
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
3
|
+
export function NavList({ className, children, ...props }) {
|
|
4
|
+
return (_jsx("nav", { ...props, className: classNames('dc-nav-list', className), children: _jsx("ul", { className: "dc-nav-list__items", children: children }) }));
|
|
5
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './password-input.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './password-input.js';
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { TextInputProps } from '../text-input/index.js';
|
|
3
|
+
export type PasswordInputBaseProps = Omit<TextInputProps, 'type' | 'slotRight'>;
|
|
4
|
+
export type PasswordInputProps = {
|
|
5
|
+
defaultVisible?: boolean;
|
|
6
|
+
getTooltipText?: (visible: boolean) => ReactNode;
|
|
7
|
+
renderToggleButtonIcon?: (visible: boolean) => ReactNode;
|
|
8
|
+
} & PasswordInputBaseProps;
|
|
9
|
+
export declare const PasswordInput: import("react").ForwardRefExoticComponent<Omit<PasswordInputProps, "ref"> & import("react").RefAttributes<HTMLInputElement>>;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef, useState } from 'react';
|
|
3
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
4
|
+
import { TextInput } from '../text-input/index.js';
|
|
5
|
+
import { Tooltip } from '../tooltip/index.js';
|
|
6
|
+
import { EyeIcon } from '../hero-icons/24/outline/eye-icon.js';
|
|
7
|
+
import { EyeSlashIcon } from '../hero-icons/24/outline/eye-slash-icon.js';
|
|
8
|
+
const getDefaultTooltipText = (visible) => (visible
|
|
9
|
+
? 'Hide password'
|
|
10
|
+
: 'Show password');
|
|
11
|
+
const renderToggleButtonDefaultIcon = (visible) => (visible
|
|
12
|
+
? _jsx(EyeIcon, { width: "1.25em", height: "1.25em" })
|
|
13
|
+
: _jsx(EyeSlashIcon, { width: "1.25em", height: "1.25em" }));
|
|
14
|
+
export const PasswordInput = forwardRef(function PasswordInput({ className, defaultVisible = false, getTooltipText = getDefaultTooltipText, renderToggleButtonIcon = renderToggleButtonDefaultIcon, ...props }, ref) {
|
|
15
|
+
const [visible, setVisible] = useState(defaultVisible);
|
|
16
|
+
return (_jsx(TextInput, { ...props, ref: ref, className: classNames('dc-password-input', className), type: visible ? 'text' : 'password', slotRight: () => (_jsx(Tooltip, { content: getTooltipText(visible), children: _jsx("button", { className: "dc-password-input__toggle-button", type: "button", onClick: () => setVisible(!visible), children: renderToggleButtonIcon(visible) }) })) }));
|
|
17
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './popover.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './popover.js';
|
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import { jsx } from
|
|
2
|
-
import { forwardRef,
|
|
3
|
-
import {
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { cloneElement, forwardRef, useCallback, useImperativeHandle, useRef, useState, } from 'react';
|
|
3
|
+
import { classNames, focusElement, isReactElementWithRef, mergeRefs } from '../../lib/react-helpers.js';
|
|
4
4
|
import { useMountTransition } from '../../hooks/use-mount-transition.js';
|
|
5
5
|
import { useEscKeyDown } from '../../hooks/use-esc-key-down.js';
|
|
6
6
|
import { useFocusTrap } from '../../hooks/use-focus-trap.js';
|
|
7
7
|
import { usePageClick } from './use-page-click.js';
|
|
8
|
-
import { Positioner } from '../positioner/
|
|
9
|
-
|
|
10
|
-
const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocusAnchorAfterEscPress = true, transitionDurationMs = 100, placement = 'bottom', alignment = 'start', anchorGap, viewportGap, anchor, className, children, onOpen, onClose, ...props }, ref) {
|
|
8
|
+
import { Positioner, } from '../positioner/index.js';
|
|
9
|
+
export const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocusAnchorAfterEscPress = true, transitionDurationMs = 100, placement = 'bottom', alignment = 'start', anchorGap, viewportGap, anchor, className, children, onOpen, onClose, ...props }, ref) {
|
|
11
10
|
const [defaultIsOpen, setDefaultIsOpen] = useState(props.defaultIsOpen ?? false);
|
|
12
11
|
const anchorRef = useRef(null);
|
|
13
12
|
const contentRef = useRef(null);
|
|
@@ -82,13 +81,11 @@ const Popover = forwardRef(function Popover({ shouldTrapFocus = true, shouldFocu
|
|
|
82
81
|
if (isOpen || isMounted) {
|
|
83
82
|
delete props.defaultIsOpen;
|
|
84
83
|
delete props.isOpen;
|
|
85
|
-
return (
|
|
84
|
+
return (_jsx("div", { ref: portalRef, style: {
|
|
86
85
|
'--dc-popover-transition-duration': `${transitionDurationMs}ms`,
|
|
87
86
|
...portalStyle,
|
|
88
|
-
}, className: classNames('dc-popover', transitionClass), children:
|
|
87
|
+
}, className: classNames('dc-popover', transitionClass), children: _jsx("div", { ...props, ref: contentRef, className: classNames('dc-popover-modal', className), children: children }) }));
|
|
89
88
|
}
|
|
90
89
|
};
|
|
91
|
-
return (
|
|
90
|
+
return (_jsx(Positioner, { position: "absolute", placement: placement, alignment: alignment, anchorGap: anchorGap, viewportGap: viewportGap, renderAnchor: renderAnchor, renderContent: renderContent }));
|
|
92
91
|
});
|
|
93
|
-
|
|
94
|
-
export { Popover };
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
1
|
+
import { useEffect, useRef } from 'react';
|
|
3
2
|
const handlers = [];
|
|
4
3
|
/**
|
|
5
4
|
* Invokes a given handler when the user clicks on any place on the page.
|
|
@@ -11,7 +10,7 @@ const handlers = [];
|
|
|
11
10
|
* @param options.isEnabled - A flag that determines whether to run
|
|
12
11
|
* the passed handler or not.
|
|
13
12
|
*/
|
|
14
|
-
function usePageClick(handler, options) {
|
|
13
|
+
export function usePageClick(handler, options) {
|
|
15
14
|
const handlerRef = useRef(handler);
|
|
16
15
|
const isEnabled = options.isEnabled;
|
|
17
16
|
useEffect(() => {
|
|
@@ -45,5 +44,3 @@ function usePageClick(handler, options) {
|
|
|
45
44
|
};
|
|
46
45
|
}, [isEnabled]);
|
|
47
46
|
}
|
|
48
|
-
|
|
49
|
-
export { usePageClick };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './portal.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './portal.js';
|
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { createContext, useContext } from 'react';
|
|
3
|
-
|
|
4
3
|
let root = null;
|
|
5
4
|
const getPortalRoot = () => {
|
|
6
5
|
if (root == null) {
|
|
@@ -12,9 +11,11 @@ const getPortalRoot = () => {
|
|
|
12
11
|
return root;
|
|
13
12
|
};
|
|
14
13
|
const PortalContext = createContext(getPortalRoot);
|
|
15
|
-
function usePortalRoot() {
|
|
14
|
+
export function usePortalRoot() {
|
|
16
15
|
const getRoot = useContext(PortalContext);
|
|
17
16
|
return getRoot();
|
|
18
17
|
}
|
|
19
|
-
|
|
20
|
-
|
|
18
|
+
export function PortalRootProvider(props) {
|
|
19
|
+
const { getPortalRoot, children } = props;
|
|
20
|
+
return (_jsx(PortalContext.Provider, { value: getPortalRoot, children: children }));
|
|
21
|
+
}
|
|
@@ -1,9 +1,6 @@
|
|
|
1
1
|
import { createPortal } from 'react-dom';
|
|
2
2
|
import { usePortalRoot } from './portal-context.js';
|
|
3
|
-
|
|
4
|
-
function Portal({ children }) {
|
|
3
|
+
export function Portal({ children }) {
|
|
5
4
|
const container = usePortalRoot();
|
|
6
5
|
return createPortal(children, container);
|
|
7
6
|
}
|
|
8
|
-
|
|
9
|
-
export { Portal };
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
function calcPosition({ placement, alignment, anchorRect, contentRect, viewportWidth, viewportHeight, scrollX, scrollY, anchorGap, viewportGap, }) {
|
|
1
|
+
export function calcPosition({ placement, alignment, anchorRect, contentRect, viewportWidth, viewportHeight, scrollX, scrollY, anchorGap, viewportGap, }) {
|
|
2
2
|
const maxWidth = viewportWidth - (2 * viewportGap);
|
|
3
3
|
const maxSideWidth = Math.max(anchorRect.left - anchorGap - viewportGap, viewportWidth - anchorRect.right - anchorGap - viewportGap);
|
|
4
4
|
if ((placement === 'left' || placement === 'right') &&
|
|
@@ -88,7 +88,7 @@ function getXAxisOffset({ alignment, viewportGap, scrollX, anchorX, viewportWidt
|
|
|
88
88
|
}
|
|
89
89
|
return x;
|
|
90
90
|
}
|
|
91
|
-
function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewportHeight, contentHeight, anchorHeight, }) {
|
|
91
|
+
export function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewportHeight, contentHeight, anchorHeight, }) {
|
|
92
92
|
const anchorBottom = viewportHeight - anchorY + anchorHeight;
|
|
93
93
|
const top = scrollY + anchorY - anchorGap - contentHeight;
|
|
94
94
|
const bottom = scrollY + anchorY + anchorHeight + anchorGap;
|
|
@@ -110,5 +110,3 @@ function getYAxisOffset({ placement, anchorGap, scrollY, anchorY, viewportHeight
|
|
|
110
110
|
}
|
|
111
111
|
return { offset: y, placement };
|
|
112
112
|
}
|
|
113
|
-
|
|
114
|
-
export { calcPosition, getYAxisOffset };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './positioner.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './positioner.js';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CSSProperties, ReactNode, RefCallback } from 'react';
|
|
2
|
-
import { Alignment, Placement } from './types';
|
|
2
|
+
import { Alignment, Placement } from './types.js';
|
|
3
3
|
export type PositionerAnchorRenderFn = (params: {
|
|
4
4
|
setRef: RefCallback<HTMLElement>;
|
|
5
5
|
}) => ReactNode;
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useLayoutEffect, useState } from 'react';
|
|
3
3
|
import { calcPosition } from './calc-position.js';
|
|
4
|
-
import { Portal } from '../portal/
|
|
5
|
-
|
|
6
|
-
function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed', placement = 'bottom', alignment = 'start', renderAnchor, renderContent, }) {
|
|
4
|
+
import { Portal } from '../portal/index.js';
|
|
5
|
+
export function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed', placement = 'bottom', alignment = 'start', renderAnchor, renderContent, }) {
|
|
7
6
|
const [anchor, setAnchor] = useState(null);
|
|
8
7
|
const [content, setContent] = useState(null);
|
|
9
8
|
useLayoutEffect(() => {
|
|
@@ -35,7 +34,7 @@ function Positioner({ anchorGap = 4, viewportGap = 8, position = 'fixed', placem
|
|
|
35
34
|
window.removeEventListener('scroll', calcContentPosition);
|
|
36
35
|
};
|
|
37
36
|
}, [anchor, content, position, placement, alignment, anchorGap, viewportGap]);
|
|
38
|
-
return (
|
|
37
|
+
return (_jsxs(_Fragment, { children: [renderAnchor({ setRef: setAnchor }), _jsx(Portal, { children: renderContent({
|
|
39
38
|
setRef: setContent,
|
|
40
39
|
style: {
|
|
41
40
|
position,
|
|
@@ -58,5 +57,3 @@ function getRect(element) {
|
|
|
58
57
|
bottom: top + height,
|
|
59
58
|
};
|
|
60
59
|
}
|
|
61
|
-
|
|
62
|
-
export { Positioner };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './radio.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './radio.js';
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
4
|
+
export const Radio = forwardRef(function Radio({ icon = 'dot', style, className, onChange, onToggle, ...props }, ref) {
|
|
5
|
+
let iconElement;
|
|
6
|
+
switch (icon) {
|
|
7
|
+
case 'check':
|
|
8
|
+
iconElement = _jsx(CheckIcon, { className: "dc-radio__icon", "data-testid": "radio-check-icon" });
|
|
9
|
+
break;
|
|
10
|
+
default:
|
|
11
|
+
iconElement = _jsx(DotIcon, { className: "dc-radio__icon", "data-testid": "radio-dot-icon" });
|
|
12
|
+
}
|
|
13
|
+
return (_jsxs("label", { style: style, className: classNames('dc-radio', className), children: [_jsx("input", { ...props, ref: ref, type: "radio", className: "dc-radio__input", onChange: (event) => {
|
|
14
|
+
onChange?.(event);
|
|
15
|
+
onToggle?.(event.target.checked);
|
|
16
|
+
} }), _jsx("span", { className: "dc-radio__check", "data-testid": "radio-check", "aria-hidden": true, children: iconElement })] }));
|
|
17
|
+
});
|
|
18
|
+
function CheckIcon(props) {
|
|
19
|
+
return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", width: 20, height: 20, ...props, children: _jsx("path", { d: "M5 10.4444L9 14L15 6", fill: "none", stroke: "currentColor", strokeWidth: 2, strokeLinecap: "round", strokeLinejoin: "round" }) }));
|
|
20
|
+
}
|
|
21
|
+
function DotIcon(props) {
|
|
22
|
+
return (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", width: 20, height: 20, ...props, children: _jsx("circle", { cx: 10, cy: 10, r: 4, fill: "currentColor" }) }));
|
|
23
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './segmented-control.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './segmented-control.js';
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
export type SegmentedButtonProps<T extends string | number> = {
|
|
3
|
+
className?: string;
|
|
4
|
+
disabled?: boolean;
|
|
5
|
+
selected: boolean;
|
|
6
|
+
value: T;
|
|
7
|
+
icon?: ReactNode;
|
|
8
|
+
children?: ReactNode;
|
|
9
|
+
onChangeValue: (value: T) => void;
|
|
10
|
+
};
|
|
11
|
+
export declare function SegmentedButton<T extends string | number>({ className, disabled, selected, value, icon, children, onChangeValue, }: SegmentedButtonProps<T>): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
3
|
+
export function SegmentedButton({ className, disabled, selected, value, icon, children, onChangeValue, }) {
|
|
4
|
+
function handleClick() {
|
|
5
|
+
if (!selected) {
|
|
6
|
+
onChangeValue(value);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
return (_jsxs("button", { className: classNames('dc-segmented-button', className), type: "button", value: value, disabled: disabled, "aria-current": selected, onClick: handleClick, children: [icon, children] }));
|
|
10
|
+
}
|
|
@@ -1,15 +1,17 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ComponentPropsWithoutRef, ReactNode } from 'react';
|
|
2
|
+
type SegmentedControlHTMLProps = ComponentPropsWithoutRef<'ul'>;
|
|
3
|
+
export type SegmentedControlSize = 'sm' | 'md' | 'lg';
|
|
2
4
|
export type SegmentedControlOption<T extends string | number> = {
|
|
3
5
|
value: T;
|
|
4
6
|
icon?: ReactNode;
|
|
5
7
|
label?: ReactNode;
|
|
6
8
|
};
|
|
7
|
-
export type SegmentedControlSize = 'sm' | 'md' | 'lg';
|
|
8
9
|
export type SegmentedControlProps<T extends string | number> = {
|
|
9
10
|
size?: SegmentedControlSize;
|
|
10
11
|
disabled?: boolean;
|
|
11
12
|
options: SegmentedControlOption<T>[];
|
|
12
13
|
value: T;
|
|
13
14
|
onChangeValue: (value: T) => void;
|
|
14
|
-
} &
|
|
15
|
+
} & SegmentedControlHTMLProps;
|
|
15
16
|
export declare function SegmentedControl<T extends string | number>({ size, disabled, className, value, options, onChangeValue, ...props }: SegmentedControlProps<T>): import("react/jsx-runtime").JSX.Element;
|
|
17
|
+
export {};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
3
|
+
import { SegmentedButton } from './segmented-button.js';
|
|
4
|
+
export function SegmentedControl({ size = 'md', disabled, className, value, options, onChangeValue, ...props }) {
|
|
5
|
+
return (_jsx("ul", { ...props, className: classNames(className, 'dc-segmented', {
|
|
6
|
+
[`dc-segmented_size_${size}`]: size,
|
|
7
|
+
'dc-segmented_disabled': disabled,
|
|
8
|
+
}), children: options.map((option) => {
|
|
9
|
+
const selected = value === option.value;
|
|
10
|
+
return (_jsx("li", { className: classNames({
|
|
11
|
+
'dc-segmented__item': true,
|
|
12
|
+
'dc-segmented__item_selected': selected,
|
|
13
|
+
}), children: _jsx(SegmentedButton, { icon: option.icon, value: option.value, disabled: disabled, selected: selected, onChangeValue: onChangeValue, children: option.label }) }, option.value));
|
|
14
|
+
}) }));
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './select.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './select.js';
|
|
@@ -2,11 +2,11 @@ import { ComponentPropsWithRef } from 'react';
|
|
|
2
2
|
export type SelectSize = 'sm' | 'md' | 'lg';
|
|
3
3
|
type SelectHTMLProps = ComponentPropsWithRef<'select'>;
|
|
4
4
|
type SelectBaseProps = Omit<SelectHTMLProps, 'size' | 'multiple' | 'value' | 'defaultValue'> & {
|
|
5
|
+
fullWidth?: boolean;
|
|
6
|
+
invalid?: boolean;
|
|
5
7
|
loading?: boolean;
|
|
6
|
-
hasError?: boolean;
|
|
7
|
-
isBlock?: boolean;
|
|
8
8
|
size?: SelectSize;
|
|
9
|
-
|
|
9
|
+
displayedOptionsCount?: number;
|
|
10
10
|
};
|
|
11
11
|
export type SelectProps = SelectBaseProps & ({
|
|
12
12
|
multiple?: false;
|
|
@@ -22,11 +22,11 @@ export type SelectProps = SelectBaseProps & ({
|
|
|
22
22
|
export declare const Select: import("react").ForwardRefExoticComponent<(Omit<Omit<Omit<import("react").DetailedHTMLProps<import("react").SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>, "ref"> & {
|
|
23
23
|
ref?: ((instance: HTMLSelectElement | null) => void) | import("react").RefObject<HTMLSelectElement> | null | undefined;
|
|
24
24
|
}, "defaultValue" | "size" | "value" | "multiple"> & {
|
|
25
|
+
fullWidth?: boolean | undefined;
|
|
26
|
+
invalid?: boolean | undefined;
|
|
25
27
|
loading?: boolean | undefined;
|
|
26
|
-
hasError?: boolean | undefined;
|
|
27
|
-
isBlock?: boolean | undefined;
|
|
28
28
|
size?: SelectSize | undefined;
|
|
29
|
-
|
|
29
|
+
displayedOptionsCount?: number | undefined;
|
|
30
30
|
} & {
|
|
31
31
|
multiple?: false | undefined;
|
|
32
32
|
value?: string | number | undefined;
|
|
@@ -35,11 +35,11 @@ export declare const Select: import("react").ForwardRefExoticComponent<(Omit<Omi
|
|
|
35
35
|
}, "ref"> | Omit<Omit<Omit<import("react").DetailedHTMLProps<import("react").SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>, "ref"> & {
|
|
36
36
|
ref?: ((instance: HTMLSelectElement | null) => void) | import("react").RefObject<HTMLSelectElement> | null | undefined;
|
|
37
37
|
}, "defaultValue" | "size" | "value" | "multiple"> & {
|
|
38
|
+
fullWidth?: boolean | undefined;
|
|
39
|
+
invalid?: boolean | undefined;
|
|
38
40
|
loading?: boolean | undefined;
|
|
39
|
-
hasError?: boolean | undefined;
|
|
40
|
-
isBlock?: boolean | undefined;
|
|
41
41
|
size?: SelectSize | undefined;
|
|
42
|
-
|
|
42
|
+
displayedOptionsCount?: number | undefined;
|
|
43
43
|
} & {
|
|
44
44
|
multiple: true;
|
|
45
45
|
value?: string[] | undefined;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { forwardRef } from 'react';
|
|
3
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
4
|
+
import { Spinner } from '../spinner/index.js';
|
|
5
|
+
export const Select = forwardRef(function Select({ fullWidth, invalid, loading, size = 'md', style, className, disabled, multiple, displayedOptionsCount, children, onChange, onChangeValue, ...props }, ref) {
|
|
6
|
+
const handleChange = (event) => {
|
|
7
|
+
if (typeof onChange === 'function') {
|
|
8
|
+
onChange(event);
|
|
9
|
+
}
|
|
10
|
+
if (typeof onChangeValue === 'function') {
|
|
11
|
+
if (multiple === true) {
|
|
12
|
+
const values = Array.from(event.target.options)
|
|
13
|
+
.filter((option) => option.selected)
|
|
14
|
+
.map((option) => option.value);
|
|
15
|
+
onChangeValue(values);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
onChangeValue(event.target.value);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
let slotElement = (_jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", width: "auto", height: "55%", stroke: "currentColor", strokeWidth: 1.5, fill: "none", children: _jsx("path", { strokeLinecap: "round", strokeLinejoin: "round", d: "M8.25 15L12 18.75 15.75 15m-7.5-6L12 5.25 15.75 9" }) }));
|
|
23
|
+
if (loading) {
|
|
24
|
+
slotElement = (_jsx(Spinner, { color: "currentColor", width: "auto", height: "45%" }));
|
|
25
|
+
}
|
|
26
|
+
return (_jsxs("div", { style: style, className: classNames(className, 'dc-select', {
|
|
27
|
+
[`dc-select_${size}`]: size,
|
|
28
|
+
'dc-select_full-width': fullWidth,
|
|
29
|
+
'dc-select_loading': loading,
|
|
30
|
+
'dc-select_invalid': invalid,
|
|
31
|
+
'dc-select_disabled': disabled,
|
|
32
|
+
'dc-select_multiple': multiple,
|
|
33
|
+
}), children: [_jsx("select", { ...props, ref: ref, className: "dc-select__native", size: displayedOptionsCount, multiple: multiple, disabled: disabled || loading, "aria-invalid": props['aria-invalid'] ?? invalid, onChange: handleChange, children: children }), _jsx("span", { className: "dc-select__slot-left", "aria-hidden": true, children: slotElement })] }));
|
|
34
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './selection-control.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './selection-control.js';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { cloneElement, useId } from 'react';
|
|
3
|
+
import { classNames } from '../../lib/react-helpers.js';
|
|
4
|
+
import { Label } from '../label/index.js';
|
|
5
|
+
import { Caption } from '../caption/index.js';
|
|
6
|
+
export function SelectionControl({ label, labelFor, caption, className, children, ...props }) {
|
|
7
|
+
const defaultId = useId();
|
|
8
|
+
const controlId = labelFor || defaultId;
|
|
9
|
+
return (_jsxs("div", { ...props, className: classNames(className, {
|
|
10
|
+
'dc-selection-control': true,
|
|
11
|
+
'dc-selection-control__with_caption': caption,
|
|
12
|
+
}), children: [_jsx("div", { className: "dc-selection-control__input", children: typeof children === 'function'
|
|
13
|
+
? children({ id: controlId })
|
|
14
|
+
: cloneElement(children, { id: children.props.id || controlId }) }), _jsx(Label, { className: "dc-selection-control__label", htmlFor: controlId, children: label }), caption ? (_jsx(Caption, { className: "dc-selection-control__caption", children: caption })) : null] }));
|
|
15
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { type SlideOverCloseCallback } from './types.js';
|
|
2
|
+
export { SlideOver, type SlideOverProps, type SlideOverRef, } from './slide-over.js';
|
|
3
|
+
export { SlideOverHeader, type SlideOverHeaderProps, } from './slide-over-header.js';
|
|
4
|
+
export { SlideOverBody, type SlideOverBodyProps, } from './slide-over-body.js';
|
|
@@ -1,21 +1,18 @@
|
|
|
1
|
-
import { jsx } from
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { createContext, useContext, useMemo } from 'react';
|
|
3
|
-
|
|
4
3
|
const Context = createContext(null);
|
|
5
|
-
function useSlideOverContext() {
|
|
4
|
+
export function useSlideOverContext() {
|
|
6
5
|
const ctx = useContext(Context);
|
|
7
6
|
if (!ctx) {
|
|
8
7
|
throw new Error('useSlideOverContext must be used within SlideOverContextProvider');
|
|
9
8
|
}
|
|
10
9
|
return ctx;
|
|
11
10
|
}
|
|
12
|
-
function SlideOverContextProvider({ titleId, descriptionId, closePanel, children, }) {
|
|
11
|
+
export function SlideOverContextProvider({ titleId, descriptionId, closePanel, children, }) {
|
|
13
12
|
const ctx = useMemo(() => ({
|
|
14
13
|
titleId,
|
|
15
14
|
descriptionId,
|
|
16
15
|
closePanel,
|
|
17
16
|
}), [titleId, descriptionId, closePanel]);
|
|
18
|
-
return (
|
|
17
|
+
return (_jsx(Context.Provider, { value: ctx, children: children }));
|
|
19
18
|
}
|
|
20
|
-
|
|
21
|
-
export { SlideOverContextProvider, useSlideOverContext };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { classNames } from '../../lib/index.js';
|
|
3
|
+
import { IconButton } from '../button/index.js';
|
|
4
|
+
import { useSlideOverContext } from './slide-over-context.js';
|
|
5
|
+
import { XMarkIcon } from '../hero-icons/24/outline/x-mark-icon.js';
|
|
6
|
+
export function SlideOverHeader({ className, htmlTitle, title, children, description, closeButtonAccessibleName, onClickCloseButton, ...props }) {
|
|
7
|
+
const { titleId, descriptionId, closePanel } = useSlideOverContext();
|
|
8
|
+
const onCloseButtonClicked = (ev) => {
|
|
9
|
+
closePanel('close-button');
|
|
10
|
+
onClickCloseButton?.(ev);
|
|
11
|
+
};
|
|
12
|
+
return (_jsxs("div", { className: classNames('dc-slide-over-header', className), title: htmlTitle, ...props, children: [_jsxs("div", { className: "dc-slide-over-header__title", children: [_jsx("h2", { id: titleId, children: title }), _jsx(IconButton, { buttonStyle: "tinted", size: "xs", "aria-label": closeButtonAccessibleName, onClick: onCloseButtonClicked, children: _jsx(XMarkIcon, { width: 20, height: 20 }) })] }), description ? (_jsx("div", { id: descriptionId, className: "dc-slide-over-header__description", children: description })) : null, children ? (_jsx("div", { className: "dc-slide-over-header__content", children: children })) : null] }));
|
|
13
|
+
}
|