@lumx/react 4.17.1-alpha.2 → 4.17.1-alpha.3
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/_internal/_virtual/_rolldown/runtime.js +34 -0
- package/_internal/components/alert-dialog/AlertDialog.d.ts +30 -0
- package/_internal/components/alert-dialog/AlertDialog.js +49 -0
- package/_internal/components/alert-dialog/index.d.ts +1 -0
- package/_internal/components/autocomplete/Autocomplete.d.ts +181 -0
- package/_internal/components/autocomplete/Autocomplete.js +92 -0
- package/_internal/components/autocomplete/AutocompleteMultiple.d.ts +28 -0
- package/_internal/components/autocomplete/AutocompleteMultiple.js +95 -0
- package/_internal/components/autocomplete/index.d.ts +2 -0
- package/_internal/components/avatar/Avatar.d.ts +39 -0
- package/_internal/components/avatar/Avatar.js +46 -0
- package/_internal/components/avatar/index.d.ts +2 -0
- package/_internal/components/badge/Badge.d.ts +24 -0
- package/_internal/components/badge/Badge.js +21 -0
- package/_internal/components/badge/BadgeWrapper.d.ts +16 -0
- package/_internal/components/badge/BadgeWrapper.js +13 -0
- package/_internal/components/badge/index.d.ts +2 -0
- package/_internal/components/button/Button.d.ts +22 -0
- package/_internal/components/button/Button.js +49 -0
- package/_internal/components/button/ButtonGroup.d.ts +17 -0
- package/_internal/components/button/ButtonGroup.js +21 -0
- package/_internal/components/button/ButtonRoot.d.ts +1 -0
- package/_internal/components/button/IconButton.d.ts +30 -0
- package/_internal/components/button/IconButton.js +40 -0
- package/_internal/components/button/index.d.ts +5 -0
- package/_internal/components/checkbox/Checkbox.d.ts +24 -0
- package/_internal/components/checkbox/Checkbox.js +58 -0
- package/_internal/components/checkbox/index.d.ts +1 -0
- package/_internal/components/chip/Chip.d.ts +34 -0
- package/_internal/components/chip/Chip.js +43 -0
- package/_internal/components/chip/ChipGroup.d.ts +20 -0
- package/_internal/components/chip/ChipGroup.js +25 -0
- package/_internal/components/chip/SelectionChipGroup.d.ts +43 -0
- package/_internal/components/chip/SelectionChipGroup.js +78 -0
- package/_internal/components/chip/index.d.ts +3 -0
- package/_internal/components/combobox/ComboboxButton.d.ts +17 -0
- package/_internal/components/combobox/ComboboxButton.js +59 -0
- package/_internal/components/combobox/ComboboxInput.d.ts +19 -0
- package/_internal/components/combobox/ComboboxInput.js +79 -0
- package/_internal/components/combobox/ComboboxList.d.ts +8 -0
- package/_internal/components/combobox/ComboboxList.js +64 -0
- package/_internal/components/combobox/ComboboxOption.d.ts +36 -0
- package/_internal/components/combobox/ComboboxOption.js +76 -0
- package/_internal/components/combobox/ComboboxOptionAction.d.ts +18 -0
- package/_internal/components/combobox/ComboboxOptionAction.js +38 -0
- package/_internal/components/combobox/ComboboxOptionMoreInfo.d.ts +19 -0
- package/_internal/components/combobox/ComboboxOptionMoreInfo.js +49 -0
- package/_internal/components/combobox/ComboboxOptionSkeleton.d.ts +19 -0
- package/_internal/components/combobox/ComboboxOptionSkeleton.js +38 -0
- package/_internal/components/combobox/ComboboxPopover.d.ts +18 -0
- package/_internal/components/combobox/ComboboxPopover.js +32 -0
- package/_internal/components/combobox/ComboboxProvider.d.ts +27 -0
- package/_internal/components/combobox/ComboboxProvider.js +41 -0
- package/_internal/components/combobox/ComboboxSection.d.ts +15 -0
- package/_internal/components/combobox/ComboboxSection.js +47 -0
- package/_internal/components/combobox/ComboboxState.d.ts +14 -0
- package/_internal/components/combobox/ComboboxState.js +70 -0
- package/_internal/components/combobox/context/ComboboxContext.js +15 -0
- package/_internal/components/combobox/context/ComboboxListContext.js +12 -0
- package/_internal/components/combobox/context/ComboboxOptionContext.js +16 -0
- package/_internal/components/combobox/context/useComboboxEvent.d.ts +10 -0
- package/_internal/components/combobox/context/useComboboxEvent.js +17 -0
- package/_internal/components/combobox/context/useComboboxOpen.js +13 -0
- package/_internal/components/combobox/index.d.ts +73 -0
- package/_internal/components/combobox/index.js +47 -0
- package/_internal/components/combobox/wrapRenderOption.js +38 -0
- package/_internal/components/comment-block/CommentBlock.d.ts +68 -0
- package/_internal/components/comment-block/CommentBlock.js +109 -0
- package/_internal/components/comment-block/index.d.ts +1 -0
- package/_internal/components/date-picker/DatePicker.d.ts +14 -0
- package/_internal/components/date-picker/DatePicker.js +45 -0
- package/_internal/components/date-picker/DatePickerControlled.d.ts +26 -0
- package/_internal/components/date-picker/DatePickerControlled.js +177 -0
- package/_internal/components/date-picker/DatePickerField.d.ts +38 -0
- package/_internal/components/date-picker/DatePickerField.js +83 -0
- package/_internal/components/date-picker/constants.js +11 -0
- package/_internal/components/date-picker/index.d.ts +4 -0
- package/_internal/components/date-picker/types.d.ts +30 -0
- package/_internal/components/dialog/Dialog.d.ts +47 -0
- package/_internal/components/dialog/Dialog.js +110 -0
- package/_internal/components/dialog/index.d.ts +2 -0
- package/_internal/components/divider/Divider.d.ts +20 -0
- package/_internal/components/divider/Divider.js +30 -0
- package/_internal/components/divider/index.d.ts +1 -0
- package/_internal/components/drag-handle/DragHandle.d.ts +20 -0
- package/_internal/components/drag-handle/DragHandle.js +29 -0
- package/_internal/components/drag-handle/index.d.ts +1 -0
- package/_internal/components/dropdown/Dropdown.d.ts +89 -0
- package/_internal/components/dropdown/Dropdown.js +89 -0
- package/_internal/components/dropdown/index.d.ts +1 -0
- package/_internal/components/expansion-panel/ExpansionPanel.d.ts +31 -0
- package/_internal/components/expansion-panel/ExpansionPanel.js +80 -0
- package/_internal/components/expansion-panel/index.d.ts +1 -0
- package/_internal/components/flag/Flag.d.ts +20 -0
- package/_internal/components/flag/Flag.js +28 -0
- package/_internal/components/flag/index.d.ts +1 -0
- package/_internal/components/flex-box/FlexBox.d.ts +25 -0
- package/_internal/components/flex-box/FlexBox.js +24 -0
- package/_internal/components/flex-box/index.d.ts +2 -0
- package/_internal/components/generic-block/GenericBlock.d.ts +51 -0
- package/_internal/components/generic-block/GenericBlock.js +90 -0
- package/_internal/components/generic-block/index.d.ts +2 -0
- package/_internal/components/grid/Grid.d.ts +33 -0
- package/_internal/components/grid/Grid.js +48 -0
- package/_internal/components/grid/GridItem.d.ts +29 -0
- package/_internal/components/grid/GridItem.js +37 -0
- package/_internal/components/grid/index.d.ts +2 -0
- package/_internal/components/grid-column/GridColumn.d.ts +24 -0
- package/_internal/components/grid-column/GridColumn.js +27 -0
- package/_internal/components/grid-column/index.d.ts +2 -0
- package/_internal/components/heading/Heading.d.ts +14 -0
- package/_internal/components/heading/Heading.js +25 -0
- package/_internal/components/heading/HeadingLevelProvider.d.ts +15 -0
- package/_internal/components/heading/HeadingLevelProvider.js +22 -0
- package/_internal/components/heading/context.js +6 -0
- package/_internal/components/heading/index.d.ts +3 -0
- package/_internal/components/heading/useHeadingLevel.d.ts +7 -0
- package/_internal/components/heading/useHeadingLevel.js +12 -0
- package/_internal/components/icon/Icon.d.ts +17 -0
- package/_internal/components/icon/Icon.js +24 -0
- package/_internal/components/icon/index.d.ts +2 -0
- package/_internal/components/image-block/ImageBlock.d.ts +29 -0
- package/_internal/components/image-block/ImageBlock.js +30 -0
- package/_internal/components/image-block/ImageCaption.d.ts +13 -0
- package/_internal/components/image-block/ImageCaption.js +18 -0
- package/_internal/components/image-block/index.d.ts +2 -0
- package/_internal/components/image-lightbox/ImageLightbox.d.ts +17 -0
- package/_internal/components/image-lightbox/ImageLightbox.js +66 -0
- package/_internal/components/image-lightbox/constants.js +11 -0
- package/_internal/components/image-lightbox/index.d.ts +2 -0
- package/_internal/components/image-lightbox/internal/ImageSlide.js +81 -0
- package/_internal/components/image-lightbox/internal/ImageSlideshow.js +112 -0
- package/_internal/components/image-lightbox/internal/useAnimateScroll.js +40 -0
- package/_internal/components/image-lightbox/internal/usePointerZoom.js +98 -0
- package/_internal/components/image-lightbox/types.d.ts +33 -0
- package/_internal/components/image-lightbox/useImageLightbox.d.ts +29 -0
- package/_internal/components/image-lightbox/useImageLightbox.js +102 -0
- package/_internal/components/inline-list/InlineList.d.ts +25 -0
- package/_internal/components/inline-list/InlineList.js +24 -0
- package/_internal/components/inline-list/index.d.ts +1 -0
- package/_internal/components/input-helper/InputHelper.d.ts +17 -0
- package/_internal/components/input-helper/InputHelper.js +25 -0
- package/_internal/components/input-helper/index.d.ts +1 -0
- package/_internal/components/input-label/InputLabel.d.ts +17 -0
- package/_internal/components/input-label/InputLabel.js +25 -0
- package/_internal/components/input-label/index.d.ts +1 -0
- package/_internal/components/lightbox/Lightbox.d.ts +33 -0
- package/_internal/components/lightbox/Lightbox.js +69 -0
- package/_internal/components/lightbox/index.d.ts +1 -0
- package/_internal/components/link/Link.d.ts +35 -0
- package/_internal/components/link/Link.js +45 -0
- package/_internal/components/link/index.d.ts +1 -0
- package/_internal/components/link-preview/LinkPreview.d.ts +25 -0
- package/_internal/components/link-preview/LinkPreview.js +31 -0
- package/_internal/components/link-preview/index.d.ts +1 -0
- package/_internal/components/list/List.d.ts +27 -0
- package/_internal/components/list/List.js +28 -0
- package/_internal/components/list/ListDivider.d.ts +21 -0
- package/_internal/components/list/ListDivider.js +22 -0
- package/_internal/components/list/ListItem.d.ts +47 -0
- package/_internal/components/list/ListItem.js +39 -0
- package/_internal/components/list/ListItemAction.js +30 -0
- package/_internal/components/list/ListSection.d.ts +24 -0
- package/_internal/components/list/ListSection.js +26 -0
- package/_internal/components/list/ListSubheader.d.ts +23 -0
- package/_internal/components/list/ListSubheader.js +33 -0
- package/_internal/components/list/index.d.ts +6 -0
- package/_internal/components/menu-button/MenuButton.d.ts +34 -0
- package/_internal/components/menu-button/MenuButton.js +48 -0
- package/_internal/components/menu-button/MenuItem.d.ts +46 -0
- package/_internal/components/menu-button/MenuItem.js +62 -0
- package/_internal/components/menu-button/MenuList.js +39 -0
- package/_internal/components/menu-button/MenuPopover.d.ts +13 -0
- package/_internal/components/menu-button/MenuPopover.js +31 -0
- package/_internal/components/menu-button/MenuProvider.js +45 -0
- package/_internal/components/menu-button/MenuTrigger.js +40 -0
- package/_internal/components/menu-button/context/MenuContext.js +11 -0
- package/_internal/components/menu-button/context/useMenuEvent.js +21 -0
- package/_internal/components/menu-button/context/useMenuOpen.js +15 -0
- package/_internal/components/menu-button/index.d.ts +3 -0
- package/_internal/components/message/Message.d.ts +17 -0
- package/_internal/components/message/Message.js +20 -0
- package/_internal/components/message/index.d.ts +1 -0
- package/_internal/components/mosaic/Mosaic.d.ts +25 -0
- package/_internal/components/mosaic/Mosaic.js +29 -0
- package/_internal/components/mosaic/index.d.ts +1 -0
- package/_internal/components/navigation/Navigation.d.ts +18 -0
- package/_internal/components/navigation/Navigation.js +51 -0
- package/_internal/components/navigation/NavigationItem.d.ts +23 -0
- package/_internal/components/navigation/NavigationItem.js +52 -0
- package/_internal/components/navigation/NavigationSection.d.ts +15 -0
- package/_internal/components/navigation/NavigationSection.js +100 -0
- package/_internal/components/navigation/constants.js +11 -0
- package/_internal/components/navigation/context.js +6 -0
- package/_internal/components/navigation/index.d.ts +1 -0
- package/_internal/components/notification/Notification.d.ts +36 -0
- package/_internal/components/notification/Notification.js +97 -0
- package/_internal/components/notification/constants.js +28 -0
- package/_internal/components/notification/index.d.ts +1 -0
- package/_internal/components/popover/Popover.d.ts +43 -0
- package/_internal/components/popover/Popover.js +86 -0
- package/_internal/components/popover/index.d.ts +3 -0
- package/_internal/components/popover/usePopoverStyle.js +82 -0
- package/_internal/components/popover-dialog/PopoverDialog.d.ts +22 -0
- package/_internal/components/popover-dialog/PopoverDialog.js +42 -0
- package/_internal/components/popover-dialog/index.d.ts +1 -0
- package/_internal/components/post-block/PostBlock.d.ts +44 -0
- package/_internal/components/post-block/PostBlock.js +92 -0
- package/_internal/components/post-block/index.d.ts +1 -0
- package/_internal/components/progress/Progress.d.ts +30 -0
- package/_internal/components/progress/Progress.js +54 -0
- package/_internal/components/progress/ProgressCircular.d.ts +20 -0
- package/_internal/components/progress/ProgressCircular.js +31 -0
- package/_internal/components/progress/ProgressLinear.d.ts +20 -0
- package/_internal/components/progress/ProgressLinear.js +26 -0
- package/_internal/components/progress/index.d.ts +4 -0
- package/_internal/components/progress-tracker/ProgressTracker.d.ts +26 -0
- package/_internal/components/progress-tracker/ProgressTracker.js +75 -0
- package/_internal/components/progress-tracker/ProgressTrackerProvider.d.ts +29 -0
- package/_internal/components/progress-tracker/ProgressTrackerProvider.js +45 -0
- package/_internal/components/progress-tracker/ProgressTrackerStep.d.ts +37 -0
- package/_internal/components/progress-tracker/ProgressTrackerStep.js +107 -0
- package/_internal/components/progress-tracker/ProgressTrackerStepPanel.d.ts +27 -0
- package/_internal/components/progress-tracker/ProgressTrackerStepPanel.js +47 -0
- package/_internal/components/progress-tracker/index.d.ts +4 -0
- package/_internal/components/radio-button/RadioButton.d.ts +23 -0
- package/_internal/components/radio-button/RadioButton.js +50 -0
- package/_internal/components/radio-button/RadioGroup.d.ts +20 -0
- package/_internal/components/radio-button/RadioGroup.js +23 -0
- package/_internal/components/radio-button/index.d.ts +2 -0
- package/_internal/components/select/Select.d.ts +20 -0
- package/_internal/components/select/Select.js +130 -0
- package/_internal/components/select/SelectMultiple.d.ts +24 -0
- package/_internal/components/select/SelectMultiple.js +128 -0
- package/_internal/components/select/WithSelectContext.js +96 -0
- package/_internal/components/select/constants.d.ts +59 -0
- package/_internal/components/select/constants.js +10 -0
- package/_internal/components/select/index.d.ts +3 -0
- package/_internal/components/select-button/SelectButton.d.ts +93 -0
- package/_internal/components/select-button/SelectButton.js +73 -0
- package/_internal/components/select-button/index.d.ts +18 -0
- package/_internal/components/select-button/index.js +11 -0
- package/_internal/components/select-text-field/SelectTextField.d.ts +80 -0
- package/_internal/components/select-text-field/SelectTextField.js +167 -0
- package/_internal/components/select-text-field/index.d.ts +33 -0
- package/_internal/components/select-text-field/index.js +24 -0
- package/_internal/components/side-navigation/SideNavigation.d.ts +22 -0
- package/_internal/components/side-navigation/SideNavigation.js +39 -0
- package/_internal/components/side-navigation/SideNavigationItem.d.ts +44 -0
- package/_internal/components/side-navigation/SideNavigationItem.js +111 -0
- package/_internal/components/side-navigation/index.d.ts +2 -0
- package/_internal/components/skeleton/SkeletonCircle.d.ts +19 -0
- package/_internal/components/skeleton/SkeletonCircle.js +30 -0
- package/_internal/components/skeleton/SkeletonRectangle.d.ts +19 -0
- package/_internal/components/skeleton/SkeletonRectangle.js +33 -0
- package/_internal/components/skeleton/SkeletonTypography.d.ts +19 -0
- package/_internal/components/skeleton/SkeletonTypography.js +31 -0
- package/_internal/components/skeleton/index.d.ts +4 -0
- package/_internal/components/slider/Slider.d.ts +44 -0
- package/_internal/components/slider/Slider.js +232 -0
- package/_internal/components/slider/index.d.ts +2 -0
- package/_internal/components/slideshow/Slides.d.ts +49 -0
- package/_internal/components/slideshow/Slides.js +86 -0
- package/_internal/components/slideshow/Slideshow.d.ts +35 -0
- package/_internal/components/slideshow/Slideshow.js +104 -0
- package/_internal/components/slideshow/SlideshowControls.d.ts +65 -0
- package/_internal/components/slideshow/SlideshowControls.js +139 -0
- package/_internal/components/slideshow/SlideshowItem.d.ts +23 -0
- package/_internal/components/slideshow/SlideshowItem.js +32 -0
- package/_internal/components/slideshow/SlideshowItemGroup.js +44 -0
- package/_internal/components/slideshow/constants.d.ts +13 -0
- package/_internal/components/slideshow/constants.js +16 -0
- package/_internal/components/slideshow/index.d.ts +4 -0
- package/_internal/components/slideshow/usePaginationVisibleRange.js +41 -0
- package/_internal/components/slideshow/useSlideFocusManagement.js +64 -0
- package/_internal/components/slideshow/useSlideScroll.js +57 -0
- package/_internal/components/slideshow/useSwipeNavigate.js +21 -0
- package/_internal/components/switch/Switch.d.ts +24 -0
- package/_internal/components/switch/Switch.js +54 -0
- package/_internal/components/switch/index.d.ts +1 -0
- package/_internal/components/table/Table.d.ts +20 -0
- package/_internal/components/table/Table.js +28 -0
- package/_internal/components/table/TableBody.d.ts +20 -0
- package/_internal/components/table/TableBody.js +22 -0
- package/_internal/components/table/TableCell.d.ts +23 -0
- package/_internal/components/table/TableCell.js +23 -0
- package/_internal/components/table/TableHeader.d.ts +20 -0
- package/_internal/components/table/TableHeader.js +23 -0
- package/_internal/components/table/TableRow.d.ts +23 -0
- package/_internal/components/table/TableRow.js +28 -0
- package/_internal/components/table/index.d.ts +6 -0
- package/_internal/components/tabs/Tab.d.ts +39 -0
- package/_internal/components/tabs/Tab.js +39 -0
- package/_internal/components/tabs/TabList.d.ts +22 -0
- package/_internal/components/tabs/TabList.js +37 -0
- package/_internal/components/tabs/TabPanel.d.ts +25 -0
- package/_internal/components/tabs/TabPanel.js +30 -0
- package/_internal/components/tabs/TabProvider.d.ts +27 -0
- package/_internal/components/tabs/TabProvider.js +51 -0
- package/_internal/components/tabs/index.d.ts +5 -0
- package/_internal/components/tabs/state.js +55 -0
- package/_internal/components/text/Text.d.ts +17 -0
- package/_internal/components/text/Text.js +33 -0
- package/_internal/components/text/index.d.ts +1 -0
- package/_internal/components/text-field/RawInputText.d.ts +20 -0
- package/_internal/components/text-field/RawInputText.js +23 -0
- package/_internal/components/text-field/RawInputTextarea.d.ts +21 -0
- package/_internal/components/text-field/RawInputTextarea.js +34 -0
- package/_internal/components/text-field/TextField.d.ts +46 -0
- package/_internal/components/text-field/TextField.js +122 -0
- package/_internal/components/text-field/index.d.ts +3 -0
- package/_internal/components/text-field/useFitRowsToContent.js +27 -0
- package/_internal/components/thumbnail/Thumbnail.d.ts +31 -0
- package/_internal/components/thumbnail/Thumbnail.js +45 -0
- package/_internal/components/thumbnail/index.d.ts +3 -0
- package/_internal/components/thumbnail/types.d.ts +49 -0
- package/_internal/components/thumbnail/types.js +23 -0
- package/_internal/components/thumbnail/useFocusPointStyle.d.ts +15 -0
- package/_internal/components/thumbnail/useFocusPointStyle.js +53 -0
- package/_internal/components/thumbnail/useImageLoad.js +23 -0
- package/_internal/components/time-picker-field/TimePickerField.d.ts +38 -0
- package/_internal/components/time-picker-field/TimePickerField.js +103 -0
- package/_internal/components/time-picker-field/index.d.ts +2 -0
- package/_internal/components/toolbar/Toolbar.d.ts +28 -0
- package/_internal/components/toolbar/Toolbar.js +21 -0
- package/_internal/components/toolbar/index.d.ts +1 -0
- package/_internal/components/tooltip/Tooltip.d.ts +23 -0
- package/_internal/components/tooltip/Tooltip.js +69 -0
- package/_internal/components/tooltip/context.js +15 -0
- package/_internal/components/tooltip/index.d.ts +2 -0
- package/_internal/components/tooltip/useInjectTooltipRef.js +43 -0
- package/_internal/components/tooltip/useTooltipOpen.js +36 -0
- package/_internal/components/uploader/Uploader.d.ts +29 -0
- package/_internal/components/uploader/Uploader.js +71 -0
- package/_internal/components/uploader/index.d.ts +2 -0
- package/_internal/components/user-block/UserBlock.d.ts +33 -0
- package/_internal/components/user-block/UserBlock.js +88 -0
- package/_internal/components/user-block/index.d.ts +2 -0
- package/_internal/constants.js +2 -0
- package/_internal/hooks/useBooleanState.js +13 -0
- package/_internal/hooks/useCallbackOnEscape.js +30 -0
- package/_internal/hooks/useChipGroupNavigation.d.ts +12 -0
- package/_internal/hooks/useChipGroupNavigation.js +49 -0
- package/_internal/hooks/useClickAway.d.ts +16 -0
- package/_internal/hooks/useClickAway.js +20 -0
- package/_internal/hooks/useDisableBodyScroll.js +25 -0
- package/_internal/hooks/useEventCallback.js +21 -0
- package/_internal/hooks/useFocus.js +19 -0
- package/_internal/hooks/useFocusTrap.js +28 -0
- package/_internal/hooks/useFocusWithin.js +27 -0
- package/_internal/hooks/useId.js +16 -0
- package/_internal/hooks/useImageSize.js +19 -0
- package/_internal/hooks/useInfiniteScroll.js +36 -0
- package/_internal/hooks/useIntersectionObserver.js +24 -0
- package/_internal/hooks/useInterval.js +26 -0
- package/_internal/hooks/useIsomorphicLayoutEffect.js +9 -0
- package/_internal/hooks/useKeyboardListNavigation.d.ts +17 -0
- package/_internal/hooks/useKeyboardListNavigation.js +136 -0
- package/_internal/hooks/useListenFocus.js +23 -0
- package/_internal/hooks/useOverflowTooltipLabel.js +27 -0
- package/_internal/hooks/usePreviousValue.js +15 -0
- package/_internal/hooks/useRestoreFocusOnClose.js +47 -0
- package/_internal/hooks/useRovingTabIndexContainer.js +31 -0
- package/_internal/hooks/useSizeOnWindowResize.js +26 -0
- package/_internal/hooks/useSlideshowControls.d.ts +63 -0
- package/_internal/hooks/useSlideshowControls.js +105 -0
- package/_internal/hooks/useStopPropagation.js +18 -0
- package/_internal/hooks/useTransitionVisibility.js +41 -0
- package/_internal/node_modules/@floating-ui/core/dist/floating-ui.core.js +536 -0
- package/_internal/node_modules/@floating-ui/dom/dist/floating-ui.dom.js +528 -0
- package/_internal/node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js +209 -0
- package/_internal/node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.js +144 -0
- package/_internal/node_modules/@floating-ui/utils/dist/floating-ui.utils.js +135 -0
- package/_internal/node_modules/body-scroll-lock/lib/bodyScrollLock.esm.js +114 -0
- package/_internal/node_modules/classnames/index.js +45 -0
- package/_internal/packages/lumx-core/src/js/components/AlertDialog/index.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/AlertDialog/index.js +116 -0
- package/_internal/packages/lumx-core/src/js/components/Avatar/index.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/Avatar/index.js +49 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/BadgeWrapper.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/BadgeWrapper.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/index.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Badge/index.js +38 -0
- package/_internal/packages/lumx-core/src/js/components/Button/Button.d.ts +41 -0
- package/_internal/packages/lumx-core/src/js/components/Button/Button.js +46 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonGroup.d.ts +17 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonGroup.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonRoot.d.ts +46 -0
- package/_internal/packages/lumx-core/src/js/components/Button/ButtonRoot.js +75 -0
- package/_internal/packages/lumx-core/src/js/components/Button/IconButton.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Button/IconButton.js +46 -0
- package/_internal/packages/lumx-core/src/js/components/Checkbox/index.d.ts +35 -0
- package/_internal/packages/lumx-core/src/js/components/Checkbox/index.js +83 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/ChipGroup.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/ChipGroup.js +32 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/SelectionChipGroup.d.ts +29 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/SelectionChipGroup.js +66 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/index.d.ts +63 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/index.js +78 -0
- package/_internal/packages/lumx-core/src/js/components/Chip/setupSelectionChipGroupEvents.js +97 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxButton.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxButton.js +51 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxInput.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxInput.js +56 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxList.d.ts +36 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxList.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOption.d.ts +53 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOption.js +73 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionAction.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionMoreInfo.d.ts +29 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionMoreInfo.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionSkeleton.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxOptionSkeleton.js +44 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxPopover.js +47 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxSection.d.ts +36 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxSection.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxState.d.ts +64 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/ComboboxState.js +86 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/constants.js +4 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupCombobox.js +350 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupComboboxButton.js +84 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupComboboxInput.js +95 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/setupListbox.js +84 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/subscribeComboboxState.js +43 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/types.d.ts +59 -0
- package/_internal/packages/lumx-core/src/js/components/Combobox/utils.js +63 -0
- package/_internal/packages/lumx-core/src/js/components/Dialog/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/Dialog/index.js +93 -0
- package/_internal/packages/lumx-core/src/js/components/Divider/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/Divider/index.js +29 -0
- package/_internal/packages/lumx-core/src/js/components/DragHandle/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/DragHandle/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/ExpansionPanel/index.d.ts +51 -0
- package/_internal/packages/lumx-core/src/js/components/ExpansionPanel/index.js +92 -0
- package/_internal/packages/lumx-core/src/js/components/Flag/index.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Flag/index.js +41 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/index.js +39 -0
- package/_internal/packages/lumx-core/src/js/components/FlexBox/types.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/constants.d.ts +22 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/constants.js +15 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/index.d.ts +66 -0
- package/_internal/packages/lumx-core/src/js/components/GenericBlock/index.js +63 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/GridColumn.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/GridColumn.js +44 -0
- package/_internal/packages/lumx-core/src/js/components/GridColumn/index.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/constants.js +19 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/index.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/index.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/Heading/utils.js +14 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/constants.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Icon/index.js +66 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/ImageCaption.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/ImageCaption.js +61 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/index.d.ts +52 -0
- package/_internal/packages/lumx-core/src/js/components/ImageBlock/index.js +80 -0
- package/_internal/packages/lumx-core/src/js/components/InlineList/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/InlineList/index.js +48 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/constants.js +9 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/index.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/InputHelper/index.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/InputLabel/index.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/InputLabel/index.js +31 -0
- package/_internal/packages/lumx-core/src/js/components/Lightbox/index.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/components/Lightbox/index.js +70 -0
- package/_internal/packages/lumx-core/src/js/components/Link/index.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Link/index.js +40 -0
- package/_internal/packages/lumx-core/src/js/components/LinkPreview/index.d.ts +36 -0
- package/_internal/packages/lumx-core/src/js/components/LinkPreview/index.js +94 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListDivider.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListDivider.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItem.d.ts +41 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItem.js +66 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItemAction.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListItemAction.js +36 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListSection.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/List/ListSection.js +51 -0
- package/_internal/packages/lumx-core/src/js/components/List/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/List/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuButton.d.ts +28 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuButton.js +29 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuItem.d.ts +30 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuItem.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuList.js +20 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuPopover.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuPopover.js +32 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/MenuTrigger.js +20 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/setupMenu.js +256 -0
- package/_internal/packages/lumx-core/src/js/components/Menu/utils.js +16 -0
- package/_internal/packages/lumx-core/src/js/components/Message/index.d.ts +31 -0
- package/_internal/packages/lumx-core/src/js/components/Message/index.js +85 -0
- package/_internal/packages/lumx-core/src/js/components/Mosaic/index.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Mosaic/index.js +70 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/constants.d.ts +39 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/constants.js +37 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/index.d.ts +65 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/index.js +74 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/types.d.ts +39 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/buildPopoverMiddleware.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/computeArrowStyles.js +13 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/getFloatingPlacement.js +10 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/parseAutoPlacement.js +21 -0
- package/_internal/packages/lumx-core/src/js/components/Popover/utils/parseFitWidth.js +12 -0
- package/_internal/packages/lumx-core/src/js/components/PopoverDialog/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/PopoverDialog/index.js +15 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressCircular/index.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressCircular/index.js +57 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressLinear/index.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/components/ProgressLinear/index.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/RadioButton/index.d.ts +35 -0
- package/_internal/packages/lumx-core/src/js/components/RadioButton/index.js +71 -0
- package/_internal/packages/lumx-core/src/js/components/RadioGroup/index.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/RadioGroup/index.js +35 -0
- package/_internal/packages/lumx-core/src/js/components/RawClickable/index.d.ts +17 -0
- package/_internal/packages/lumx-core/src/js/components/RawClickable/index.js +34 -0
- package/_internal/packages/lumx-core/src/js/components/SelectButton/index.d.ts +58 -0
- package/_internal/packages/lumx-core/src/js/components/SelectButton/index.js +85 -0
- package/_internal/packages/lumx-core/src/js/components/SelectTextField/index.js +78 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonCircle.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonCircle.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonRectangle.d.ts +34 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonRectangle.js +49 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonTypography.d.ts +24 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/SkeletonTypography.js +38 -0
- package/_internal/packages/lumx-core/src/js/components/Skeleton/index.d.ts +3 -0
- package/_internal/packages/lumx-core/src/js/components/Switch/index.d.ts +37 -0
- package/_internal/packages/lumx-core/src/js/components/Switch/index.js +78 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableBody.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableBody.js +29 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableCell.d.ts +42 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableCell.js +101 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableHeader.d.ts +15 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableHeader.js +33 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableRow.d.ts +22 -0
- package/_internal/packages/lumx-core/src/js/components/Table/TableRow.js +42 -0
- package/_internal/packages/lumx-core/src/js/components/Table/constants.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Table/constants.js +11 -0
- package/_internal/packages/lumx-core/src/js/components/Table/index.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/components/Table/index.js +31 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/Tab.d.ts +54 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/Tab.js +69 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabList.d.ts +27 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabList.js +52 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabPanel.d.ts +26 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/TabPanel.js +41 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/constants.js +7 -0
- package/_internal/packages/lumx-core/src/js/components/Tabs/state.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Text/index.d.ts +55 -0
- package/_internal/packages/lumx-core/src/js/components/Text/index.js +50 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputText.d.ts +21 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputText.js +40 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputTextarea.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/RawInputTextarea.js +40 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/TextField.d.ts +70 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/TextField.js +143 -0
- package/_internal/packages/lumx-core/src/js/components/TextField/constants.js +15 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/index.d.ts +60 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/index.js +114 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/types.d.ts +39 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/utils.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/components/Thumbnail/utils.js +76 -0
- package/_internal/packages/lumx-core/src/js/components/TimePickerField/index.d.ts +70 -0
- package/_internal/packages/lumx-core/src/js/components/TimePickerField/index.js +53 -0
- package/_internal/packages/lumx-core/src/js/components/Toolbar/index.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/components/Toolbar/index.js +51 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/constants.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/constants.js +8 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/index.d.ts +25 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/index.js +55 -0
- package/_internal/packages/lumx-core/src/js/components/Tooltip/tooltipOpenManager.js +93 -0
- package/_internal/packages/lumx-core/src/js/components/Uploader/index.d.ts +59 -0
- package/_internal/packages/lumx-core/src/js/components/Uploader/index.js +79 -0
- package/_internal/packages/lumx-core/src/js/components/UserBlock/index.d.ts +124 -0
- package/_internal/packages/lumx-core/src/js/components/UserBlock/index.js +101 -0
- package/_internal/packages/lumx-core/src/js/constants/browser/index.js +7 -0
- package/_internal/packages/lumx-core/src/js/constants/components/index.js +19 -0
- package/_internal/packages/lumx-core/src/js/constants/enums/index.d.ts +184 -0
- package/_internal/packages/lumx-core/src/js/constants/enums/index.js +140 -0
- package/_internal/packages/lumx-core/src/js/constants/index.d.ts +1 -0
- package/_internal/packages/lumx-core/src/js/types/AriaAttributes.d.ts +32 -0
- package/_internal/packages/lumx-core/src/js/types/Booleanish.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/types/CommonRef.d.ts +4 -0
- package/_internal/packages/lumx-core/src/js/types/GenericProps.d.ts +14 -0
- package/_internal/packages/lumx-core/src/js/types/HasAriaDisabled.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasAriaLabelOrLabelledBy.d.ts +19 -0
- package/_internal/packages/lumx-core/src/js/types/HasChecked.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasClassName.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasCloseMode.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/types/HasDisabled.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/types/HasPolymorphicAs.d.ts +12 -0
- package/_internal/packages/lumx-core/src/js/types/HasRequiredLinkHref.d.ts +6 -0
- package/_internal/packages/lumx-core/src/js/types/HasTheme.d.ts +10 -0
- package/_internal/packages/lumx-core/src/js/types/HeadingElement.d.ts +5 -0
- package/_internal/packages/lumx-core/src/js/types/JSXElement.d.ts +13 -0
- package/_internal/packages/lumx-core/src/js/types/KebabCase.d.ts +5 -0
- package/_internal/packages/lumx-core/src/js/types/LumxClassName.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/types/Selector.d.ts +11 -0
- package/_internal/packages/lumx-core/src/js/types/TextElement.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/types/ValueOf.d.ts +5 -0
- package/_internal/packages/lumx-core/src/js/types/index.d.ts +18 -0
- package/_internal/packages/lumx-core/src/js/utils/ClickAway/index.js +37 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/index.d.ts +9 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/index.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/InfiniteScroll/setupInfiniteScrollObserver.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/Portal/index.d.ts +28 -0
- package/_internal/packages/lumx-core/src/js/utils/_internal/color/resolveColorWithVariants.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/createSelectorTreeWalker.js +20 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/combineSize.js +14 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/resolveCssSize.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/css/types.d.ts +7 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isFocusVisible.js +11 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isHoverNotSupported.js +5 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/isPrintableKey.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/lastDescendant.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/querySelectorInclusive.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/browser/trackContainerFocus.js +28 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/action-area/index.js +22 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/block.js +18 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/element.js +7 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/index.js +22 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/bem/modifier.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/color/index.js +38 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/index.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/spacing/index.js +31 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/typography/index.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/classNames/visually-hidden/index.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/disabledState/index.js +13 -0
- package/_internal/packages/lumx-core/src/js/utils/events/keyboard.js +15 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/constants.js +13 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/getFirstAndLastFocusable.js +20 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/getFocusableElements.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/focus/setupFocusTrap.js +83 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createActiveItemState.js +38 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createGridFocusNavigation.js +182 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createListFocusNavigation.js +151 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/createPendingNavigation.js +23 -0
- package/_internal/packages/lumx-core/src/js/utils/focusNavigation/setupRovingTabIndex.js +167 -0
- package/_internal/packages/lumx-core/src/js/utils/function/listenerTower.js +25 -0
- package/_internal/packages/lumx-core/src/js/utils/iterable/first.js +8 -0
- package/_internal/packages/lumx-core/src/js/utils/locale/getCurrentLocale.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/select/findOptionById.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/select/getOptionDisplayName.js +19 -0
- package/_internal/packages/lumx-core/src/js/utils/select/renderSelectOptions.js +51 -0
- package/_internal/packages/lumx-core/src/js/utils/select/toggleSelection.js +39 -0
- package/_internal/packages/lumx-core/src/js/utils/select/types.d.ts +203 -0
- package/_internal/packages/lumx-core/src/js/utils/selectors/getWithSelector.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/selectors/groupBySelector.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/time/buildTimeList.d.ts +20 -0
- package/_internal/packages/lumx-core/src/js/utils/time/buildTimeList.js +36 -0
- package/_internal/packages/lumx-core/src/js/utils/time/formatTime.js +14 -0
- package/_internal/packages/lumx-core/src/js/utils/time/getDateAtTime.js +12 -0
- package/_internal/packages/lumx-core/src/js/utils/time/isDateOnTime.js +10 -0
- package/_internal/packages/lumx-core/src/js/utils/time/parseTimeInput.js +46 -0
- package/_internal/packages/lumx-core/src/js/utils/time/snapTimeToBounds.js +21 -0
- package/_internal/packages/lumx-core/src/js/utils/time/timeOfDayMinutes.js +9 -0
- package/_internal/packages/lumx-core/src/js/utils/typeahead/index.js +77 -0
- package/_internal/utils/A11YLiveMessage/index.d.ts +50 -0
- package/_internal/utils/A11YLiveMessage/index.js +28 -0
- package/_internal/utils/ClickAwayProvider/ClickAwayProvider.d.ts +23 -0
- package/_internal/utils/ClickAwayProvider/ClickAwayProvider.js +46 -0
- package/_internal/utils/ClickAwayProvider/index.d.ts +1 -0
- package/_internal/utils/InfiniteScroll/InfiniteScroll.d.ts +10 -0
- package/_internal/utils/InfiniteScroll/InfiniteScroll.js +18 -0
- package/_internal/utils/InfiniteScroll/index.d.ts +2 -0
- package/_internal/utils/Portal/Portal.d.ts +15 -0
- package/_internal/utils/Portal/Portal.js +23 -0
- package/_internal/utils/Portal/PortalProvider.d.ts +14 -0
- package/_internal/utils/Portal/PortalProvider.js +9 -0
- package/_internal/utils/Portal/index.d.ts +3 -0
- package/_internal/utils/browser/DOM/findImage.js +5 -0
- package/_internal/utils/browser/DOM/startViewTransition.js +47 -0
- package/_internal/utils/browser/isReducedMotion.js +8 -0
- package/_internal/utils/browser/isScrollSnapSupported.js +8 -0
- package/_internal/utils/browser/onScrollEnd.js +25 -0
- package/_internal/utils/date/addMonthResetDay.js +12 -0
- package/_internal/utils/date/formatDayNumber.js +8 -0
- package/_internal/utils/date/getFirstDayOfWeek.js +42 -0
- package/_internal/utils/date/getMonthCalendar.js +43 -0
- package/_internal/utils/date/getWeekDays.js +25 -0
- package/_internal/utils/date/getYearDisplayName.js +12 -0
- package/_internal/utils/date/isDateValid.js +7 -0
- package/_internal/utils/date/isSameDay.js +8 -0
- package/_internal/utils/disabled/DisabledStateContext.d.ts +21 -0
- package/_internal/utils/disabled/DisabledStateContext.js +22 -0
- package/_internal/utils/disabled/index.d.ts +1 -0
- package/_internal/utils/disabled/useDisableStateProps.d.ts +1 -0
- package/_internal/utils/disabled/useDisableStateProps.js +29 -0
- package/_internal/utils/locale/parseLocale.js +26 -0
- package/_internal/utils/moving-focus/components/MovingFocusProvider/context.d.ts +14 -0
- package/_internal/utils/moving-focus/components/MovingFocusProvider/context.js +10 -0
- package/_internal/utils/moving-focus/components/MovingFocusProvider/index.d.ts +21 -0
- package/_internal/utils/moving-focus/components/MovingFocusProvider/index.js +58 -0
- package/_internal/utils/moving-focus/constants.d.ts +19 -0
- package/_internal/utils/moving-focus/constants.js +25 -0
- package/_internal/utils/moving-focus/ducks/keyboard-navigation.js +453 -0
- package/_internal/utils/moving-focus/ducks/slice.js +50 -0
- package/_internal/utils/moving-focus/ducks/tab-stop.js +109 -0
- package/_internal/utils/moving-focus/hooks/useRovingTabIndex/index.d.ts +1 -0
- package/_internal/utils/moving-focus/hooks/useRovingTabIndex/useRovingTabIndex.d.ts +19 -0
- package/_internal/utils/moving-focus/hooks/useRovingTabIndex/useRovingTabIndex.js +81 -0
- package/_internal/utils/moving-focus/hooks/useVirtualFocus/index.d.ts +2 -0
- package/_internal/utils/moving-focus/hooks/useVirtualFocus/useVirtualFocus.d.ts +15 -0
- package/_internal/utils/moving-focus/hooks/useVirtualFocus/useVirtualFocus.js +83 -0
- package/_internal/utils/moving-focus/hooks/useVirtualFocus/useVirtualFocusParent.d.ts +10 -0
- package/_internal/utils/moving-focus/hooks/useVirtualFocus/useVirtualFocusParent.js +47 -0
- package/_internal/utils/moving-focus/index.d.ts +5 -0
- package/_internal/utils/moving-focus/types.d.ts +177 -0
- package/_internal/utils/moving-focus/utils/buildLoopAroundObject.js +22 -0
- package/_internal/utils/moving-focus/utils/createGridMap.js +17 -0
- package/_internal/utils/moving-focus/utils/getCell.js +94 -0
- package/_internal/utils/moving-focus/utils/getCellCoordinates.js +16 -0
- package/_internal/utils/moving-focus/utils/getPointerTypeFromEvent.js +11 -0
- package/_internal/utils/moving-focus/utils/shouldLoopListHorizontally.js +7 -0
- package/_internal/utils/moving-focus/utils/shouldLoopListVertically.js +7 -0
- package/_internal/utils/moving-focus/utils/tabStopIsEnabled.js +5 -0
- package/_internal/utils/number/clamp.d.ts +12 -0
- package/_internal/utils/number/clamp.js +16 -0
- package/_internal/utils/object/isEqual.js +14 -0
- package/_internal/utils/partitionMulti.js +24 -0
- package/_internal/utils/react/OnBeforeUnmount.js +17 -0
- package/_internal/utils/react/forwardRef.js +8 -0
- package/_internal/utils/react/forwardRefPolymorphic.js +6 -0
- package/_internal/utils/react/mergeRefs.js +22 -0
- package/_internal/utils/react/skipRender.js +19 -0
- package/_internal/utils/react/unref.js +8 -0
- package/_internal/utils/react/wrapChildrenIconWithSpaces.js +19 -0
- package/_internal/utils/theme/ThemeContext.d.ts +14 -0
- package/_internal/utils/theme/ThemeContext.js +11 -0
- package/_internal/utils/type/Comp.d.ts +15 -0
- package/_internal/utils/type/ComponentRef.d.ts +15 -0
- package/_internal/utils/type/HasPolymorphicAs.d.ts +9 -0
- package/_internal/utils/type/MaybeElementOrRef.d.ts +9 -0
- package/_internal/utils/type/ReactToJSX.d.ts +13 -0
- package/_internal/utils/type/index.d.ts +15 -0
- package/_internal/utils/type/isComponent.d.ts +13 -0
- package/_internal/utils/type/isComponent.js +27 -0
- package/_internal/utils/type/isComponentType.d.ts +9 -0
- package/_internal/utils/type/isComponentType.js +8 -0
- package/index.d.ts +150 -5788
- package/index.js +247 -22493
- package/package.json +8 -21
- package/utils/index.d.ts +14 -413
- package/utils/index.js +12 -1440
- package/_internal/BvaFEHZn.js +0 -262
- package/_internal/BvaFEHZn.js.map +0 -1
- package/index.js.map +0 -1
- package/utils/index.js.map +0 -1
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { setupFocusTrap } from "../packages/lumx-core/src/js/utils/focus/setupFocusTrap.js";
|
|
2
|
+
import { useEffect } from "react";
|
|
3
|
+
//#region src/hooks/useFocusTrap.ts
|
|
4
|
+
/**
|
|
5
|
+
* Trap 'Tab' focus switch inside the `focusZoneElement`.
|
|
6
|
+
*
|
|
7
|
+
* If multiple focus traps are activated, only the last one is maintained and when a focus trap closes, the previous one
|
|
8
|
+
* gets activated again.
|
|
9
|
+
*
|
|
10
|
+
* If the zone has no focusable descendant, the zone element itself receives focus (with a fallback `tabindex="-1"`).
|
|
11
|
+
*
|
|
12
|
+
* @param focusZoneElement The element in which to trap the focus.
|
|
13
|
+
* @param focusElement The element to focus when the focus trap is activated (otherwise the first focusable element
|
|
14
|
+
* will be focused — and finally the zone element itself if no focusable is found).
|
|
15
|
+
*/
|
|
16
|
+
function useFocusTrap(focusZoneElement, focusElement) {
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (!focusZoneElement) return;
|
|
19
|
+
const controller = new AbortController();
|
|
20
|
+
setupFocusTrap({
|
|
21
|
+
focusZoneElement,
|
|
22
|
+
focusElement
|
|
23
|
+
}, controller.signal);
|
|
24
|
+
return () => controller.abort();
|
|
25
|
+
}, [focusElement, focusZoneElement]);
|
|
26
|
+
}
|
|
27
|
+
//#endregion
|
|
28
|
+
export { useFocusTrap };
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
//#region src/hooks/useFocusWithin.ts
|
|
3
|
+
/**
|
|
4
|
+
* Hook that allows to control when there is a focus event within a given element, meaning
|
|
5
|
+
* that any element within the given target will trigger the focus in and focus out events.
|
|
6
|
+
* @param options - UseFocusWithinOptions
|
|
7
|
+
*/
|
|
8
|
+
var useFocusWithin = ({ element, onFocusIn, onFocusOut }) => {
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
if (element) {
|
|
11
|
+
element.addEventListener("focusin", onFocusIn);
|
|
12
|
+
element.addEventListener("focusout", onFocusOut);
|
|
13
|
+
}
|
|
14
|
+
return () => {
|
|
15
|
+
if (element) {
|
|
16
|
+
element.removeEventListener("focusin", onFocusIn);
|
|
17
|
+
element.removeEventListener("focusout", onFocusOut);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}, [
|
|
21
|
+
onFocusIn,
|
|
22
|
+
element,
|
|
23
|
+
onFocusOut
|
|
24
|
+
]);
|
|
25
|
+
};
|
|
26
|
+
//#endregion
|
|
27
|
+
export { useFocusWithin };
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
//#region src/hooks/useId.ts
|
|
3
|
+
var i = 0;
|
|
4
|
+
/**
|
|
5
|
+
* Generate a unique id (for use in a11y or other id based DOM linking).
|
|
6
|
+
*
|
|
7
|
+
* (Tries to emulate React 18 useId hook, to remove once we upgrade React)
|
|
8
|
+
*/
|
|
9
|
+
function useId() {
|
|
10
|
+
return React.useMemo(() => {
|
|
11
|
+
i += 1;
|
|
12
|
+
return `:lumx${i}:`;
|
|
13
|
+
}, []);
|
|
14
|
+
}
|
|
15
|
+
//#endregion
|
|
16
|
+
export { useId };
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
//#region src/hooks/useImageSize.ts
|
|
3
|
+
/** Get natural image size after load. */
|
|
4
|
+
function useImageSize(imgRef, getInitialSize) {
|
|
5
|
+
const [imageSize, setImageSize] = React.useState(getInitialSize || null);
|
|
6
|
+
React.useEffect(() => {
|
|
7
|
+
const { current: img } = imgRef;
|
|
8
|
+
if (!img) return;
|
|
9
|
+
const onLoad = () => setImageSize({
|
|
10
|
+
width: img.naturalWidth,
|
|
11
|
+
height: img.naturalHeight
|
|
12
|
+
});
|
|
13
|
+
img.addEventListener("load", onLoad);
|
|
14
|
+
return () => img.removeEventListener("load", onLoad);
|
|
15
|
+
}, [imgRef]);
|
|
16
|
+
return imageSize;
|
|
17
|
+
}
|
|
18
|
+
//#endregion
|
|
19
|
+
export { useImageSize };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { useEffect } from "react";
|
|
2
|
+
//#region src/hooks/useInfiniteScroll.tsx
|
|
3
|
+
var SCROLL_TRIGGER_MARGIN = 5;
|
|
4
|
+
/**
|
|
5
|
+
* Listen to clicks away from a given element and callback the passed in function.
|
|
6
|
+
*
|
|
7
|
+
* @param ref A reference to the element on which you want to listen scroll event.
|
|
8
|
+
* @param [callback] A callback function to call when the bottom of the reference element is reached.
|
|
9
|
+
* @param [callbackOnMount] A callback function to call when the component is mounted.
|
|
10
|
+
*/
|
|
11
|
+
var useInfiniteScroll = (ref, callback, callbackOnMount = false, scrollTriggerMargin = SCROLL_TRIGGER_MARGIN) => {
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
const { current } = ref;
|
|
14
|
+
if (!callback || !current) return;
|
|
15
|
+
const isAtBottom = () => Boolean(current && current.scrollHeight - (current.scrollTop + current.clientHeight) <= scrollTriggerMargin);
|
|
16
|
+
const onScroll = (e) => {
|
|
17
|
+
if (isAtBottom()) callback(e);
|
|
18
|
+
};
|
|
19
|
+
if (isAtBottom()) onScroll();
|
|
20
|
+
current.addEventListener("scroll", onScroll);
|
|
21
|
+
current.addEventListener("resize", onScroll);
|
|
22
|
+
return () => {
|
|
23
|
+
current.removeEventListener("scroll", onScroll);
|
|
24
|
+
current.removeEventListener("resize", onScroll);
|
|
25
|
+
};
|
|
26
|
+
}, [
|
|
27
|
+
ref,
|
|
28
|
+
callback,
|
|
29
|
+
scrollTriggerMargin
|
|
30
|
+
]);
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
if (callback && callbackOnMount) callback();
|
|
33
|
+
}, [callback, callbackOnMount]);
|
|
34
|
+
};
|
|
35
|
+
//#endregion
|
|
36
|
+
export { useInfiniteScroll };
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
//#region src/hooks/useIntersectionObserver.tsx
|
|
3
|
+
/**
|
|
4
|
+
* Convenient hook to create interaction observers.
|
|
5
|
+
*
|
|
6
|
+
* @param elements Elements to observe.
|
|
7
|
+
* @param options IntersectionObserver options.
|
|
8
|
+
* @return Map of intersections.
|
|
9
|
+
*/
|
|
10
|
+
function useIntersectionObserver(elements, options) {
|
|
11
|
+
const [intersections, setIntersections] = useState(() => /* @__PURE__ */ new Map());
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (elements.length < 1 || !elements.some(Boolean)) return;
|
|
14
|
+
const observer = new IntersectionObserver((entries) => {
|
|
15
|
+
for (const entry of entries) intersections.set(entry.target, entry);
|
|
16
|
+
setIntersections(new Map(intersections));
|
|
17
|
+
}, options);
|
|
18
|
+
for (const element of elements) if (element) observer.observe(element);
|
|
19
|
+
return () => observer.disconnect();
|
|
20
|
+
}, [...elements]);
|
|
21
|
+
return intersections;
|
|
22
|
+
}
|
|
23
|
+
//#endregion
|
|
24
|
+
export { useIntersectionObserver };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useEffect, useRef } from "react";
|
|
2
|
+
import isFunction from "lodash/isFunction.js";
|
|
3
|
+
//#region src/hooks/useInterval.tsx
|
|
4
|
+
/**
|
|
5
|
+
* Making setInterval Declarative with React Hooks.
|
|
6
|
+
* Credits: https://overreacted.io/making-setinterval-declarative-with-react-hooks/
|
|
7
|
+
*
|
|
8
|
+
* @param callback Function called by setInterval.
|
|
9
|
+
* @param delay Delay for setInterval.
|
|
10
|
+
*/
|
|
11
|
+
function useInterval(callback, delay) {
|
|
12
|
+
const savedCallback = useRef();
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
savedCallback.current = callback;
|
|
15
|
+
});
|
|
16
|
+
useEffect(() => {
|
|
17
|
+
if (delay === null) return void 0;
|
|
18
|
+
function tick() {
|
|
19
|
+
if (isFunction(savedCallback.current)) savedCallback.current();
|
|
20
|
+
}
|
|
21
|
+
const id = setInterval(tick, delay);
|
|
22
|
+
return () => clearInterval(id);
|
|
23
|
+
}, [delay]);
|
|
24
|
+
}
|
|
25
|
+
//#endregion
|
|
26
|
+
export { useInterval };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { useEffect, useLayoutEffect } from "react";
|
|
2
|
+
//#region src/hooks/useIsomorphicLayoutEffect.tsx
|
|
3
|
+
/**
|
|
4
|
+
* SSR-safe version of `useLayoutEffect`.
|
|
5
|
+
* Uses `useLayoutEffect` on the client and `useEffect` on the server to avoid React SSR warnings.
|
|
6
|
+
*/
|
|
7
|
+
var useIsomorphicLayoutEffect = typeof window !== "undefined" ? useLayoutEffect : useEffect;
|
|
8
|
+
//#endregion
|
|
9
|
+
export { useIsomorphicLayoutEffect };
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { RefObject, SetStateAction } from "react";
|
|
2
|
+
|
|
3
|
+
//#region src/hooks/useKeyboardListNavigation.d.ts
|
|
4
|
+
type Listener = (evt: KeyboardEvent) => void;
|
|
5
|
+
interface UseKeyboardListNavigationType {
|
|
6
|
+
/** the current active index */
|
|
7
|
+
activeItemIndex: number;
|
|
8
|
+
/** callback to be used when a key is pressed. usually used with the native prop `onKeyDown` */
|
|
9
|
+
onKeyboardNavigation: Listener;
|
|
10
|
+
/** Resets the active index to the initial state */
|
|
11
|
+
resetActiveIndex(): void;
|
|
12
|
+
/** Sets the active index to a given value */
|
|
13
|
+
setActiveItemIndex(value: SetStateAction<number>): void;
|
|
14
|
+
}
|
|
15
|
+
type useKeyboardListNavigationType = <I>(items: I[], ref: RefObject<HTMLElement>, onListItemSelected: (itemSelected: I) => void, onListItemNavigated?: (itemSelected: I) => void, onEnterPressed?: (itemSelected: string) => void, onBackspacePressed?: Listener, keepFocusAfterSelection?: boolean, initialIndex?: number, preventTabOnEnteredValue?: boolean) => UseKeyboardListNavigationType;
|
|
16
|
+
//#endregion
|
|
17
|
+
export { useKeyboardListNavigationType };
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
import get from "lodash/get.js";
|
|
3
|
+
//#region src/hooks/useKeyboardListNavigation.tsx
|
|
4
|
+
var INITIAL_INDEX = -1;
|
|
5
|
+
/**
|
|
6
|
+
* This custom hook provides the necessary set of functions and values to properly navigate
|
|
7
|
+
* a list using the keyboard.
|
|
8
|
+
*
|
|
9
|
+
* @param items the list of items that will be navigated using the keyboard.
|
|
10
|
+
* @param ref A reference to the element that is controlling the navigation.
|
|
11
|
+
* @param onListItemSelected callback to be executed when the ENTER key is pressed on an item.
|
|
12
|
+
* @param onListItemNavigated callback to be executed when the Arrow keys are pressed.
|
|
13
|
+
* @param onEnterPressed callback to be executed when the ENTER key is pressed.
|
|
14
|
+
* @param onBackspacePressed callback to be executed when the BACKSPACE key is pressed.
|
|
15
|
+
* @param keepFocusAfterSelection determines whether after selecting an item, the focus should be maintained on the current target or not.
|
|
16
|
+
* @param initialIndex where should the navigation start from. it defaults to `-1`, so the first item navigated is the item on position `0`.
|
|
17
|
+
* @param preventTabOnEnteredValue determines whether upon TAB, if there is a value entered, the event is prevented or not.
|
|
18
|
+
* @return useKeyboardListNavigation helpers.
|
|
19
|
+
*/
|
|
20
|
+
var useKeyboardListNavigation = (items, ref, onListItemSelected, onListItemNavigated, onEnterPressed, onBackspacePressed, keepFocusAfterSelection = false, initialIndex = INITIAL_INDEX, preventTabOnEnteredValue = true) => {
|
|
21
|
+
const [activeItemIndex, setActiveItemIndex] = useState(initialIndex);
|
|
22
|
+
/**
|
|
23
|
+
* This function calculates the next index in the list to be highlighted
|
|
24
|
+
* @param key - key code pressed
|
|
25
|
+
* @return next active index
|
|
26
|
+
*/
|
|
27
|
+
const calculateActiveIndex = (key) => {
|
|
28
|
+
switch (key) {
|
|
29
|
+
case "ArrowDown": return activeItemIndex + 1 < items.length ? activeItemIndex + 1 : 0;
|
|
30
|
+
case "ArrowUp": return activeItemIndex - 1 >= 0 ? activeItemIndex - 1 : items.length - 1;
|
|
31
|
+
default: return initialIndex;
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* Resets the active index to the initial state
|
|
36
|
+
*/
|
|
37
|
+
const resetActiveIndex = () => {
|
|
38
|
+
setActiveItemIndex(initialIndex);
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Prevents the default event and stops the propagation of said event
|
|
42
|
+
* @param evt - key pressed event
|
|
43
|
+
*/
|
|
44
|
+
const preventDefaultAndStopPropagation = (evt) => {
|
|
45
|
+
evt.preventDefault();
|
|
46
|
+
evt.stopPropagation();
|
|
47
|
+
};
|
|
48
|
+
/**
|
|
49
|
+
* Handles navigation with the arrows using the keyboard
|
|
50
|
+
* @param evt - key pressed event
|
|
51
|
+
*/
|
|
52
|
+
const onArrowPressed = (evt) => {
|
|
53
|
+
const { key } = evt;
|
|
54
|
+
const nextActiveIndex = calculateActiveIndex(key);
|
|
55
|
+
setActiveItemIndex(nextActiveIndex);
|
|
56
|
+
preventDefaultAndStopPropagation(evt);
|
|
57
|
+
if (onListItemNavigated) {
|
|
58
|
+
const selectedItem = items[nextActiveIndex];
|
|
59
|
+
onListItemNavigated(selectedItem);
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Handles the event when the backspace key is pressed
|
|
64
|
+
* @param evt - key pressed event
|
|
65
|
+
*/
|
|
66
|
+
const onBackspaceKeyPressed = (evt) => {
|
|
67
|
+
if (onBackspacePressed) onBackspacePressed(evt);
|
|
68
|
+
};
|
|
69
|
+
/**
|
|
70
|
+
* Handles when the ENTER key is pressed
|
|
71
|
+
* @param evt - key pressed event
|
|
72
|
+
*/
|
|
73
|
+
const onEnterKeyPressed = (evt) => {
|
|
74
|
+
if (!onListItemSelected) return;
|
|
75
|
+
preventDefaultAndStopPropagation(evt);
|
|
76
|
+
if (!keepFocusAfterSelection) evt.currentTarget.blur();
|
|
77
|
+
const selectedItem = items[activeItemIndex];
|
|
78
|
+
if (selectedItem) {
|
|
79
|
+
onListItemSelected(selectedItem);
|
|
80
|
+
resetActiveIndex();
|
|
81
|
+
} else if (activeItemIndex === initialIndex && onEnterPressed) {
|
|
82
|
+
onEnterPressed(get(evt, "target.value"));
|
|
83
|
+
resetActiveIndex();
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
/**
|
|
87
|
+
* Handles when the TAB key is pressed
|
|
88
|
+
* @param evt - key pressed event
|
|
89
|
+
*/
|
|
90
|
+
const onTabKeyPressed = (evt) => {
|
|
91
|
+
const value = get(evt, "target.value");
|
|
92
|
+
if (preventTabOnEnteredValue && value && value.length > 0) preventDefaultAndStopPropagation(evt);
|
|
93
|
+
};
|
|
94
|
+
/**
|
|
95
|
+
* In order to make it easier in the future to add new events depending on the key
|
|
96
|
+
* a map was created to add these handlers. In the future, if there is another event
|
|
97
|
+
* that we need to manage depending on a specific key, we just need to add the key code
|
|
98
|
+
* here, and as a value, the handler for said key.
|
|
99
|
+
*/
|
|
100
|
+
const eventsForKeyPressed = {
|
|
101
|
+
ArrowDown: onArrowPressed,
|
|
102
|
+
Tab: onTabKeyPressed,
|
|
103
|
+
ArrowUp: onArrowPressed,
|
|
104
|
+
Enter: onEnterKeyPressed,
|
|
105
|
+
Backspace: onBackspaceKeyPressed
|
|
106
|
+
};
|
|
107
|
+
/**
|
|
108
|
+
* Calculates the next active item index depending on the key pressed.
|
|
109
|
+
* If the key pressed was ENTER, the function executes the callback `onListItemSelected`
|
|
110
|
+
* and resets the active index, since an item was selected.
|
|
111
|
+
* @param evt - key pressed or key down event
|
|
112
|
+
*/
|
|
113
|
+
const onKeyboardNavigation = (evt) => {
|
|
114
|
+
const { key } = evt;
|
|
115
|
+
const handler = eventsForKeyPressed[key];
|
|
116
|
+
if (handler) handler(evt);
|
|
117
|
+
};
|
|
118
|
+
useEffect(() => {
|
|
119
|
+
const { current: currentElement } = ref;
|
|
120
|
+
if (!currentElement) return;
|
|
121
|
+
currentElement.addEventListener("focus", resetActiveIndex);
|
|
122
|
+
currentElement.addEventListener("keydown", onKeyboardNavigation);
|
|
123
|
+
return () => {
|
|
124
|
+
currentElement.removeEventListener("focus", resetActiveIndex);
|
|
125
|
+
currentElement.removeEventListener("keydown", onKeyboardNavigation);
|
|
126
|
+
};
|
|
127
|
+
});
|
|
128
|
+
return {
|
|
129
|
+
activeItemIndex,
|
|
130
|
+
onKeyboardNavigation,
|
|
131
|
+
resetActiveIndex,
|
|
132
|
+
setActiveItemIndex
|
|
133
|
+
};
|
|
134
|
+
};
|
|
135
|
+
//#endregion
|
|
136
|
+
export { useKeyboardListNavigation };
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { useEffect, useState } from "react";
|
|
2
|
+
//#region src/hooks/useListenFocus.tsx
|
|
3
|
+
/**
|
|
4
|
+
* Listen on element focus to store the focus status.
|
|
5
|
+
*/
|
|
6
|
+
function useListenFocus(ref) {
|
|
7
|
+
const [isFocus, setFocus] = useState(false);
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
const { current: element } = ref;
|
|
10
|
+
if (!element) return;
|
|
11
|
+
const onFocus = () => setFocus(true);
|
|
12
|
+
const onBlur = () => setFocus(false);
|
|
13
|
+
element.addEventListener("focus", onFocus);
|
|
14
|
+
element.addEventListener("blur", onBlur);
|
|
15
|
+
return () => {
|
|
16
|
+
element.removeEventListener("focus", onFocus);
|
|
17
|
+
element.removeEventListener("blur", onBlur);
|
|
18
|
+
};
|
|
19
|
+
}, [ref, setFocus]);
|
|
20
|
+
return isFocus;
|
|
21
|
+
}
|
|
22
|
+
//#endregion
|
|
23
|
+
export { useListenFocus };
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { useTooltipContext } from "../components/tooltip/context.js";
|
|
2
|
+
import React from "react";
|
|
3
|
+
import { classNames } from "@lumx/core/js/utils";
|
|
4
|
+
//#region src/hooks/useOverflowTooltipLabel.tsx
|
|
5
|
+
/**
|
|
6
|
+
* Compute a tooltip label based on a label element `innerText` if the text overflows.
|
|
7
|
+
* Updates dynamically on content changes (but not on resize!)
|
|
8
|
+
*/
|
|
9
|
+
var useOverflowTooltipLabel = (content) => {
|
|
10
|
+
const parentTooltip = useTooltipContext();
|
|
11
|
+
const [tooltipLabel, setTooltipLabel] = React.useState(void 0);
|
|
12
|
+
const [labelElement, setLabelElement] = React.useState(null);
|
|
13
|
+
React.useLayoutEffect(() => {
|
|
14
|
+
if (!parentTooltip && labelElement && !labelElement?.closest(`.${classNames.visuallyHidden()}`) && labelElement.offsetWidth < labelElement.scrollWidth) setTooltipLabel(labelElement.innerText);
|
|
15
|
+
else setTooltipLabel(void 0);
|
|
16
|
+
}, [
|
|
17
|
+
labelElement,
|
|
18
|
+
parentTooltip,
|
|
19
|
+
content
|
|
20
|
+
]);
|
|
21
|
+
return {
|
|
22
|
+
labelRef: setLabelElement,
|
|
23
|
+
tooltipLabel
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
//#endregion
|
|
27
|
+
export { useOverflowTooltipLabel };
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
//#region src/hooks/usePreviousValue.ts
|
|
3
|
+
/**
|
|
4
|
+
* Returns the value from the previous render.
|
|
5
|
+
*/
|
|
6
|
+
function usePreviousValue(value) {
|
|
7
|
+
const prevValueRef = React.useRef();
|
|
8
|
+
const prevValue = prevValueRef.current;
|
|
9
|
+
React.useEffect(() => {
|
|
10
|
+
prevValueRef.current = value;
|
|
11
|
+
}, [value]);
|
|
12
|
+
return prevValue;
|
|
13
|
+
}
|
|
14
|
+
//#endregion
|
|
15
|
+
export { usePreviousValue };
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { getFirstAndLastFocusable } from "../packages/lumx-core/src/js/utils/focus/getFirstAndLastFocusable.js";
|
|
2
|
+
import { OnBeforeUnmount } from "../utils/react/OnBeforeUnmount.js";
|
|
3
|
+
import React from "react";
|
|
4
|
+
import { jsx } from "react/jsx-runtime";
|
|
5
|
+
//#region src/hooks/useRestoreFocusOnClose.tsx
|
|
6
|
+
/**
|
|
7
|
+
* Provides an unmount sentinel to inject in the popover to detect when it closes and restore the focus to the
|
|
8
|
+
* anchor if needed.
|
|
9
|
+
*/
|
|
10
|
+
function useRestoreFocusOnClose({ focusAnchorOnClose, anchorRef, parentElement }, popoverElement, isOpen) {
|
|
11
|
+
const onBeforeUnmountRef = React.useRef();
|
|
12
|
+
const prevIsOpenRef = React.useRef(isOpen);
|
|
13
|
+
const tryRestoreFocus = React.useCallback(() => {
|
|
14
|
+
if (!popoverElement || !focusAnchorOnClose) return;
|
|
15
|
+
const focusedAtClose = document.activeElement;
|
|
16
|
+
if (!popoverElement.contains(focusedAtClose)) return;
|
|
17
|
+
setTimeout(() => {
|
|
18
|
+
const active = document.activeElement;
|
|
19
|
+
if (active && active !== focusedAtClose && active !== document.body && active !== document.documentElement) return;
|
|
20
|
+
const anchor = anchorRef.current;
|
|
21
|
+
(parentElement?.current || (anchor ? getFirstAndLastFocusable(anchor).first : void 0) || anchor)?.focus({ preventScroll: true });
|
|
22
|
+
}, 0);
|
|
23
|
+
}, [
|
|
24
|
+
anchorRef,
|
|
25
|
+
focusAnchorOnClose,
|
|
26
|
+
parentElement,
|
|
27
|
+
popoverElement
|
|
28
|
+
]);
|
|
29
|
+
React.useEffect(() => {
|
|
30
|
+
if (!popoverElement || !focusAnchorOnClose) {
|
|
31
|
+
onBeforeUnmountRef.current = void 0;
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
onBeforeUnmountRef.current = tryRestoreFocus;
|
|
35
|
+
}, [
|
|
36
|
+
focusAnchorOnClose,
|
|
37
|
+
popoverElement,
|
|
38
|
+
tryRestoreFocus
|
|
39
|
+
]);
|
|
40
|
+
React.useEffect(() => {
|
|
41
|
+
if (prevIsOpenRef.current && !isOpen) tryRestoreFocus();
|
|
42
|
+
prevIsOpenRef.current = isOpen;
|
|
43
|
+
}, [isOpen, tryRestoreFocus]);
|
|
44
|
+
return /* @__PURE__ */ jsx(OnBeforeUnmount, { callbackRef: onBeforeUnmountRef });
|
|
45
|
+
}
|
|
46
|
+
//#endregion
|
|
47
|
+
export { useRestoreFocusOnClose };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { setupRovingTabIndex } from "../packages/lumx-core/src/js/utils/focusNavigation/setupRovingTabIndex.js";
|
|
2
|
+
import { useIsomorphicLayoutEffect } from "./useIsomorphicLayoutEffect.js";
|
|
3
|
+
import { useEventCallback } from "./useEventCallback.js";
|
|
4
|
+
import { unref } from "../utils/react/unref.js";
|
|
5
|
+
//#region src/hooks/useRovingTabIndexContainer.tsx
|
|
6
|
+
var useRovingTabIndexContainer = ({ containerRef, itemSelector, onItemFocused: unstableOnItemFocused, direction, itemDisabledSelector, itemSelectedAttr }) => {
|
|
7
|
+
const onItemFocused = useEventCallback(unstableOnItemFocused);
|
|
8
|
+
useIsomorphicLayoutEffect(() => {
|
|
9
|
+
const container = unref(containerRef);
|
|
10
|
+
if (!container) return;
|
|
11
|
+
const abortController = new AbortController();
|
|
12
|
+
setupRovingTabIndex({
|
|
13
|
+
container,
|
|
14
|
+
itemSelector,
|
|
15
|
+
direction,
|
|
16
|
+
itemDisabledSelector,
|
|
17
|
+
itemSelectedAttr,
|
|
18
|
+
onItemFocused
|
|
19
|
+
}, abortController.signal);
|
|
20
|
+
return () => abortController.abort();
|
|
21
|
+
}, [
|
|
22
|
+
containerRef,
|
|
23
|
+
itemSelector,
|
|
24
|
+
direction,
|
|
25
|
+
itemDisabledSelector,
|
|
26
|
+
itemSelectedAttr,
|
|
27
|
+
onItemFocused
|
|
28
|
+
]);
|
|
29
|
+
};
|
|
30
|
+
//#endregion
|
|
31
|
+
export { useRovingTabIndexContainer };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import throttle from "lodash/throttle.js";
|
|
3
|
+
//#region src/hooks/useSizeOnWindowResize.ts
|
|
4
|
+
/**
|
|
5
|
+
* Observe element size (only works if it's size depends on the window size).
|
|
6
|
+
*
|
|
7
|
+
* (Not using ResizeObserver for better browser backward compat)
|
|
8
|
+
*
|
|
9
|
+
* @param elementRef Element to observe
|
|
10
|
+
* @return the size and a manual update callback
|
|
11
|
+
*/
|
|
12
|
+
function useSizeOnWindowResize(elementRef) {
|
|
13
|
+
const [size, setSize] = React.useState(null);
|
|
14
|
+
const updateSize = React.useMemo(() => throttle(() => {
|
|
15
|
+
const newSize = elementRef.current?.getBoundingClientRect();
|
|
16
|
+
if (newSize) setSize(newSize);
|
|
17
|
+
}, 10), [elementRef]);
|
|
18
|
+
React.useEffect(() => {
|
|
19
|
+
updateSize();
|
|
20
|
+
window.addEventListener("resize", updateSize);
|
|
21
|
+
return () => window.removeEventListener("resize", updateSize);
|
|
22
|
+
}, [updateSize]);
|
|
23
|
+
return [size, updateSize];
|
|
24
|
+
}
|
|
25
|
+
//#endregion
|
|
26
|
+
export { useSizeOnWindowResize };
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
//#region src/hooks/useSlideshowControls.d.ts
|
|
2
|
+
interface UseSlideshowControlsOptions {
|
|
3
|
+
/** default active index to be displayed */
|
|
4
|
+
defaultActiveIndex?: number;
|
|
5
|
+
/** total slides to display */
|
|
6
|
+
itemsCount: number;
|
|
7
|
+
/** Index of the current slide. */
|
|
8
|
+
activeIndex?: number;
|
|
9
|
+
/** Whether the automatic rotation of the slideshow is enabled or not. */
|
|
10
|
+
autoPlay?: boolean;
|
|
11
|
+
/** Whether the image has to fill its container height or not. */
|
|
12
|
+
fillHeight?: boolean;
|
|
13
|
+
/** Number of slides to group together. */
|
|
14
|
+
groupBy?: number;
|
|
15
|
+
/** Interval between each slide when automatic rotation is enabled. */
|
|
16
|
+
interval?: number;
|
|
17
|
+
/** Callback when slide changes */
|
|
18
|
+
onChange?(index: number): void;
|
|
19
|
+
/** slideshow HTML id attribute */
|
|
20
|
+
id?: string;
|
|
21
|
+
/** slides wrapper HTML id attribute */
|
|
22
|
+
slidesId?: string;
|
|
23
|
+
}
|
|
24
|
+
interface UseSlideshowControls {
|
|
25
|
+
/** Index for the first visible slide, should be used when groupBy is passed in */
|
|
26
|
+
startIndexVisible: number;
|
|
27
|
+
/** Index for the last visible slide, should be used when groupBy is passed in */
|
|
28
|
+
endIndexVisible: number;
|
|
29
|
+
/** total slides to be displayed */
|
|
30
|
+
slidesCount: number;
|
|
31
|
+
/** callback to set */
|
|
32
|
+
setSlideshow: (element: HTMLDivElement | null) => void;
|
|
33
|
+
/** reference to the slideshow element */
|
|
34
|
+
slideshow: HTMLDivElement | null;
|
|
35
|
+
/** id to be used for the slideshow */
|
|
36
|
+
slideshowId: string;
|
|
37
|
+
/** id to be used for the wrapper that contains the slides */
|
|
38
|
+
slideshowSlidesId: string;
|
|
39
|
+
/** callback that triggers the previous slide while using the slideshow controls */
|
|
40
|
+
onPreviousClick: (loopback: boolean) => void;
|
|
41
|
+
/** callback that triggers the next slide while using the slideshow controls */
|
|
42
|
+
onNextClick: (loopback: boolean) => void;
|
|
43
|
+
/** callback that triggers a specific page while using the slideshow controls */
|
|
44
|
+
onPaginationClick: (index: number) => void;
|
|
45
|
+
/** whether the slideshow is autoplaying or not */
|
|
46
|
+
isAutoPlaying: boolean;
|
|
47
|
+
/** whether the slideshow was force paused or not */
|
|
48
|
+
isForcePaused: boolean;
|
|
49
|
+
/** callback to change whether the slideshow is autoplaying or not */
|
|
50
|
+
toggleAutoPlay: () => void;
|
|
51
|
+
/** calback to change whether the slideshow should be force paused or not */
|
|
52
|
+
toggleForcePause: () => void;
|
|
53
|
+
/** current active slide index */
|
|
54
|
+
activeIndex: number;
|
|
55
|
+
/** set the current index as the active one */
|
|
56
|
+
setActiveIndex: (index: number) => void;
|
|
57
|
+
/** callback that stops the auto play */
|
|
58
|
+
stopAutoPlay: () => void;
|
|
59
|
+
/** callback that starts the auto play */
|
|
60
|
+
startAutoPlay: () => void;
|
|
61
|
+
}
|
|
62
|
+
//#endregion
|
|
63
|
+
export { UseSlideshowControls, UseSlideshowControlsOptions };
|