@itwin/itwinui-react 3.12.2 → 3.13.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/CHANGELOG.md +38 -0
- package/DEV-cjs/core/Alert/Alert.js +90 -0
- package/DEV-cjs/core/Avatar/Avatar.js +55 -0
- package/DEV-cjs/core/AvatarGroup/AvatarGroup.js +38 -0
- package/DEV-cjs/core/Backdrop/Backdrop.js +26 -0
- package/DEV-cjs/core/Badge/Badge.js +48 -0
- package/DEV-cjs/core/Breadcrumbs/Breadcrumbs.js +96 -0
- package/DEV-cjs/core/ButtonGroup/ButtonGroup.js +91 -0
- package/DEV-cjs/core/Buttons/Button.js +54 -0
- package/DEV-cjs/core/Buttons/DropdownButton.js +43 -0
- package/DEV-cjs/core/Buttons/IconButton.js +46 -0
- package/DEV-cjs/core/Buttons/IdeasButton.js +30 -0
- package/DEV-cjs/core/Buttons/SplitButton.js +71 -0
- package/DEV-cjs/core/Carousel/Carousel.js +74 -0
- package/DEV-cjs/core/Carousel/CarouselContext.js +14 -0
- package/DEV-cjs/core/Carousel/CarouselDot.js +31 -0
- package/DEV-cjs/core/Carousel/CarouselDotsList.js +122 -0
- package/DEV-cjs/core/Carousel/CarouselNavigation.js +79 -0
- package/DEV-cjs/core/Carousel/CarouselSlide.js +46 -0
- package/DEV-cjs/core/Carousel/CarouselSlider.js +65 -0
- package/DEV-cjs/core/Checkbox/Checkbox.js +58 -0
- package/DEV-cjs/core/ColorPicker/ColorBuilder.js +250 -0
- package/DEV-cjs/core/ColorPicker/ColorInputPanel.js +384 -0
- package/DEV-cjs/core/ColorPicker/ColorPalette.js +43 -0
- package/DEV-cjs/core/ColorPicker/ColorPicker.js +79 -0
- package/DEV-cjs/core/ColorPicker/ColorPickerContext.js +26 -0
- package/DEV-cjs/core/ColorPicker/ColorSwatch.js +38 -0
- package/DEV-cjs/core/ComboBox/ComboBox.js +310 -0
- package/DEV-cjs/core/ComboBox/ComboBox.types-test.js +82 -0
- package/DEV-cjs/core/ComboBox/ComboBoxEndIcon.js +31 -0
- package/DEV-cjs/core/ComboBox/ComboBoxInput.js +133 -0
- package/DEV-cjs/core/ComboBox/ComboBoxInputContainer.js +32 -0
- package/DEV-cjs/core/ComboBox/ComboBoxMenu.js +101 -0
- package/DEV-cjs/core/ComboBox/ComboBoxMenuItem.js +48 -0
- package/DEV-cjs/core/ComboBox/ComboBoxMultipleContainer.js +22 -0
- package/DEV-cjs/core/ComboBox/helpers.js +24 -0
- package/DEV-cjs/core/DatePicker/DatePicker.js +382 -0
- package/DEV-cjs/core/Dialog/Dialog.js +65 -0
- package/DEV-cjs/core/Dialog/DialogBackdrop.js +43 -0
- package/DEV-cjs/core/Dialog/DialogButtonBar.js +13 -0
- package/DEV-cjs/core/Dialog/DialogContent.js +13 -0
- package/DEV-cjs/core/Dialog/DialogContext.js +22 -0
- package/DEV-cjs/core/Dialog/DialogDragContext.js +27 -0
- package/DEV-cjs/core/Dialog/DialogMain.js +131 -0
- package/DEV-cjs/core/Dialog/DialogTitleBar.js +41 -0
- package/DEV-cjs/core/Dialog/DialogTitleBarTitle.js +13 -0
- package/DEV-cjs/core/Divider/Divider.js +26 -0
- package/DEV-cjs/core/DropdownMenu/DropdownMenu.js +48 -0
- package/DEV-cjs/core/ExpandableBlock/ExpandableBlock.js +151 -0
- package/DEV-cjs/core/Fieldset/Fieldset.js +27 -0
- package/DEV-cjs/core/FileUpload/FileEmptyCard.js +35 -0
- package/DEV-cjs/core/FileUpload/FileUpload.js +61 -0
- package/DEV-cjs/core/FileUpload/FileUploadCard.js +153 -0
- package/DEV-cjs/core/FileUpload/FileUploadTemplate.js +39 -0
- package/DEV-cjs/core/Flex/Flex.js +88 -0
- package/DEV-cjs/core/Footer/Footer.js +103 -0
- package/DEV-cjs/core/Footer/FooterItem.js +13 -0
- package/DEV-cjs/core/Footer/FooterList.js +13 -0
- package/DEV-cjs/core/Footer/FooterSeparator.js +15 -0
- package/DEV-cjs/core/Header/Header.js +50 -0
- package/DEV-cjs/core/Header/HeaderBasicButton.js +23 -0
- package/DEV-cjs/core/Header/HeaderBreadcrumbs.js +41 -0
- package/DEV-cjs/core/Header/HeaderButton.js +51 -0
- package/DEV-cjs/core/Header/HeaderDropdownButton.js +48 -0
- package/DEV-cjs/core/Header/HeaderLogo.js +34 -0
- package/DEV-cjs/core/Header/HeaderSplitButton.js +53 -0
- package/DEV-cjs/core/Icon/Icon.js +40 -0
- package/DEV-cjs/core/InformationPanel/InformationPanel.js +68 -0
- package/DEV-cjs/core/InformationPanel/InformationPanelBody.js +13 -0
- package/DEV-cjs/core/InformationPanel/InformationPanelContent.js +26 -0
- package/DEV-cjs/core/InformationPanel/InformationPanelHeader.js +36 -0
- package/DEV-cjs/core/InformationPanel/InformationPanelWrapper.js +13 -0
- package/DEV-cjs/core/Input/Input.js +30 -0
- package/DEV-cjs/core/InputGrid/InputGrid.js +125 -0
- package/DEV-cjs/core/InputGroup/InputGroup.js +58 -0
- package/DEV-cjs/core/InputWithDecorations/InputWithDecorations.js +61 -0
- package/DEV-cjs/core/Label/Label.js +29 -0
- package/DEV-cjs/core/LabeledInput/LabeledInput.js +49 -0
- package/DEV-cjs/core/LabeledSelect/LabeledSelect.js +43 -0
- package/DEV-cjs/core/LabeledSelect/LabeledSelect.types-test.js +84 -0
- package/DEV-cjs/core/LabeledTextarea/LabeledTextarea.js +20 -0
- package/DEV-cjs/core/LinkAction/LinkAction.js +36 -0
- package/DEV-cjs/core/List/List.js +15 -0
- package/DEV-cjs/core/List/ListItem.js +45 -0
- package/DEV-cjs/core/Menu/Menu.js +140 -0
- package/DEV-cjs/core/Menu/MenuDivider.js +15 -0
- package/DEV-cjs/core/Menu/MenuExtraContent.js +15 -0
- package/DEV-cjs/core/Menu/MenuItem.js +82 -0
- package/DEV-cjs/core/Menu/MenuItemSkeleton.js +44 -0
- package/DEV-cjs/core/Modal/Modal.js +36 -0
- package/DEV-cjs/core/Modal/ModalButtonBar.js +13 -0
- package/DEV-cjs/core/Modal/ModalContent.js +13 -0
- package/DEV-cjs/core/NonIdealState/ErrorPage.js +133 -0
- package/DEV-cjs/core/NonIdealState/NonIdealState.js +40 -0
- package/DEV-cjs/core/NotificationMarker/NotificationMarker.js +29 -0
- package/DEV-cjs/core/Overlay/Overlay.js +52 -0
- package/DEV-cjs/core/Popover/Popover.js +209 -0
- package/DEV-cjs/core/ProgressIndicators/ProgressLinear.js +38 -0
- package/DEV-cjs/core/ProgressIndicators/ProgressRadial.js +45 -0
- package/DEV-cjs/core/Radio/Radio.js +42 -0
- package/DEV-cjs/core/RadioTiles/RadioTile.js +47 -0
- package/DEV-cjs/core/RadioTiles/RadioTileGroup.js +25 -0
- package/DEV-cjs/core/SearchBox/SearchBox.js +154 -0
- package/DEV-cjs/core/Select/Select.js +300 -0
- package/DEV-cjs/core/Select/Select.types-test.js +90 -0
- package/DEV-cjs/core/Select/SelectTag.js +27 -0
- package/DEV-cjs/core/Select/SelectTagContainer.js +28 -0
- package/DEV-cjs/core/SideNavigation/SideNavigation.js +74 -0
- package/DEV-cjs/core/SideNavigation/SidenavButton.js +37 -0
- package/DEV-cjs/core/SideNavigation/SidenavSubmenu.js +26 -0
- package/DEV-cjs/core/SideNavigation/SidenavSubmenuHeader.js +28 -0
- package/DEV-cjs/core/SkipToContentLink/SkipToContentLink.js +25 -0
- package/DEV-cjs/core/Slider/Slider.js +281 -0
- package/DEV-cjs/core/Slider/Thumb.js +102 -0
- package/DEV-cjs/core/Slider/Track.js +70 -0
- package/DEV-cjs/core/StatusMessage/StatusMessage.js +31 -0
- package/DEV-cjs/core/Stepper/Stepper.js +56 -0
- package/DEV-cjs/core/Stepper/StepperStep.js +64 -0
- package/DEV-cjs/core/Stepper/WorkflowDiagram.js +37 -0
- package/DEV-cjs/core/Stepper/WorkflowDiagramStep.js +32 -0
- package/DEV-cjs/core/Surface/Surface.js +94 -0
- package/DEV-cjs/core/Table/SubRowExpander.js +37 -0
- package/DEV-cjs/core/Table/Table.js +538 -0
- package/DEV-cjs/core/Table/TableCell.js +69 -0
- package/DEV-cjs/core/Table/TablePaginator.js +188 -0
- package/DEV-cjs/core/Table/TableRowMemoized.js +99 -0
- package/DEV-cjs/core/Table/actionHandlers/expandHandler.js +21 -0
- package/DEV-cjs/core/Table/actionHandlers/filterHandler.js +26 -0
- package/DEV-cjs/core/Table/actionHandlers/index.js +37 -0
- package/DEV-cjs/core/Table/actionHandlers/resizeHandler.js +32 -0
- package/DEV-cjs/core/Table/actionHandlers/selectHandler.js +100 -0
- package/DEV-cjs/core/Table/cells/DefaultCell.js +48 -0
- package/DEV-cjs/core/Table/cells/EditableCell.js +67 -0
- package/DEV-cjs/core/Table/cells/index.js +20 -0
- package/DEV-cjs/core/Table/columns/actionColumn.js +81 -0
- package/DEV-cjs/core/Table/columns/expanderColumn.js +57 -0
- package/DEV-cjs/core/Table/columns/index.js +30 -0
- package/DEV-cjs/core/Table/columns/selectionColumn.js +67 -0
- package/DEV-cjs/core/Table/filters/BaseFilter.js +27 -0
- package/DEV-cjs/core/Table/filters/DateRangeFilter/DatePickerInput.js +91 -0
- package/DEV-cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.js +98 -0
- package/DEV-cjs/core/Table/filters/FilterButtonBar.js +38 -0
- package/DEV-cjs/core/Table/filters/FilterToggle.js +60 -0
- package/DEV-cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +65 -0
- package/DEV-cjs/core/Table/filters/TextFilter/TextFilter.js +39 -0
- package/DEV-cjs/core/Table/filters/customFilterFunctions.js +25 -0
- package/DEV-cjs/core/Table/filters/defaultFilterFunctions.js +83 -0
- package/DEV-cjs/core/Table/filters/index.js +28 -0
- package/DEV-cjs/core/Table/filters/tableFilters.js +29 -0
- package/DEV-cjs/core/Table/filters/types.js +4 -0
- package/DEV-cjs/core/Table/hooks/index.js +44 -0
- package/DEV-cjs/core/Table/hooks/useColumnDragAndDrop.js +109 -0
- package/DEV-cjs/core/Table/hooks/useExpanderCell.js +31 -0
- package/DEV-cjs/core/Table/hooks/useResizeColumns.js +269 -0
- package/DEV-cjs/core/Table/hooks/useScrollToRow.js +41 -0
- package/DEV-cjs/core/Table/hooks/useSelectionCell.js +21 -0
- package/DEV-cjs/core/Table/hooks/useStickyColumns.js +57 -0
- package/DEV-cjs/core/Table/hooks/useSubRowFiltering.js +92 -0
- package/DEV-cjs/core/Table/hooks/useSubRowSelection.js +43 -0
- package/DEV-cjs/core/Table/index.js +47 -0
- package/DEV-cjs/core/Table/utils.js +74 -0
- package/DEV-cjs/core/Tabs/Tabs.js +300 -0
- package/DEV-cjs/core/Tag/Tag.js +46 -0
- package/DEV-cjs/core/Tag/TagContainer.js +27 -0
- package/DEV-cjs/core/Textarea/Textarea.js +20 -0
- package/DEV-cjs/core/ThemeProvider/ThemeContext.js +13 -0
- package/DEV-cjs/core/ThemeProvider/ThemeProvider.js +189 -0
- package/DEV-cjs/core/Tile/Tile.js +211 -0
- package/DEV-cjs/core/TimePicker/TimePicker.js +283 -0
- package/DEV-cjs/core/Toast/Toast.js +173 -0
- package/DEV-cjs/core/Toast/Toaster.js +136 -0
- package/DEV-cjs/core/ToggleSwitch/ToggleSwitch.js +46 -0
- package/DEV-cjs/core/Tooltip/Tooltip.js +180 -0
- package/DEV-cjs/core/TransferList/TransferList.js +153 -0
- package/DEV-cjs/core/Tree/Tree.js +198 -0
- package/DEV-cjs/core/Tree/TreeContext.js +26 -0
- package/DEV-cjs/core/Tree/TreeNode.js +153 -0
- package/DEV-cjs/core/Tree/TreeNodeExpander.js +35 -0
- package/DEV-cjs/core/Typography/Anchor.js +31 -0
- package/DEV-cjs/core/Typography/Blockquote.js +25 -0
- package/DEV-cjs/core/Typography/Code.js +13 -0
- package/DEV-cjs/core/Typography/Kbd.js +48 -0
- package/DEV-cjs/core/Typography/Text.js +40 -0
- package/DEV-cjs/core/VisuallyHidden/VisuallyHidden.js +44 -0
- package/DEV-cjs/index.js +481 -0
- package/DEV-cjs/react-table/react-table.js +4 -0
- package/DEV-cjs/react-table/react-table.types-test.js +496 -0
- package/DEV-cjs/styles.js +1 -0
- package/DEV-cjs/utils/color/ColorValue.js +343 -0
- package/DEV-cjs/utils/color/index.js +6 -0
- package/DEV-cjs/utils/components/AutoclearingHiddenLiveRegion.js +29 -0
- package/DEV-cjs/utils/components/Box.js +12 -0
- package/DEV-cjs/utils/components/ButtonBase.js +39 -0
- package/DEV-cjs/utils/components/FieldsetBase.js +12 -0
- package/DEV-cjs/utils/components/FocusTrap.js +48 -0
- package/DEV-cjs/utils/components/InputContainer.js +37 -0
- package/DEV-cjs/utils/components/InputFlexContainer.js +58 -0
- package/DEV-cjs/utils/components/InputWithIcon.js +13 -0
- package/DEV-cjs/utils/components/LineClamp.js +35 -0
- package/DEV-cjs/utils/components/MiddleTextTruncation.js +38 -0
- package/DEV-cjs/utils/components/Portal.js +41 -0
- package/DEV-cjs/utils/components/Resizer.js +226 -0
- package/DEV-cjs/utils/components/ShadowRoot.js +77 -0
- package/DEV-cjs/utils/components/WithCSSTransition.js +53 -0
- package/DEV-cjs/utils/components/index.js +19 -0
- package/DEV-cjs/utils/functions/colors.js +45 -0
- package/DEV-cjs/utils/functions/date.js +18 -0
- package/DEV-cjs/utils/functions/dev.js +31 -0
- package/DEV-cjs/utils/functions/dom.js +47 -0
- package/DEV-cjs/utils/functions/focusable.js +73 -0
- package/DEV-cjs/utils/functions/import.js +27 -0
- package/DEV-cjs/utils/functions/index.js +15 -0
- package/DEV-cjs/utils/functions/numbers.js +32 -0
- package/DEV-cjs/utils/functions/polymorphic.js +48 -0
- package/DEV-cjs/utils/functions/react.js +26 -0
- package/DEV-cjs/utils/functions/supports.js +12 -0
- package/DEV-cjs/utils/hooks/index.js +21 -0
- package/DEV-cjs/utils/hooks/useContainerWidth.js +29 -0
- package/DEV-cjs/utils/hooks/useControlledState.js +30 -0
- package/DEV-cjs/utils/hooks/useDragAndDrop.js +92 -0
- package/DEV-cjs/utils/hooks/useEventListener.js +31 -0
- package/DEV-cjs/utils/hooks/useGlobals.js +51 -0
- package/DEV-cjs/utils/hooks/useId.js +21 -0
- package/DEV-cjs/utils/hooks/useIntersection.js +41 -0
- package/DEV-cjs/utils/hooks/useIsClient.js +19 -0
- package/DEV-cjs/utils/hooks/useIsomorphicLayoutEffect.js +13 -0
- package/DEV-cjs/utils/hooks/useLatestRef.js +21 -0
- package/DEV-cjs/utils/hooks/useMediaQuery.js +26 -0
- package/DEV-cjs/utils/hooks/useMergedRefs.js +29 -0
- package/DEV-cjs/utils/hooks/useOverflow.js +76 -0
- package/DEV-cjs/utils/hooks/useResizeObserver.js +36 -0
- package/DEV-cjs/utils/hooks/useSafeContext.js +17 -0
- package/DEV-cjs/utils/hooks/useSyncExternalStore.js +46 -0
- package/DEV-cjs/utils/hooks/useVirtualScroll.js +38 -0
- package/DEV-cjs/utils/icons/StatusIconMap.js +34 -0
- package/DEV-cjs/utils/icons/Svg.js +16 -0
- package/DEV-cjs/utils/icons/SvgCalendar.js +16 -0
- package/DEV-cjs/utils/icons/SvgCaretDownSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgCaretRightSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgCaretUpSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgCheckmark.js +16 -0
- package/DEV-cjs/utils/icons/SvgCheckmarkSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgChevronLeft.js +16 -0
- package/DEV-cjs/utils/icons/SvgChevronLeftDouble.js +16 -0
- package/DEV-cjs/utils/icons/SvgChevronRight.js +16 -0
- package/DEV-cjs/utils/icons/SvgChevronRightDouble.js +16 -0
- package/DEV-cjs/utils/icons/SvgChevronRightSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgClose.js +16 -0
- package/DEV-cjs/utils/icons/SvgCloseSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgColumnManager.js +16 -0
- package/DEV-cjs/utils/icons/SvgDocument.js +16 -0
- package/DEV-cjs/utils/icons/SvgFilter.js +16 -0
- package/DEV-cjs/utils/icons/SvgFilterHollow.js +16 -0
- package/DEV-cjs/utils/icons/SvgImportantSmall.js +16 -0
- package/DEV-cjs/utils/icons/SvgInfoCircular.js +16 -0
- package/DEV-cjs/utils/icons/SvgMore.js +16 -0
- package/DEV-cjs/utils/icons/SvgMoreVertical.js +16 -0
- package/DEV-cjs/utils/icons/SvgNew.js +16 -0
- package/DEV-cjs/utils/icons/SvgSearch.js +16 -0
- package/DEV-cjs/utils/icons/SvgSmileyHappy.js +16 -0
- package/DEV-cjs/utils/icons/SvgSortDown.js +16 -0
- package/DEV-cjs/utils/icons/SvgSortUp.js +16 -0
- package/DEV-cjs/utils/icons/SvgStatusError.js +16 -0
- package/DEV-cjs/utils/icons/SvgStatusSuccess.js +16 -0
- package/DEV-cjs/utils/icons/SvgStatusWarning.js +16 -0
- package/DEV-cjs/utils/icons/SvgSwap.js +16 -0
- package/DEV-cjs/utils/icons/SvgUpload.js +16 -0
- package/DEV-cjs/utils/icons/index.js +37 -0
- package/DEV-cjs/utils/index.js +13 -0
- package/DEV-cjs/utils/meta.js +16 -0
- package/DEV-cjs/utils/props.js +4 -0
- package/DEV-cjs/utils/providers/HydrationProvider.js +46 -0
- package/DEV-cjs/utils/providers/ScopeProvider.js +64 -0
- package/DEV-cjs/utils/providers/index.js +7 -0
- package/DEV-cjs/utils/types.js +4 -0
- package/DEV-esm/core/Alert/Alert.js +78 -0
- package/DEV-esm/core/Avatar/Avatar.js +35 -0
- package/DEV-esm/core/AvatarGroup/AvatarGroup.js +26 -0
- package/DEV-esm/core/Backdrop/Backdrop.js +14 -0
- package/DEV-esm/core/Badge/Badge.js +36 -0
- package/DEV-esm/core/Breadcrumbs/Breadcrumbs.js +84 -0
- package/DEV-esm/core/ButtonGroup/ButtonGroup.js +71 -0
- package/DEV-esm/core/Buttons/Button.js +42 -0
- package/DEV-esm/core/Buttons/DropdownButton.js +31 -0
- package/DEV-esm/core/Buttons/IconButton.js +34 -0
- package/DEV-esm/core/Buttons/IdeasButton.js +18 -0
- package/DEV-esm/core/Buttons/SplitButton.js +59 -0
- package/DEV-esm/core/Carousel/Carousel.js +62 -0
- package/DEV-esm/core/Carousel/CarouselContext.js +3 -0
- package/DEV-esm/core/Carousel/CarouselDot.js +19 -0
- package/DEV-esm/core/Carousel/CarouselDotsList.js +110 -0
- package/DEV-esm/core/Carousel/CarouselNavigation.js +67 -0
- package/DEV-esm/core/Carousel/CarouselSlide.js +34 -0
- package/DEV-esm/core/Carousel/CarouselSlider.js +53 -0
- package/DEV-esm/core/Checkbox/Checkbox.js +46 -0
- package/DEV-esm/core/ColorPicker/ColorBuilder.js +238 -0
- package/DEV-esm/core/ColorPicker/ColorInputPanel.js +372 -0
- package/DEV-esm/core/ColorPicker/ColorPalette.js +31 -0
- package/DEV-esm/core/ColorPicker/ColorPicker.js +59 -0
- package/DEV-esm/core/ColorPicker/ColorPickerContext.js +7 -0
- package/DEV-esm/core/ColorPicker/ColorSwatch.js +26 -0
- package/DEV-esm/core/ComboBox/ComboBox.js +299 -0
- package/DEV-esm/core/ComboBox/ComboBox.types-test.js +78 -0
- package/DEV-esm/core/ComboBox/ComboBoxEndIcon.js +19 -0
- package/DEV-esm/core/ComboBox/ComboBoxInput.js +122 -0
- package/DEV-esm/core/ComboBox/ComboBoxInputContainer.js +21 -0
- package/DEV-esm/core/ComboBox/ComboBoxMenu.js +89 -0
- package/DEV-esm/core/ComboBox/ComboBoxMenuItem.js +37 -0
- package/DEV-esm/core/ComboBox/ComboBoxMultipleContainer.js +11 -0
- package/DEV-esm/core/ComboBox/helpers.js +5 -0
- package/DEV-esm/core/DatePicker/DatePicker.js +362 -0
- package/DEV-esm/core/Dialog/Dialog.js +53 -0
- package/DEV-esm/core/Dialog/DialogBackdrop.js +31 -0
- package/DEV-esm/core/Dialog/DialogButtonBar.js +3 -0
- package/DEV-esm/core/Dialog/DialogContent.js +3 -0
- package/DEV-esm/core/Dialog/DialogContext.js +3 -0
- package/DEV-esm/core/Dialog/DialogDragContext.js +8 -0
- package/DEV-esm/core/Dialog/DialogMain.js +119 -0
- package/DEV-esm/core/Dialog/DialogTitleBar.js +29 -0
- package/DEV-esm/core/Dialog/DialogTitleBarTitle.js +3 -0
- package/DEV-esm/core/Divider/Divider.js +14 -0
- package/DEV-esm/core/DropdownMenu/DropdownMenu.js +37 -0
- package/DEV-esm/core/ExpandableBlock/ExpandableBlock.js +139 -0
- package/DEV-esm/core/Fieldset/Fieldset.js +15 -0
- package/DEV-esm/core/FileUpload/FileEmptyCard.js +23 -0
- package/DEV-esm/core/FileUpload/FileUpload.js +49 -0
- package/DEV-esm/core/FileUpload/FileUploadCard.js +133 -0
- package/DEV-esm/core/FileUpload/FileUploadTemplate.js +27 -0
- package/DEV-esm/core/Flex/Flex.js +76 -0
- package/DEV-esm/core/Footer/Footer.js +83 -0
- package/DEV-esm/core/Footer/FooterItem.js +3 -0
- package/DEV-esm/core/Footer/FooterList.js +3 -0
- package/DEV-esm/core/Footer/FooterSeparator.js +5 -0
- package/DEV-esm/core/Header/Header.js +38 -0
- package/DEV-esm/core/Header/HeaderBasicButton.js +11 -0
- package/DEV-esm/core/Header/HeaderBreadcrumbs.js +29 -0
- package/DEV-esm/core/Header/HeaderButton.js +40 -0
- package/DEV-esm/core/Header/HeaderDropdownButton.js +36 -0
- package/DEV-esm/core/Header/HeaderLogo.js +22 -0
- package/DEV-esm/core/Header/HeaderSplitButton.js +41 -0
- package/DEV-esm/core/Icon/Icon.js +28 -0
- package/DEV-esm/core/InformationPanel/InformationPanel.js +56 -0
- package/DEV-esm/core/InformationPanel/InformationPanelBody.js +3 -0
- package/DEV-esm/core/InformationPanel/InformationPanelContent.js +14 -0
- package/DEV-esm/core/InformationPanel/InformationPanelHeader.js +24 -0
- package/DEV-esm/core/InformationPanel/InformationPanelWrapper.js +3 -0
- package/DEV-esm/core/Input/Input.js +18 -0
- package/DEV-esm/core/InputGrid/InputGrid.js +113 -0
- package/DEV-esm/core/InputGroup/InputGroup.js +46 -0
- package/DEV-esm/core/InputWithDecorations/InputWithDecorations.js +50 -0
- package/DEV-esm/core/Label/Label.js +17 -0
- package/DEV-esm/core/LabeledInput/LabeledInput.js +37 -0
- package/DEV-esm/core/LabeledSelect/LabeledSelect.js +32 -0
- package/DEV-esm/core/LabeledSelect/LabeledSelect.types-test.js +80 -0
- package/DEV-esm/core/LabeledTextarea/LabeledTextarea.js +9 -0
- package/DEV-esm/core/LinkAction/LinkAction.js +16 -0
- package/DEV-esm/core/List/List.js +5 -0
- package/DEV-esm/core/List/ListItem.js +33 -0
- package/DEV-esm/core/Menu/Menu.js +120 -0
- package/DEV-esm/core/Menu/MenuDivider.js +5 -0
- package/DEV-esm/core/Menu/MenuExtraContent.js +5 -0
- package/DEV-esm/core/Menu/MenuItem.js +70 -0
- package/DEV-esm/core/Menu/MenuItemSkeleton.js +32 -0
- package/DEV-esm/core/Modal/Modal.js +25 -0
- package/DEV-esm/core/Modal/ModalButtonBar.js +3 -0
- package/DEV-esm/core/Modal/ModalContent.js +3 -0
- package/DEV-esm/core/NonIdealState/ErrorPage.js +122 -0
- package/DEV-esm/core/NonIdealState/NonIdealState.js +28 -0
- package/DEV-esm/core/NotificationMarker/NotificationMarker.js +17 -0
- package/DEV-esm/core/Overlay/Overlay.js +41 -0
- package/DEV-esm/core/Popover/Popover.js +186 -0
- package/DEV-esm/core/ProgressIndicators/ProgressLinear.js +26 -0
- package/DEV-esm/core/ProgressIndicators/ProgressRadial.js +33 -0
- package/DEV-esm/core/Radio/Radio.js +30 -0
- package/DEV-esm/core/RadioTiles/RadioTile.js +35 -0
- package/DEV-esm/core/RadioTiles/RadioTileGroup.js +14 -0
- package/DEV-esm/core/SearchBox/SearchBox.js +142 -0
- package/DEV-esm/core/Select/Select.js +288 -0
- package/DEV-esm/core/Select/Select.types-test.js +86 -0
- package/DEV-esm/core/Select/SelectTag.js +15 -0
- package/DEV-esm/core/Select/SelectTagContainer.js +16 -0
- package/DEV-esm/core/SideNavigation/SideNavigation.js +54 -0
- package/DEV-esm/core/SideNavigation/SidenavButton.js +25 -0
- package/DEV-esm/core/SideNavigation/SidenavSubmenu.js +14 -0
- package/DEV-esm/core/SideNavigation/SidenavSubmenuHeader.js +16 -0
- package/DEV-esm/core/SkipToContentLink/SkipToContentLink.js +13 -0
- package/DEV-esm/core/Slider/Slider.js +269 -0
- package/DEV-esm/core/Slider/Thumb.js +90 -0
- package/DEV-esm/core/Slider/Track.js +58 -0
- package/DEV-esm/core/StatusMessage/StatusMessage.js +19 -0
- package/DEV-esm/core/Stepper/Stepper.js +44 -0
- package/DEV-esm/core/Stepper/StepperStep.js +52 -0
- package/DEV-esm/core/Stepper/WorkflowDiagram.js +25 -0
- package/DEV-esm/core/Stepper/WorkflowDiagramStep.js +20 -0
- package/DEV-esm/core/Surface/Surface.js +82 -0
- package/DEV-esm/core/Table/SubRowExpander.js +26 -0
- package/DEV-esm/core/Table/Table.js +518 -0
- package/DEV-esm/core/Table/TableCell.js +57 -0
- package/DEV-esm/core/Table/TablePaginator.js +176 -0
- package/DEV-esm/core/Table/TableRowMemoized.js +79 -0
- package/DEV-esm/core/Table/actionHandlers/expandHandler.js +11 -0
- package/DEV-esm/core/Table/actionHandlers/filterHandler.js +16 -0
- package/DEV-esm/core/Table/actionHandlers/index.js +4 -0
- package/DEV-esm/core/Table/actionHandlers/resizeHandler.js +14 -0
- package/DEV-esm/core/Table/actionHandlers/selectHandler.js +79 -0
- package/DEV-esm/core/Table/cells/DefaultCell.js +36 -0
- package/DEV-esm/core/Table/cells/EditableCell.js +55 -0
- package/DEV-esm/core/Table/cells/index.js +2 -0
- package/DEV-esm/core/Table/columns/actionColumn.js +70 -0
- package/DEV-esm/core/Table/columns/expanderColumn.js +38 -0
- package/DEV-esm/core/Table/columns/index.js +3 -0
- package/DEV-esm/core/Table/columns/selectionColumn.js +48 -0
- package/DEV-esm/core/Table/filters/BaseFilter.js +15 -0
- package/DEV-esm/core/Table/filters/DateRangeFilter/DatePickerInput.js +80 -0
- package/DEV-esm/core/Table/filters/DateRangeFilter/DateRangeFilter.js +87 -0
- package/DEV-esm/core/Table/filters/FilterButtonBar.js +26 -0
- package/DEV-esm/core/Table/filters/FilterToggle.js +48 -0
- package/DEV-esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +54 -0
- package/DEV-esm/core/Table/filters/TextFilter/TextFilter.js +28 -0
- package/DEV-esm/core/Table/filters/customFilterFunctions.js +15 -0
- package/DEV-esm/core/Table/filters/defaultFilterFunctions.js +73 -0
- package/DEV-esm/core/Table/filters/index.js +4 -0
- package/DEV-esm/core/Table/filters/tableFilters.js +18 -0
- package/DEV-esm/core/Table/filters/types.js +1 -0
- package/DEV-esm/core/Table/hooks/index.js +8 -0
- package/DEV-esm/core/Table/hooks/useColumnDragAndDrop.js +99 -0
- package/DEV-esm/core/Table/hooks/useExpanderCell.js +20 -0
- package/DEV-esm/core/Table/hooks/useResizeColumns.js +259 -0
- package/DEV-esm/core/Table/hooks/useScrollToRow.js +30 -0
- package/DEV-esm/core/Table/hooks/useSelectionCell.js +11 -0
- package/DEV-esm/core/Table/hooks/useStickyColumns.js +47 -0
- package/DEV-esm/core/Table/hooks/useSubRowFiltering.js +81 -0
- package/DEV-esm/core/Table/hooks/useSubRowSelection.js +32 -0
- package/DEV-esm/core/Table/index.js +5 -0
- package/DEV-esm/core/Table/utils.js +49 -0
- package/DEV-esm/core/Tabs/Tabs.js +281 -0
- package/DEV-esm/core/Tag/Tag.js +34 -0
- package/DEV-esm/core/Tag/TagContainer.js +15 -0
- package/DEV-esm/core/Textarea/Textarea.js +9 -0
- package/DEV-esm/core/ThemeProvider/ThemeContext.js +2 -0
- package/DEV-esm/core/ThemeProvider/ThemeProvider.js +177 -0
- package/DEV-esm/core/Tile/Tile.js +199 -0
- package/DEV-esm/core/TimePicker/TimePicker.js +271 -0
- package/DEV-esm/core/Toast/Toast.js +153 -0
- package/DEV-esm/core/Toast/Toaster.js +110 -0
- package/DEV-esm/core/ToggleSwitch/ToggleSwitch.js +34 -0
- package/DEV-esm/core/Tooltip/Tooltip.js +168 -0
- package/DEV-esm/core/TransferList/TransferList.js +133 -0
- package/DEV-esm/core/Tree/Tree.js +187 -0
- package/DEV-esm/core/Tree/TreeContext.js +7 -0
- package/DEV-esm/core/Tree/TreeNode.js +141 -0
- package/DEV-esm/core/Tree/TreeNodeExpander.js +23 -0
- package/DEV-esm/core/Typography/Anchor.js +19 -0
- package/DEV-esm/core/Typography/Blockquote.js +13 -0
- package/DEV-esm/core/Typography/Code.js +3 -0
- package/DEV-esm/core/Typography/Kbd.js +28 -0
- package/DEV-esm/core/Typography/Text.js +20 -0
- package/DEV-esm/core/VisuallyHidden/VisuallyHidden.js +32 -0
- package/DEV-esm/index.js +106 -0
- package/DEV-esm/react-table/react-table.js +1 -0
- package/DEV-esm/react-table/react-table.types-test.js +491 -0
- package/DEV-esm/styles.js +17 -0
- package/DEV-esm/utils/color/ColorValue.js +319 -0
- package/DEV-esm/utils/color/index.js +1 -0
- package/DEV-esm/utils/components/AutoclearingHiddenLiveRegion.js +18 -0
- package/DEV-esm/utils/components/Box.js +2 -0
- package/DEV-esm/utils/components/ButtonBase.js +27 -0
- package/DEV-esm/utils/components/FieldsetBase.js +2 -0
- package/DEV-esm/utils/components/FocusTrap.js +37 -0
- package/DEV-esm/utils/components/InputContainer.js +25 -0
- package/DEV-esm/utils/components/InputFlexContainer.js +35 -0
- package/DEV-esm/utils/components/InputWithIcon.js +3 -0
- package/DEV-esm/utils/components/LineClamp.js +24 -0
- package/DEV-esm/utils/components/MiddleTextTruncation.js +27 -0
- package/DEV-esm/utils/components/Portal.js +19 -0
- package/DEV-esm/utils/components/Resizer.js +215 -0
- package/DEV-esm/utils/components/ShadowRoot.js +66 -0
- package/DEV-esm/utils/components/WithCSSTransition.js +42 -0
- package/DEV-esm/utils/components/index.js +14 -0
- package/DEV-esm/utils/functions/colors.js +24 -0
- package/DEV-esm/utils/functions/date.js +8 -0
- package/DEV-esm/utils/functions/dev.js +14 -0
- package/DEV-esm/utils/functions/dom.js +20 -0
- package/DEV-esm/utils/functions/focusable.js +51 -0
- package/DEV-esm/utils/functions/import.js +17 -0
- package/DEV-esm/utils/functions/index.js +10 -0
- package/DEV-esm/utils/functions/numbers.js +11 -0
- package/DEV-esm/utils/functions/polymorphic.js +36 -0
- package/DEV-esm/utils/functions/react.js +15 -0
- package/DEV-esm/utils/functions/supports.js +2 -0
- package/DEV-esm/utils/hooks/index.js +16 -0
- package/DEV-esm/utils/hooks/useContainerWidth.js +18 -0
- package/DEV-esm/utils/hooks/useControlledState.js +19 -0
- package/DEV-esm/utils/hooks/useDragAndDrop.js +81 -0
- package/DEV-esm/utils/hooks/useEventListener.js +20 -0
- package/DEV-esm/utils/hooks/useGlobals.js +32 -0
- package/DEV-esm/utils/hooks/useId.js +10 -0
- package/DEV-esm/utils/hooks/useIntersection.js +30 -0
- package/DEV-esm/utils/hooks/useIsClient.js +8 -0
- package/DEV-esm/utils/hooks/useIsomorphicLayoutEffect.js +3 -0
- package/DEV-esm/utils/hooks/useLatestRef.js +10 -0
- package/DEV-esm/utils/hooks/useMediaQuery.js +15 -0
- package/DEV-esm/utils/hooks/useMergedRefs.js +10 -0
- package/DEV-esm/utils/hooks/useOverflow.js +65 -0
- package/DEV-esm/utils/hooks/useResizeObserver.js +25 -0
- package/DEV-esm/utils/hooks/useSafeContext.js +6 -0
- package/DEV-esm/utils/hooks/useSyncExternalStore.js +35 -0
- package/DEV-esm/utils/hooks/useVirtualScroll.js +27 -0
- package/DEV-esm/utils/icons/StatusIconMap.js +23 -0
- package/DEV-esm/utils/icons/Svg.js +6 -0
- package/DEV-esm/utils/icons/SvgCalendar.js +5 -0
- package/DEV-esm/utils/icons/SvgCaretDownSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgCaretRightSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgCaretUpSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgCheckmark.js +5 -0
- package/DEV-esm/utils/icons/SvgCheckmarkSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgChevronLeft.js +5 -0
- package/DEV-esm/utils/icons/SvgChevronLeftDouble.js +5 -0
- package/DEV-esm/utils/icons/SvgChevronRight.js +5 -0
- package/DEV-esm/utils/icons/SvgChevronRightDouble.js +5 -0
- package/DEV-esm/utils/icons/SvgChevronRightSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgClose.js +5 -0
- package/DEV-esm/utils/icons/SvgCloseSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgColumnManager.js +5 -0
- package/DEV-esm/utils/icons/SvgDocument.js +5 -0
- package/DEV-esm/utils/icons/SvgFilter.js +5 -0
- package/DEV-esm/utils/icons/SvgFilterHollow.js +5 -0
- package/DEV-esm/utils/icons/SvgImportantSmall.js +5 -0
- package/DEV-esm/utils/icons/SvgInfoCircular.js +5 -0
- package/DEV-esm/utils/icons/SvgMore.js +5 -0
- package/DEV-esm/utils/icons/SvgMoreVertical.js +5 -0
- package/DEV-esm/utils/icons/SvgNew.js +5 -0
- package/DEV-esm/utils/icons/SvgSearch.js +5 -0
- package/DEV-esm/utils/icons/SvgSmileyHappy.js +5 -0
- package/DEV-esm/utils/icons/SvgSortDown.js +5 -0
- package/DEV-esm/utils/icons/SvgSortUp.js +5 -0
- package/DEV-esm/utils/icons/SvgStatusError.js +5 -0
- package/DEV-esm/utils/icons/SvgStatusSuccess.js +5 -0
- package/DEV-esm/utils/icons/SvgStatusWarning.js +5 -0
- package/DEV-esm/utils/icons/SvgSwap.js +5 -0
- package/DEV-esm/utils/icons/SvgUpload.js +5 -0
- package/DEV-esm/utils/icons/index.js +32 -0
- package/DEV-esm/utils/index.js +8 -0
- package/DEV-esm/utils/meta.js +6 -0
- package/DEV-esm/utils/props.js +1 -0
- package/DEV-esm/utils/providers/HydrationProvider.js +27 -0
- package/DEV-esm/utils/providers/ScopeProvider.js +42 -0
- package/DEV-esm/utils/providers/index.js +2 -0
- package/DEV-esm/utils/types.js +1 -0
- package/cjs/core/Alert/Alert.js +11 -17
- package/cjs/core/Avatar/Avatar.js +5 -7
- package/cjs/core/AvatarGroup/AvatarGroup.js +8 -9
- package/cjs/core/Backdrop/Backdrop.js +1 -1
- package/cjs/core/Badge/Badge.js +8 -10
- package/cjs/core/Breadcrumbs/Breadcrumbs.js +14 -20
- package/cjs/core/ButtonGroup/ButtonGroup.js +18 -24
- package/cjs/core/Buttons/Button.js +7 -7
- package/cjs/core/Buttons/DropdownButton.js +2 -2
- package/cjs/core/Buttons/IconButton.js +7 -7
- package/cjs/core/Buttons/IdeasButton.js +1 -1
- package/cjs/core/Buttons/SplitButton.js +9 -12
- package/cjs/core/Carousel/Carousel.js +10 -10
- package/cjs/core/Carousel/CarouselContext.js +1 -1
- package/cjs/core/Carousel/CarouselDot.js +1 -1
- package/cjs/core/Carousel/CarouselDotsList.js +59 -68
- package/cjs/core/Carousel/CarouselNavigation.js +9 -11
- package/cjs/core/Carousel/CarouselSlide.js +11 -15
- package/cjs/core/Carousel/CarouselSlider.js +13 -19
- package/cjs/core/Checkbox/Checkbox.js +13 -14
- package/cjs/core/ColorPicker/ColorBuilder.js +44 -57
- package/cjs/core/ColorPicker/ColorInputPanel.js +65 -92
- package/cjs/core/ColorPicker/ColorPalette.js +3 -3
- package/cjs/core/ColorPicker/ColorPicker.js +11 -19
- package/cjs/core/ColorPicker/ColorPickerContext.js +3 -4
- package/cjs/core/ColorPicker/ColorSwatch.js +5 -5
- package/cjs/core/ComboBox/ComboBox.js +80 -115
- package/cjs/core/ComboBox/ComboBox.types-test.js +14 -17
- package/cjs/core/ComboBox/ComboBoxEndIcon.js +1 -2
- package/cjs/core/ComboBox/ComboBoxInput.js +39 -68
- package/cjs/core/ComboBox/ComboBoxInputContainer.js +3 -4
- package/cjs/core/ComboBox/ComboBoxMenu.js +76 -44
- package/cjs/core/ComboBox/ComboBoxMenuItem.js +7 -9
- package/cjs/core/ComboBox/ComboBoxMultipleContainer.js +1 -2
- package/cjs/core/ComboBox/helpers.js +2 -4
- package/cjs/core/DatePicker/DatePicker.js +132 -167
- package/cjs/core/Dialog/Dialog.js +3 -3
- package/cjs/core/Dialog/DialogBackdrop.js +8 -12
- package/cjs/core/Dialog/DialogContext.js +2 -4
- package/cjs/core/Dialog/DialogDragContext.js +2 -2
- package/cjs/core/Dialog/DialogMain.js +26 -40
- package/cjs/core/Dialog/DialogTitleBar.js +3 -3
- package/cjs/core/Dialog/DialogTitleBarTitle.d.ts +3 -1
- package/cjs/core/Divider/Divider.js +2 -2
- package/cjs/core/DropdownMenu/DropdownMenu.js +10 -15
- package/cjs/core/ExpandableBlock/ExpandableBlock.js +21 -37
- package/cjs/core/Fieldset/Fieldset.js +2 -3
- package/cjs/core/FileUpload/FileEmptyCard.js +1 -1
- package/cjs/core/FileUpload/FileUpload.js +8 -10
- package/cjs/core/FileUpload/FileUploadCard.js +25 -40
- package/cjs/core/FileUpload/FileUploadTemplate.js +1 -1
- package/cjs/core/Flex/Flex.js +7 -12
- package/cjs/core/Footer/Footer.js +10 -11
- package/cjs/core/Header/Header.js +3 -3
- package/cjs/core/Header/HeaderBasicButton.js +1 -3
- package/cjs/core/Header/HeaderBreadcrumbs.js +1 -1
- package/cjs/core/Header/HeaderButton.js +7 -7
- package/cjs/core/Header/HeaderDropdownButton.js +6 -8
- package/cjs/core/Header/HeaderLogo.js +3 -3
- package/cjs/core/Header/HeaderSplitButton.js +5 -7
- package/cjs/core/Icon/Icon.js +2 -2
- package/cjs/core/InformationPanel/InformationPanel.js +25 -33
- package/cjs/core/InformationPanel/InformationPanelContent.js +2 -2
- package/cjs/core/InformationPanel/InformationPanelHeader.js +1 -1
- package/cjs/core/Input/Input.js +3 -3
- package/cjs/core/InputGrid/InputGrid.js +40 -71
- package/cjs/core/InputGroup/InputGroup.js +5 -8
- package/cjs/core/InputWithDecorations/InputWithDecorations.js +6 -9
- package/cjs/core/Label/Label.js +3 -3
- package/cjs/core/LabeledInput/LabeledInput.js +4 -4
- package/cjs/core/LabeledSelect/LabeledSelect.js +4 -6
- package/cjs/core/LabeledSelect/LabeledSelect.types-test.js +11 -14
- package/cjs/core/LabeledTextarea/LabeledTextarea.js +4 -4
- package/cjs/core/LinkAction/LinkAction.js +1 -3
- package/cjs/core/List/List.js +0 -1
- package/cjs/core/List/ListItem.js +6 -11
- package/cjs/core/Menu/Menu.js +32 -38
- package/cjs/core/Menu/MenuItem.js +18 -24
- package/cjs/core/Menu/MenuItemSkeleton.js +2 -4
- package/cjs/core/Modal/Modal.js +1 -1
- package/cjs/core/NonIdealState/ErrorPage.js +26 -52
- package/cjs/core/NonIdealState/NonIdealState.js +1 -1
- package/cjs/core/NotificationMarker/NotificationMarker.js +1 -1
- package/cjs/core/Overlay/Overlay.js +10 -12
- package/cjs/core/Popover/Popover.js +35 -41
- package/cjs/core/ProgressIndicators/ProgressLinear.js +6 -6
- package/cjs/core/ProgressIndicators/ProgressRadial.js +7 -9
- package/cjs/core/Radio/Radio.js +8 -8
- package/cjs/core/RadioTiles/RadioTile.js +4 -4
- package/cjs/core/RadioTiles/RadioTileGroup.js +1 -1
- package/cjs/core/SearchBox/SearchBox.js +24 -42
- package/cjs/core/Select/Select.js +130 -142
- package/cjs/core/Select/Select.types-test.js +13 -17
- package/cjs/core/Select/SelectTag.js +1 -1
- package/cjs/core/Select/SelectTagContainer.js +3 -3
- package/cjs/core/SideNavigation/SideNavigation.js +6 -6
- package/cjs/core/SideNavigation/SidenavButton.js +8 -8
- package/cjs/core/SideNavigation/SidenavSubmenu.js +1 -1
- package/cjs/core/SideNavigation/SidenavSubmenuHeader.js +1 -1
- package/cjs/core/SkipToContentLink/SkipToContentLink.js +1 -1
- package/cjs/core/Slider/Slider.js +58 -83
- package/cjs/core/Slider/Thumb.js +13 -21
- package/cjs/core/Slider/Track.js +10 -14
- package/cjs/core/StatusMessage/StatusMessage.js +3 -3
- package/cjs/core/Stepper/Stepper.js +8 -8
- package/cjs/core/Stepper/StepperStep.js +15 -22
- package/cjs/core/Stepper/WorkflowDiagram.js +2 -2
- package/cjs/core/Stepper/WorkflowDiagramStep.js +2 -2
- package/cjs/core/Surface/Surface.d.ts +1 -0
- package/cjs/core/Surface/Surface.js +15 -24
- package/cjs/core/Table/SubRowExpander.js +3 -3
- package/cjs/core/Table/Table.d.ts +4 -1
- package/cjs/core/Table/Table.js +256 -244
- package/cjs/core/Table/TableCell.js +12 -14
- package/cjs/core/Table/TablePaginator.js +38 -55
- package/cjs/core/Table/TableRowMemoized.d.ts +3 -0
- package/cjs/core/Table/TableRowMemoized.js +43 -35
- package/cjs/core/Table/actionHandlers/expandHandler.js +2 -4
- package/cjs/core/Table/actionHandlers/filterHandler.js +3 -3
- package/cjs/core/Table/actionHandlers/resizeHandler.js +13 -17
- package/cjs/core/Table/actionHandlers/selectHandler.js +20 -29
- package/cjs/core/Table/cells/DefaultCell.d.ts +4 -1
- package/cjs/core/Table/cells/DefaultCell.js +5 -5
- package/cjs/core/Table/cells/EditableCell.d.ts +4 -1
- package/cjs/core/Table/cells/EditableCell.js +7 -13
- package/cjs/core/Table/columns/actionColumn.d.ts +2 -2
- package/cjs/core/Table/columns/actionColumn.js +79 -88
- package/cjs/core/Table/columns/expanderColumn.js +4 -6
- package/cjs/core/Table/columns/selectionColumn.js +8 -10
- package/cjs/core/Table/filters/BaseFilter.js +1 -1
- package/cjs/core/Table/filters/DateRangeFilter/DatePickerInput.js +16 -25
- package/cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.js +17 -29
- package/cjs/core/Table/filters/FilterButtonBar.js +2 -2
- package/cjs/core/Table/filters/FilterToggle.js +8 -8
- package/cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +11 -17
- package/cjs/core/Table/filters/TextFilter/TextFilter.js +7 -13
- package/cjs/core/Table/filters/customFilterFunctions.js +11 -12
- package/cjs/core/Table/filters/defaultFilterFunctions.js +69 -78
- package/cjs/core/Table/hooks/useColumnDragAndDrop.js +20 -26
- package/cjs/core/Table/hooks/useExpanderCell.js +4 -8
- package/cjs/core/Table/hooks/useResizeColumns.js +63 -100
- package/cjs/core/Table/hooks/useScrollToRow.js +13 -20
- package/cjs/core/Table/hooks/useSelectionCell.js +2 -4
- package/cjs/core/Table/hooks/useStickyColumns.js +10 -23
- package/cjs/core/Table/hooks/useSubRowFiltering.js +20 -34
- package/cjs/core/Table/hooks/useSubRowSelection.js +4 -5
- package/cjs/core/Table/utils.js +18 -31
- package/cjs/core/Tabs/Tabs.js +70 -102
- package/cjs/core/Tag/Tag.js +8 -8
- package/cjs/core/Tag/TagContainer.js +2 -2
- package/cjs/core/Textarea/Textarea.js +4 -4
- package/cjs/core/ThemeProvider/ThemeContext.js +1 -1
- package/cjs/core/ThemeProvider/ThemeProvider.js +60 -56
- package/cjs/core/Tile/Tile.js +27 -52
- package/cjs/core/TimePicker/TimePicker.js +82 -111
- package/cjs/core/Toast/Toast.js +30 -39
- package/cjs/core/Toast/Toaster.js +19 -25
- package/cjs/core/ToggleSwitch/ToggleSwitch.js +5 -5
- package/cjs/core/Tooltip/Tooltip.js +30 -39
- package/cjs/core/TransferList/TransferList.js +33 -51
- package/cjs/core/Tree/Tree.d.ts +4 -1
- package/cjs/core/Tree/Tree.js +97 -77
- package/cjs/core/Tree/TreeContext.js +3 -4
- package/cjs/core/Tree/TreeNode.d.ts +2 -2
- package/cjs/core/Tree/TreeNode.js +22 -37
- package/cjs/core/Tree/TreeNodeExpander.js +4 -4
- package/cjs/core/Typography/Anchor.js +4 -4
- package/cjs/core/Typography/Blockquote.js +1 -1
- package/cjs/core/Typography/Kbd.js +1 -1
- package/cjs/core/Typography/Text.js +3 -3
- package/cjs/core/VisuallyHidden/VisuallyHidden.js +7 -7
- package/cjs/react-table/react-table.types-test.js +110 -115
- package/cjs/styles.js +5 -5
- package/cjs/utils/color/ColorValue.js +114 -161
- package/cjs/utils/components/AutoclearingHiddenLiveRegion.js +2 -2
- package/cjs/utils/components/ButtonBase.js +10 -13
- package/cjs/utils/components/FieldsetBase.d.ts +6 -0
- package/cjs/utils/components/FieldsetBase.js +12 -0
- package/cjs/utils/components/FocusTrap.js +14 -20
- package/cjs/utils/components/InputContainer.js +3 -3
- package/cjs/utils/components/InputFlexContainer.js +4 -5
- package/cjs/utils/components/InputWithIcon.js +0 -1
- package/cjs/utils/components/LineClamp.js +1 -1
- package/cjs/utils/components/MiddleTextTruncation.d.ts +4 -1
- package/cjs/utils/components/MiddleTextTruncation.js +5 -7
- package/cjs/utils/components/Portal.js +8 -12
- package/cjs/utils/components/Resizer.js +33 -49
- package/cjs/utils/components/ShadowRoot.js +19 -28
- package/cjs/utils/components/WithCSSTransition.js +4 -5
- package/cjs/utils/components/index.d.ts +1 -1
- package/cjs/utils/components/index.js +1 -1
- package/cjs/utils/functions/colors.js +4 -5
- package/cjs/utils/functions/date.js +3 -5
- package/cjs/utils/functions/dev.d.ts +11 -5
- package/cjs/utils/functions/dev.js +6 -23
- package/cjs/utils/functions/dom.js +7 -16
- package/cjs/utils/functions/focusable.js +18 -22
- package/cjs/utils/functions/import.js +1 -1
- package/cjs/utils/functions/numbers.js +5 -8
- package/cjs/utils/functions/polymorphic.js +31 -43
- package/cjs/utils/functions/react.js +4 -8
- package/cjs/utils/hooks/index.d.ts +1 -0
- package/cjs/utils/hooks/index.js +1 -0
- package/cjs/utils/hooks/useContainerWidth.js +8 -12
- package/cjs/utils/hooks/useControlledState.js +4 -5
- package/cjs/utils/hooks/useDragAndDrop.js +31 -42
- package/cjs/utils/hooks/useEventListener.js +3 -5
- package/cjs/utils/hooks/useGlobals.js +3 -22
- package/cjs/utils/hooks/useId.js +1 -1
- package/cjs/utils/hooks/useIntersection.js +6 -10
- package/cjs/utils/hooks/useIsClient.js +1 -1
- package/cjs/utils/hooks/useIsomorphicLayoutEffect.js +1 -1
- package/cjs/utils/hooks/useLatestRef.js +1 -1
- package/cjs/utils/hooks/useMediaQuery.js +10 -8
- package/cjs/utils/hooks/useMergedRefs.js +7 -11
- package/cjs/utils/hooks/useOverflow.js +23 -25
- package/cjs/utils/hooks/useResizeObserver.js +5 -9
- package/cjs/utils/hooks/useSafeContext.js +3 -4
- package/cjs/utils/hooks/useSyncExternalStore.js +5 -7
- package/cjs/utils/hooks/useVirtualScroll.d.ts +14 -0
- package/cjs/utils/hooks/useVirtualScroll.js +39 -0
- package/cjs/utils/icons/SvgCalendar.js +2 -3
- package/cjs/utils/icons/SvgCaretDownSmall.js +2 -3
- package/cjs/utils/icons/SvgCaretRightSmall.js +2 -3
- package/cjs/utils/icons/SvgCaretUpSmall.js +2 -3
- package/cjs/utils/icons/SvgCheckmark.js +2 -3
- package/cjs/utils/icons/SvgCheckmarkSmall.js +2 -3
- package/cjs/utils/icons/SvgChevronLeft.js +2 -3
- package/cjs/utils/icons/SvgChevronLeftDouble.js +2 -3
- package/cjs/utils/icons/SvgChevronRight.js +2 -3
- package/cjs/utils/icons/SvgChevronRightDouble.js +2 -3
- package/cjs/utils/icons/SvgChevronRightSmall.js +2 -3
- package/cjs/utils/icons/SvgClose.js +2 -3
- package/cjs/utils/icons/SvgCloseSmall.js +2 -3
- package/cjs/utils/icons/SvgColumnManager.js +2 -3
- package/cjs/utils/icons/SvgDocument.js +2 -3
- package/cjs/utils/icons/SvgFilter.js +2 -3
- package/cjs/utils/icons/SvgFilterHollow.js +2 -3
- package/cjs/utils/icons/SvgImportantSmall.js +2 -3
- package/cjs/utils/icons/SvgInfoCircular.js +2 -3
- package/cjs/utils/icons/SvgMore.js +2 -3
- package/cjs/utils/icons/SvgMoreVertical.js +2 -3
- package/cjs/utils/icons/SvgNew.js +2 -3
- package/cjs/utils/icons/SvgSearch.js +2 -3
- package/cjs/utils/icons/SvgSmileyHappy.js +2 -3
- package/cjs/utils/icons/SvgSortDown.js +2 -3
- package/cjs/utils/icons/SvgSortUp.js +2 -3
- package/cjs/utils/icons/SvgStatusError.js +2 -3
- package/cjs/utils/icons/SvgStatusSuccess.js +2 -3
- package/cjs/utils/icons/SvgStatusWarning.js +2 -3
- package/cjs/utils/icons/SvgSwap.js +2 -3
- package/cjs/utils/icons/SvgUpload.js +2 -3
- package/cjs/utils/meta.js +1 -1
- package/cjs/utils/providers/HydrationProvider.js +12 -16
- package/cjs/utils/providers/ScopeProvider.js +8 -10
- package/esm/core/Alert/Alert.js +17 -23
- package/esm/core/Avatar/Avatar.js +6 -8
- package/esm/core/AvatarGroup/AvatarGroup.js +8 -9
- package/esm/core/Backdrop/Backdrop.js +1 -1
- package/esm/core/Badge/Badge.js +10 -12
- package/esm/core/Breadcrumbs/Breadcrumbs.js +18 -24
- package/esm/core/ButtonGroup/ButtonGroup.js +20 -26
- package/esm/core/Buttons/Button.js +7 -7
- package/esm/core/Buttons/DropdownButton.js +2 -2
- package/esm/core/Buttons/IconButton.js +7 -7
- package/esm/core/Buttons/IdeasButton.js +1 -1
- package/esm/core/Buttons/SplitButton.js +9 -12
- package/esm/core/Carousel/Carousel.js +11 -11
- package/esm/core/Carousel/CarouselContext.js +1 -1
- package/esm/core/Carousel/CarouselDot.js +1 -1
- package/esm/core/Carousel/CarouselDotsList.js +59 -68
- package/esm/core/Carousel/CarouselNavigation.js +12 -14
- package/esm/core/Carousel/CarouselSlide.js +11 -15
- package/esm/core/Carousel/CarouselSlider.js +13 -20
- package/esm/core/Checkbox/Checkbox.js +13 -14
- package/esm/core/ColorPicker/ColorBuilder.js +46 -59
- package/esm/core/ColorPicker/ColorInputPanel.js +65 -92
- package/esm/core/ColorPicker/ColorPalette.js +3 -3
- package/esm/core/ColorPicker/ColorPicker.js +11 -18
- package/esm/core/ColorPicker/ColorPickerContext.js +3 -4
- package/esm/core/ColorPicker/ColorSwatch.js +5 -7
- package/esm/core/ComboBox/ComboBox.js +80 -115
- package/esm/core/ComboBox/ComboBox.types-test.js +14 -17
- package/esm/core/ComboBox/ComboBoxEndIcon.js +1 -2
- package/esm/core/ComboBox/ComboBoxInput.js +39 -68
- package/esm/core/ComboBox/ComboBoxInputContainer.js +3 -4
- package/esm/core/ComboBox/ComboBoxMenu.js +80 -45
- package/esm/core/ComboBox/ComboBoxMenuItem.js +7 -9
- package/esm/core/ComboBox/ComboBoxMultipleContainer.js +1 -2
- package/esm/core/ComboBox/helpers.js +2 -4
- package/esm/core/DatePicker/DatePicker.js +136 -171
- package/esm/core/Dialog/Dialog.js +4 -4
- package/esm/core/Dialog/DialogBackdrop.js +8 -12
- package/esm/core/Dialog/DialogContext.js +2 -4
- package/esm/core/Dialog/DialogDragContext.js +2 -2
- package/esm/core/Dialog/DialogMain.js +26 -40
- package/esm/core/Dialog/DialogTitleBar.js +3 -3
- package/esm/core/Dialog/DialogTitleBarTitle.d.ts +3 -1
- package/esm/core/Divider/Divider.js +2 -2
- package/esm/core/DropdownMenu/DropdownMenu.js +11 -16
- package/esm/core/ExpandableBlock/ExpandableBlock.js +30 -42
- package/esm/core/Fieldset/Fieldset.js +3 -4
- package/esm/core/FileUpload/FileEmptyCard.js +4 -4
- package/esm/core/FileUpload/FileUpload.js +8 -10
- package/esm/core/FileUpload/FileUploadCard.js +35 -50
- package/esm/core/FileUpload/FileUploadTemplate.js +1 -1
- package/esm/core/Flex/Flex.js +12 -17
- package/esm/core/Footer/Footer.js +11 -12
- package/esm/core/Header/Header.js +4 -4
- package/esm/core/Header/HeaderBasicButton.js +1 -3
- package/esm/core/Header/HeaderBreadcrumbs.js +1 -1
- package/esm/core/Header/HeaderButton.js +7 -7
- package/esm/core/Header/HeaderDropdownButton.js +6 -8
- package/esm/core/Header/HeaderLogo.js +3 -3
- package/esm/core/Header/HeaderSplitButton.js +5 -7
- package/esm/core/Icon/Icon.js +3 -3
- package/esm/core/InformationPanel/InformationPanel.js +25 -33
- package/esm/core/InformationPanel/InformationPanelContent.js +2 -2
- package/esm/core/InformationPanel/InformationPanelHeader.js +1 -1
- package/esm/core/Input/Input.js +3 -3
- package/esm/core/InputGrid/InputGrid.js +43 -75
- package/esm/core/InputGroup/InputGroup.js +6 -9
- package/esm/core/InputWithDecorations/InputWithDecorations.js +10 -13
- package/esm/core/Label/Label.js +3 -3
- package/esm/core/LabeledInput/LabeledInput.js +4 -4
- package/esm/core/LabeledSelect/LabeledSelect.js +4 -6
- package/esm/core/LabeledSelect/LabeledSelect.types-test.js +11 -14
- package/esm/core/LabeledTextarea/LabeledTextarea.js +4 -4
- package/esm/core/LinkAction/LinkAction.js +1 -3
- package/esm/core/List/List.js +0 -1
- package/esm/core/List/ListItem.js +11 -16
- package/esm/core/Menu/Menu.js +40 -48
- package/esm/core/Menu/MenuItem.js +18 -24
- package/esm/core/Menu/MenuItemSkeleton.js +2 -4
- package/esm/core/Modal/Modal.js +1 -1
- package/esm/core/NonIdealState/ErrorPage.js +35 -61
- package/esm/core/NonIdealState/NonIdealState.js +1 -1
- package/esm/core/NotificationMarker/NotificationMarker.js +1 -1
- package/esm/core/Overlay/Overlay.js +16 -16
- package/esm/core/Popover/Popover.js +36 -42
- package/esm/core/ProgressIndicators/ProgressLinear.js +6 -6
- package/esm/core/ProgressIndicators/ProgressRadial.js +7 -9
- package/esm/core/Radio/Radio.js +8 -8
- package/esm/core/RadioTiles/RadioTile.js +4 -4
- package/esm/core/RadioTiles/RadioTileGroup.js +1 -1
- package/esm/core/SearchBox/SearchBox.js +32 -46
- package/esm/core/Select/Select.js +137 -149
- package/esm/core/Select/Select.types-test.js +13 -17
- package/esm/core/Select/SelectTag.js +1 -1
- package/esm/core/Select/SelectTagContainer.js +3 -3
- package/esm/core/SideNavigation/SideNavigation.js +6 -6
- package/esm/core/SideNavigation/SidenavButton.js +7 -7
- package/esm/core/SideNavigation/SidenavSubmenu.js +1 -1
- package/esm/core/SideNavigation/SidenavSubmenuHeader.js +1 -1
- package/esm/core/SkipToContentLink/SkipToContentLink.js +1 -1
- package/esm/core/Slider/Slider.js +63 -84
- package/esm/core/Slider/Thumb.js +13 -21
- package/esm/core/Slider/Track.js +10 -14
- package/esm/core/StatusMessage/StatusMessage.js +3 -3
- package/esm/core/Stepper/Stepper.js +9 -9
- package/esm/core/Stepper/StepperStep.js +15 -22
- package/esm/core/Stepper/WorkflowDiagram.js +2 -2
- package/esm/core/Stepper/WorkflowDiagramStep.js +2 -2
- package/esm/core/Surface/Surface.d.ts +1 -0
- package/esm/core/Surface/Surface.js +19 -28
- package/esm/core/Table/SubRowExpander.js +3 -3
- package/esm/core/Table/Table.d.ts +4 -1
- package/esm/core/Table/Table.js +262 -249
- package/esm/core/Table/TableCell.js +12 -14
- package/esm/core/Table/TablePaginator.js +39 -56
- package/esm/core/Table/TableRowMemoized.d.ts +3 -0
- package/esm/core/Table/TableRowMemoized.js +48 -36
- package/esm/core/Table/actionHandlers/expandHandler.js +2 -4
- package/esm/core/Table/actionHandlers/filterHandler.js +3 -3
- package/esm/core/Table/actionHandlers/resizeHandler.js +13 -17
- package/esm/core/Table/actionHandlers/selectHandler.js +22 -31
- package/esm/core/Table/cells/DefaultCell.d.ts +4 -1
- package/esm/core/Table/cells/DefaultCell.js +5 -5
- package/esm/core/Table/cells/EditableCell.d.ts +4 -1
- package/esm/core/Table/cells/EditableCell.js +7 -15
- package/esm/core/Table/columns/actionColumn.d.ts +2 -2
- package/esm/core/Table/columns/actionColumn.js +81 -90
- package/esm/core/Table/columns/expanderColumn.js +4 -6
- package/esm/core/Table/columns/selectionColumn.js +8 -10
- package/esm/core/Table/filters/BaseFilter.js +1 -1
- package/esm/core/Table/filters/DateRangeFilter/DatePickerInput.js +16 -25
- package/esm/core/Table/filters/DateRangeFilter/DateRangeFilter.js +20 -32
- package/esm/core/Table/filters/FilterButtonBar.js +3 -3
- package/esm/core/Table/filters/FilterToggle.js +8 -8
- package/esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +12 -18
- package/esm/core/Table/filters/TextFilter/TextFilter.js +7 -13
- package/esm/core/Table/filters/customFilterFunctions.js +13 -14
- package/esm/core/Table/filters/defaultFilterFunctions.js +71 -80
- package/esm/core/Table/hooks/useColumnDragAndDrop.js +24 -30
- package/esm/core/Table/hooks/useExpanderCell.js +4 -8
- package/esm/core/Table/hooks/useResizeColumns.js +74 -111
- package/esm/core/Table/hooks/useScrollToRow.js +13 -20
- package/esm/core/Table/hooks/useSelectionCell.js +2 -4
- package/esm/core/Table/hooks/useStickyColumns.js +12 -25
- package/esm/core/Table/hooks/useSubRowFiltering.js +22 -36
- package/esm/core/Table/hooks/useSubRowSelection.js +5 -6
- package/esm/core/Table/utils.js +18 -31
- package/esm/core/Tabs/Tabs.js +79 -109
- package/esm/core/Tag/Tag.js +8 -8
- package/esm/core/Tag/TagContainer.js +2 -2
- package/esm/core/Textarea/Textarea.js +4 -4
- package/esm/core/ThemeProvider/ThemeContext.js +1 -1
- package/esm/core/ThemeProvider/ThemeProvider.js +61 -63
- package/esm/core/Tile/Tile.js +44 -69
- package/esm/core/TimePicker/TimePicker.js +87 -116
- package/esm/core/Toast/Toast.js +31 -40
- package/esm/core/Toast/Toaster.js +21 -27
- package/esm/core/ToggleSwitch/ToggleSwitch.js +5 -5
- package/esm/core/Tooltip/Tooltip.js +31 -39
- package/esm/core/TransferList/TransferList.js +39 -55
- package/esm/core/Tree/Tree.d.ts +4 -1
- package/esm/core/Tree/Tree.js +100 -79
- package/esm/core/Tree/TreeContext.js +3 -4
- package/esm/core/Tree/TreeNode.d.ts +2 -2
- package/esm/core/Tree/TreeNode.js +22 -37
- package/esm/core/Tree/TreeNodeExpander.js +3 -3
- package/esm/core/Typography/Anchor.js +4 -4
- package/esm/core/Typography/Blockquote.js +1 -1
- package/esm/core/Typography/Kbd.js +1 -1
- package/esm/core/Typography/Text.js +3 -3
- package/esm/core/VisuallyHidden/VisuallyHidden.js +8 -8
- package/esm/react-table/react-table.types-test.js +93 -96
- package/esm/styles.js +2 -2
- package/esm/utils/color/ColorValue.js +116 -163
- package/esm/utils/components/AutoclearingHiddenLiveRegion.js +2 -2
- package/esm/utils/components/ButtonBase.js +10 -13
- package/esm/utils/components/FieldsetBase.d.ts +6 -0
- package/esm/utils/components/FieldsetBase.js +2 -0
- package/esm/utils/components/FocusTrap.js +14 -20
- package/esm/utils/components/InputContainer.js +3 -3
- package/esm/utils/components/InputFlexContainer.js +4 -5
- package/esm/utils/components/InputWithIcon.js +0 -1
- package/esm/utils/components/LineClamp.js +2 -2
- package/esm/utils/components/MiddleTextTruncation.d.ts +4 -1
- package/esm/utils/components/MiddleTextTruncation.js +6 -8
- package/esm/utils/components/Portal.js +8 -12
- package/esm/utils/components/Resizer.js +38 -53
- package/esm/utils/components/ShadowRoot.js +22 -31
- package/esm/utils/components/WithCSSTransition.js +4 -5
- package/esm/utils/components/index.d.ts +1 -1
- package/esm/utils/components/index.js +1 -1
- package/esm/utils/functions/colors.js +5 -6
- package/esm/utils/functions/date.js +3 -5
- package/esm/utils/functions/dev.d.ts +11 -5
- package/esm/utils/functions/dev.js +9 -23
- package/esm/utils/functions/dom.js +8 -16
- package/esm/utils/functions/focusable.js +19 -23
- package/esm/utils/functions/import.js +1 -1
- package/esm/utils/functions/numbers.js +6 -8
- package/esm/utils/functions/polymorphic.js +32 -40
- package/esm/utils/functions/react.js +4 -8
- package/esm/utils/hooks/index.d.ts +1 -0
- package/esm/utils/hooks/index.js +1 -0
- package/esm/utils/hooks/useContainerWidth.js +7 -11
- package/esm/utils/hooks/useControlledState.js +4 -5
- package/esm/utils/hooks/useDragAndDrop.js +32 -43
- package/esm/utils/hooks/useEventListener.js +3 -5
- package/esm/utils/hooks/useGlobals.js +6 -25
- package/esm/utils/hooks/useId.js +3 -3
- package/esm/utils/hooks/useIntersection.js +6 -10
- package/esm/utils/hooks/useIsClient.js +1 -1
- package/esm/utils/hooks/useIsomorphicLayoutEffect.js +2 -2
- package/esm/utils/hooks/useLatestRef.js +1 -1
- package/esm/utils/hooks/useMediaQuery.js +10 -8
- package/esm/utils/hooks/useMergedRefs.js +7 -11
- package/esm/utils/hooks/useOverflow.js +24 -26
- package/esm/utils/hooks/useResizeObserver.js +5 -9
- package/esm/utils/hooks/useSafeContext.js +3 -4
- package/esm/utils/hooks/useSyncExternalStore.js +6 -8
- package/esm/utils/hooks/useVirtualScroll.d.ts +14 -0
- package/esm/utils/hooks/useVirtualScroll.js +28 -0
- package/esm/utils/icons/SvgCalendar.js +2 -3
- package/esm/utils/icons/SvgCaretDownSmall.js +2 -3
- package/esm/utils/icons/SvgCaretRightSmall.js +2 -3
- package/esm/utils/icons/SvgCaretUpSmall.js +2 -3
- package/esm/utils/icons/SvgCheckmark.js +2 -3
- package/esm/utils/icons/SvgCheckmarkSmall.js +2 -3
- package/esm/utils/icons/SvgChevronLeft.js +2 -3
- package/esm/utils/icons/SvgChevronLeftDouble.js +2 -3
- package/esm/utils/icons/SvgChevronRight.js +2 -3
- package/esm/utils/icons/SvgChevronRightDouble.js +2 -3
- package/esm/utils/icons/SvgChevronRightSmall.js +2 -3
- package/esm/utils/icons/SvgClose.js +2 -3
- package/esm/utils/icons/SvgCloseSmall.js +2 -3
- package/esm/utils/icons/SvgColumnManager.js +2 -3
- package/esm/utils/icons/SvgDocument.js +2 -3
- package/esm/utils/icons/SvgFilter.js +2 -3
- package/esm/utils/icons/SvgFilterHollow.js +2 -3
- package/esm/utils/icons/SvgImportantSmall.js +2 -3
- package/esm/utils/icons/SvgInfoCircular.js +2 -3
- package/esm/utils/icons/SvgMore.js +2 -3
- package/esm/utils/icons/SvgMoreVertical.js +2 -3
- package/esm/utils/icons/SvgNew.js +2 -3
- package/esm/utils/icons/SvgSearch.js +2 -3
- package/esm/utils/icons/SvgSmileyHappy.js +2 -3
- package/esm/utils/icons/SvgSortDown.js +2 -3
- package/esm/utils/icons/SvgSortUp.js +2 -3
- package/esm/utils/icons/SvgStatusError.js +2 -3
- package/esm/utils/icons/SvgStatusSuccess.js +2 -3
- package/esm/utils/icons/SvgStatusWarning.js +2 -3
- package/esm/utils/icons/SvgSwap.js +2 -3
- package/esm/utils/icons/SvgUpload.js +2 -3
- package/esm/utils/meta.js +1 -1
- package/esm/utils/providers/HydrationProvider.js +15 -19
- package/esm/utils/providers/ScopeProvider.js +9 -11
- package/package.json +18 -7
- package/styles.css +9 -13
- package/cjs/utils/components/VirtualScroll.d.ts +0 -75
- package/cjs/utils/components/VirtualScroll.js +0 -334
- package/esm/utils/components/VirtualScroll.d.ts +0 -75
- package/esm/utils/components/VirtualScroll.js +0 -318
package/esm/core/Table/Table.js
CHANGED
|
@@ -25,6 +25,7 @@ import {
|
|
|
25
25
|
LineClamp,
|
|
26
26
|
useMergedRefs,
|
|
27
27
|
useLatestRef,
|
|
28
|
+
useVirtualScroll,
|
|
28
29
|
} from '../../utils/index.js';
|
|
29
30
|
import {
|
|
30
31
|
TableColumnsContext,
|
|
@@ -54,29 +55,27 @@ import {
|
|
|
54
55
|
onTableResizeEnd,
|
|
55
56
|
onTableResizeStart,
|
|
56
57
|
} from './actionHandlers/index.js';
|
|
57
|
-
import { VirtualScroll } from '../../utils/components/VirtualScroll.js';
|
|
58
58
|
import { SELECTION_CELL_ID } from './columns/index.js';
|
|
59
|
-
|
|
60
|
-
|
|
59
|
+
let singleRowSelectedAction = 'singleRowSelected';
|
|
60
|
+
let shiftRowSelectedAction = 'shiftRowSelected';
|
|
61
61
|
export const tableResizeStartAction = 'tableResizeStart';
|
|
62
|
-
|
|
63
|
-
|
|
62
|
+
let tableResizeEndAction = 'tableResizeEnd';
|
|
63
|
+
let COLUMN_MIN_WIDTHS = {
|
|
64
64
|
default: 72,
|
|
65
65
|
withExpander: 108,
|
|
66
66
|
};
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
67
|
+
let logWarning = createWarningLogger();
|
|
68
|
+
let flattenColumns = (columns) => {
|
|
69
|
+
let flatColumns = [];
|
|
70
70
|
columns.forEach((column) => {
|
|
71
71
|
flatColumns.push(column);
|
|
72
|
-
if ('columns' in column)
|
|
72
|
+
if ('columns' in column)
|
|
73
73
|
flatColumns.push(...flattenColumns(column.columns));
|
|
74
|
-
}
|
|
75
74
|
});
|
|
76
75
|
return flatColumns;
|
|
77
76
|
};
|
|
78
77
|
export const Table = (props) => {
|
|
79
|
-
|
|
78
|
+
let {
|
|
80
79
|
data,
|
|
81
80
|
columns,
|
|
82
81
|
isLoading = false,
|
|
@@ -121,8 +120,8 @@ export const Table = (props) => {
|
|
|
121
120
|
...rest
|
|
122
121
|
} = props;
|
|
123
122
|
useGlobals();
|
|
124
|
-
|
|
125
|
-
|
|
123
|
+
let ownerDocument = React.useRef();
|
|
124
|
+
let defaultColumn = React.useMemo(
|
|
126
125
|
() => ({
|
|
127
126
|
maxWidth: 0,
|
|
128
127
|
minWidth: 0,
|
|
@@ -130,29 +129,30 @@ export const Table = (props) => {
|
|
|
130
129
|
}),
|
|
131
130
|
[],
|
|
132
131
|
);
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
132
|
+
let rowHeight = React.useMemo(() => {
|
|
133
|
+
if ('condensed' === density) return 50;
|
|
134
|
+
if ('extra-condensed' === density) return 38;
|
|
135
|
+
return 62;
|
|
136
|
+
}, [density]);
|
|
137
|
+
let onBottomReachedRef = useLatestRef(onBottomReached);
|
|
138
|
+
let onRowInViewportRef = useLatestRef(onRowInViewport);
|
|
139
|
+
let hasManualSelectionColumn = React.useMemo(() => {
|
|
140
|
+
let flatColumns = flattenColumns(columns);
|
|
137
141
|
return flatColumns.some((column) => column.id === SELECTION_CELL_ID);
|
|
138
142
|
}, [columns]);
|
|
139
|
-
|
|
140
|
-
if (e.key
|
|
143
|
+
let disableUserSelect = React.useCallback((e) => {
|
|
144
|
+
if ('Shift' === e.key)
|
|
141
145
|
ownerDocument.current &&
|
|
142
146
|
(ownerDocument.current.documentElement.style.userSelect = 'none');
|
|
143
|
-
}
|
|
144
147
|
}, []);
|
|
145
|
-
|
|
146
|
-
if (e.key
|
|
148
|
+
let enableUserSelect = React.useCallback((e) => {
|
|
149
|
+
if ('Shift' === e.key)
|
|
147
150
|
ownerDocument.current &&
|
|
148
151
|
(ownerDocument.current.documentElement.style.userSelect = '');
|
|
149
|
-
}
|
|
150
152
|
}, []);
|
|
151
153
|
React.useEffect(() => {
|
|
152
|
-
if (!isSelectable ||
|
|
153
|
-
|
|
154
|
-
}
|
|
155
|
-
const ownerDoc = ownerDocument.current;
|
|
154
|
+
if (!isSelectable || 'multi' !== selectionMode) return;
|
|
155
|
+
let ownerDoc = ownerDocument.current;
|
|
156
156
|
ownerDoc?.addEventListener('keydown', disableUserSelect);
|
|
157
157
|
ownerDoc?.addEventListener('keyup', enableUserSelect);
|
|
158
158
|
return () => {
|
|
@@ -166,9 +166,9 @@ export const Table = (props) => {
|
|
|
166
166
|
disableUserSelect,
|
|
167
167
|
enableUserSelect,
|
|
168
168
|
]);
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
169
|
+
let previousFilter = React.useRef([]);
|
|
170
|
+
let currentFilter = React.useRef(previousFilter.current);
|
|
171
|
+
let tableStateReducer = React.useCallback(
|
|
172
172
|
(newState, action, previousState, instance) => {
|
|
173
173
|
switch (action.type) {
|
|
174
174
|
case TableActions.toggleSortBy:
|
|
@@ -187,46 +187,41 @@ export const Table = (props) => {
|
|
|
187
187
|
case TableActions.toggleAllRowsExpanded:
|
|
188
188
|
onExpandHandler(newState, instance, onExpand);
|
|
189
189
|
break;
|
|
190
|
-
case singleRowSelectedAction:
|
|
190
|
+
case singleRowSelectedAction:
|
|
191
191
|
newState = onSingleSelectHandler(
|
|
192
192
|
newState,
|
|
193
193
|
action,
|
|
194
194
|
instance,
|
|
195
195
|
onSelect,
|
|
196
|
-
hasManualSelectionColumn ?
|
|
196
|
+
hasManualSelectionColumn ? void 0 : isRowDisabled,
|
|
197
197
|
);
|
|
198
198
|
break;
|
|
199
|
-
|
|
200
|
-
case shiftRowSelectedAction: {
|
|
199
|
+
case shiftRowSelectedAction:
|
|
201
200
|
newState = onShiftSelectHandler(
|
|
202
201
|
newState,
|
|
203
202
|
action,
|
|
204
203
|
instance,
|
|
205
204
|
onSelect,
|
|
206
|
-
hasManualSelectionColumn ?
|
|
205
|
+
hasManualSelectionColumn ? void 0 : isRowDisabled,
|
|
207
206
|
);
|
|
208
207
|
break;
|
|
209
|
-
}
|
|
210
208
|
case TableActions.toggleRowSelected:
|
|
211
209
|
case TableActions.toggleAllRowsSelected:
|
|
212
|
-
case TableActions.toggleAllPageRowsSelected:
|
|
210
|
+
case TableActions.toggleAllPageRowsSelected:
|
|
213
211
|
onToggleHandler(
|
|
214
212
|
newState,
|
|
215
213
|
action,
|
|
216
214
|
instance,
|
|
217
215
|
onSelect,
|
|
218
|
-
hasManualSelectionColumn ?
|
|
216
|
+
hasManualSelectionColumn ? void 0 : isRowDisabled,
|
|
219
217
|
);
|
|
220
218
|
break;
|
|
221
|
-
|
|
222
|
-
case tableResizeStartAction: {
|
|
219
|
+
case tableResizeStartAction:
|
|
223
220
|
newState = onTableResizeStart(newState);
|
|
224
221
|
break;
|
|
225
|
-
|
|
226
|
-
case tableResizeEndAction: {
|
|
222
|
+
case tableResizeEndAction:
|
|
227
223
|
newState = onTableResizeEnd(newState, action);
|
|
228
224
|
break;
|
|
229
|
-
}
|
|
230
225
|
default:
|
|
231
226
|
break;
|
|
232
227
|
}
|
|
@@ -243,19 +238,21 @@ export const Table = (props) => {
|
|
|
243
238
|
stateReducer,
|
|
244
239
|
],
|
|
245
240
|
);
|
|
246
|
-
|
|
241
|
+
let filterTypes = React.useMemo(
|
|
247
242
|
() => ({
|
|
248
243
|
...customFilterFunctions,
|
|
249
244
|
...filterFunctions,
|
|
250
245
|
}),
|
|
251
246
|
[filterFunctions],
|
|
252
247
|
);
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
248
|
+
let hasAnySubRows = React.useMemo(
|
|
249
|
+
() =>
|
|
250
|
+
data.some((item, index) =>
|
|
251
|
+
getSubRows ? getSubRows(item, index) : item.subRows,
|
|
252
|
+
),
|
|
253
|
+
[data, getSubRows],
|
|
254
|
+
);
|
|
255
|
+
let instance = useTable(
|
|
259
256
|
{
|
|
260
257
|
manualPagination: !paginatorRenderer,
|
|
261
258
|
paginateExpandedRows: false,
|
|
@@ -290,7 +287,7 @@ export const Table = (props) => {
|
|
|
290
287
|
useColumnDragAndDrop(enableColumnReordering),
|
|
291
288
|
useStickyColumns,
|
|
292
289
|
);
|
|
293
|
-
|
|
290
|
+
let {
|
|
294
291
|
getTableProps,
|
|
295
292
|
rows,
|
|
296
293
|
headerGroups: _headerGroups,
|
|
@@ -307,58 +304,47 @@ export const Table = (props) => {
|
|
|
307
304
|
setGlobalFilter,
|
|
308
305
|
} = instance;
|
|
309
306
|
let headerGroups = _headerGroups;
|
|
310
|
-
if (columns.length
|
|
307
|
+
if (1 === columns.length && 'columns' in columns[0])
|
|
311
308
|
headerGroups = _headerGroups.slice(1);
|
|
312
|
-
|
|
313
|
-
`Table's \`columns\` prop should not have a top-level \`Header\` or sub-columns. They are only allowed to be passed for backwards compatibility.\n See https://github.com/iTwin/iTwinUI/wiki/iTwinUI-react-v2-migration-guide#breaking-changes`,
|
|
314
|
-
);
|
|
315
|
-
}
|
|
316
|
-
const ariaDataAttributes = Object.entries(rest).reduce(
|
|
309
|
+
let ariaDataAttributes = Object.entries(rest).reduce(
|
|
317
310
|
(result, [key, value]) => {
|
|
318
|
-
if (key.startsWith('data-') || key.startsWith('aria-'))
|
|
311
|
+
if (key.startsWith('data-') || key.startsWith('aria-'))
|
|
319
312
|
result[key] = value;
|
|
320
|
-
}
|
|
321
313
|
return result;
|
|
322
314
|
},
|
|
323
315
|
{},
|
|
324
316
|
);
|
|
325
|
-
|
|
317
|
+
let areFiltersSet =
|
|
326
318
|
allColumns.some(
|
|
327
|
-
(column) => column.filterValue
|
|
319
|
+
(column) => null != column.filterValue && '' !== column.filterValue,
|
|
328
320
|
) || !!globalFilterValue;
|
|
329
|
-
|
|
330
|
-
(data.length
|
|
331
|
-
|
|
332
|
-
|
|
321
|
+
let showFilterButton = (column) =>
|
|
322
|
+
(0 !== data.length || areFiltersSet) && column.canFilter && !!column.Filter;
|
|
323
|
+
let showSortButton = (column) => 0 !== data.length && column.canSort;
|
|
324
|
+
let onRowClickHandler = React.useCallback(
|
|
333
325
|
(event, row) => {
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
if (!isDisabled)
|
|
337
|
-
onRowClick?.(event, row);
|
|
338
|
-
}
|
|
326
|
+
let isDisabled = isRowDisabled?.(row.original);
|
|
327
|
+
let ctrlPressed = event.ctrlKey || event.metaKey;
|
|
328
|
+
if (!isDisabled) onRowClick?.(event, row);
|
|
339
329
|
if (
|
|
340
330
|
isSelectable &&
|
|
341
331
|
!isDisabled &&
|
|
342
332
|
selectRowOnClick &&
|
|
343
333
|
!event.isDefaultPrevented()
|
|
344
334
|
) {
|
|
345
|
-
if (
|
|
335
|
+
if ('multi' === selectionMode && event.shiftKey)
|
|
346
336
|
dispatch({
|
|
347
337
|
type: shiftRowSelectedAction,
|
|
348
338
|
id: row.id,
|
|
349
339
|
ctrlPressed: ctrlPressed,
|
|
350
340
|
});
|
|
351
|
-
|
|
352
|
-
!row.isSelected
|
|
353
|
-
|
|
354
|
-
) {
|
|
341
|
+
else if (row.isSelected || ('single' !== selectionMode && ctrlPressed))
|
|
342
|
+
row.toggleRowSelected(!row.isSelected);
|
|
343
|
+
else
|
|
355
344
|
dispatch({
|
|
356
345
|
type: singleRowSelectedAction,
|
|
357
346
|
id: row.id,
|
|
358
347
|
});
|
|
359
|
-
} else {
|
|
360
|
-
row.toggleRowSelected(!row.isSelected);
|
|
361
|
-
}
|
|
362
348
|
}
|
|
363
349
|
},
|
|
364
350
|
[
|
|
@@ -382,27 +368,26 @@ export const Table = (props) => {
|
|
|
382
368
|
onFilter?.(currentFilter.current, state, instance.filteredRows);
|
|
383
369
|
}
|
|
384
370
|
}, [state, instance.filteredRows, onFilter]);
|
|
385
|
-
|
|
371
|
+
let lastPassedColumns = React.useRef([]);
|
|
386
372
|
React.useEffect(() => {
|
|
387
373
|
if (
|
|
388
374
|
lastPassedColumns.current.length > 0 &&
|
|
389
375
|
JSON.stringify(lastPassedColumns.current) !== JSON.stringify(columns)
|
|
390
|
-
)
|
|
376
|
+
)
|
|
391
377
|
instance.setColumnOrder([]);
|
|
392
|
-
}
|
|
393
378
|
lastPassedColumns.current = columns;
|
|
394
379
|
}, [columns, instance]);
|
|
395
|
-
|
|
380
|
+
let paginatorRendererProps = React.useMemo(
|
|
396
381
|
() => ({
|
|
397
382
|
currentPage: state.pageIndex,
|
|
398
383
|
pageSize: state.pageSize,
|
|
399
384
|
totalRowsCount: rows.length,
|
|
400
|
-
size:
|
|
385
|
+
size: 'default' !== density ? 'small' : 'default',
|
|
401
386
|
isLoading,
|
|
402
387
|
onPageChange: gotoPage,
|
|
403
388
|
onPageSizeChange: setPageSize,
|
|
404
389
|
totalSelectedRowsCount:
|
|
405
|
-
|
|
390
|
+
'single' === selectionMode ? 0 : instance.selectedFlatRows.length,
|
|
406
391
|
}),
|
|
407
392
|
[
|
|
408
393
|
density,
|
|
@@ -416,32 +401,25 @@ export const Table = (props) => {
|
|
|
416
401
|
selectionMode,
|
|
417
402
|
],
|
|
418
403
|
);
|
|
419
|
-
|
|
420
|
-
|
|
404
|
+
let tableRef = React.useRef(null);
|
|
405
|
+
let { scrollToIndex, tableRowRef } = useScrollToRow({
|
|
421
406
|
...props,
|
|
422
407
|
page,
|
|
423
408
|
});
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
409
|
+
let columnRefs = React.useRef({});
|
|
410
|
+
let previousTableWidth = React.useRef(0);
|
|
411
|
+
let onTableResize = React.useCallback(
|
|
427
412
|
({ width }) => {
|
|
428
|
-
if (!isResizable)
|
|
429
|
-
return;
|
|
430
|
-
}
|
|
413
|
+
if (!isResizable) return;
|
|
431
414
|
instance.tableWidth = width;
|
|
432
|
-
if (width === previousTableWidth.current)
|
|
433
|
-
return;
|
|
434
|
-
}
|
|
415
|
+
if (width === previousTableWidth.current) return;
|
|
435
416
|
previousTableWidth.current = width;
|
|
436
417
|
flatHeaders.forEach((header) => {
|
|
437
|
-
if (columnRefs.current[header.id])
|
|
418
|
+
if (columnRefs.current[header.id])
|
|
438
419
|
header.resizeWidth =
|
|
439
420
|
columnRefs.current[header.id].getBoundingClientRect().width;
|
|
440
|
-
}
|
|
441
421
|
});
|
|
442
|
-
if (Object.keys(state.columnResizing.columnWidths).length
|
|
443
|
-
return;
|
|
444
|
-
}
|
|
422
|
+
if (0 === Object.keys(state.columnResizing.columnWidths).length) return;
|
|
445
423
|
dispatch({
|
|
446
424
|
type: tableResizeStartAction,
|
|
447
425
|
});
|
|
@@ -454,15 +432,14 @@ export const Table = (props) => {
|
|
|
454
432
|
isResizable,
|
|
455
433
|
],
|
|
456
434
|
);
|
|
457
|
-
|
|
435
|
+
let [resizeRef] = useResizeObserver(onTableResize);
|
|
458
436
|
useLayoutEffect(() => {
|
|
459
437
|
if (state.isTableResizing) {
|
|
460
|
-
|
|
438
|
+
let newColumnWidths = {};
|
|
461
439
|
flatHeaders.forEach((column) => {
|
|
462
|
-
if (columnRefs.current[column.id])
|
|
440
|
+
if (columnRefs.current[column.id])
|
|
463
441
|
newColumnWidths[column.id] =
|
|
464
442
|
columnRefs.current[column.id].getBoundingClientRect().width;
|
|
465
|
-
}
|
|
466
443
|
});
|
|
467
444
|
dispatch({
|
|
468
445
|
type: tableResizeEndAction,
|
|
@@ -470,9 +447,22 @@ export const Table = (props) => {
|
|
|
470
447
|
});
|
|
471
448
|
}
|
|
472
449
|
});
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
450
|
+
let virtualizer = useVirtualScroll({
|
|
451
|
+
count: page.length,
|
|
452
|
+
getScrollElement: () => tableRef.current,
|
|
453
|
+
estimateSize: () => rowHeight,
|
|
454
|
+
getItemKey: (index) => page[index].id,
|
|
455
|
+
overscan: 1,
|
|
456
|
+
});
|
|
457
|
+
useLayoutEffect(() => {
|
|
458
|
+
if (scrollToIndex)
|
|
459
|
+
virtualizer.scrollToIndex(scrollToIndex, {
|
|
460
|
+
align: 'center',
|
|
461
|
+
});
|
|
462
|
+
}, [virtualizer, scrollToIndex]);
|
|
463
|
+
let getPreparedRow = React.useCallback(
|
|
464
|
+
(index, virtualItem, virtualizer) => {
|
|
465
|
+
let row = page[index];
|
|
476
466
|
prepareRow(row);
|
|
477
467
|
return React.createElement(TableRowMemoized, {
|
|
478
468
|
row: row,
|
|
@@ -490,8 +480,10 @@ export const Table = (props) => {
|
|
|
490
480
|
tableInstance: instance,
|
|
491
481
|
expanderCell: expanderCell,
|
|
492
482
|
scrollContainerRef: tableRef.current,
|
|
493
|
-
tableRowRef: enableVirtualization ?
|
|
483
|
+
tableRowRef: enableVirtualization ? void 0 : tableRowRef(row),
|
|
494
484
|
density: density,
|
|
485
|
+
virtualItem: virtualItem,
|
|
486
|
+
virtualizer: virtualizer,
|
|
495
487
|
});
|
|
496
488
|
},
|
|
497
489
|
[
|
|
@@ -513,44 +505,39 @@ export const Table = (props) => {
|
|
|
513
505
|
onRowInViewportRef,
|
|
514
506
|
],
|
|
515
507
|
);
|
|
516
|
-
|
|
517
|
-
(
|
|
518
|
-
[getPreparedRow],
|
|
519
|
-
);
|
|
520
|
-
const updateStickyState = () => {
|
|
521
|
-
if (!tableRef.current || flatHeaders.every((header) => !header.sticky)) {
|
|
508
|
+
let updateStickyState = () => {
|
|
509
|
+
if (!tableRef.current || flatHeaders.every((header) => !header.sticky))
|
|
522
510
|
return;
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
});
|
|
543
|
-
} else {
|
|
544
|
-
dispatch({
|
|
545
|
-
type: TableActions.setScrolledLeft,
|
|
546
|
-
value: false,
|
|
547
|
-
});
|
|
548
|
-
}
|
|
511
|
+
0 !== tableRef.current.scrollLeft
|
|
512
|
+
? dispatch({
|
|
513
|
+
type: TableActions.setScrolledRight,
|
|
514
|
+
value: true,
|
|
515
|
+
})
|
|
516
|
+
: dispatch({
|
|
517
|
+
type: TableActions.setScrolledRight,
|
|
518
|
+
value: false,
|
|
519
|
+
});
|
|
520
|
+
tableRef.current.scrollLeft !==
|
|
521
|
+
tableRef.current.scrollWidth - tableRef.current.clientWidth
|
|
522
|
+
? dispatch({
|
|
523
|
+
type: TableActions.setScrolledLeft,
|
|
524
|
+
value: true,
|
|
525
|
+
})
|
|
526
|
+
: dispatch({
|
|
527
|
+
type: TableActions.setScrolledLeft,
|
|
528
|
+
value: false,
|
|
529
|
+
});
|
|
549
530
|
};
|
|
550
531
|
React.useEffect(() => {
|
|
551
532
|
updateStickyState();
|
|
552
533
|
}, []);
|
|
553
|
-
|
|
534
|
+
let isHeaderDirectClick = React.useRef(false);
|
|
535
|
+
let columnResizeRef = React.useCallback((el, column) => {
|
|
536
|
+
if (el) {
|
|
537
|
+
columnRefs.current[column.id] = el;
|
|
538
|
+
column.resizeWidth = el.getBoundingClientRect().width;
|
|
539
|
+
}
|
|
540
|
+
}, []);
|
|
554
541
|
return React.createElement(
|
|
555
542
|
TableColumnsContext.Provider,
|
|
556
543
|
{
|
|
@@ -559,10 +546,13 @@ export const Table = (props) => {
|
|
|
559
546
|
React.createElement(
|
|
560
547
|
Box,
|
|
561
548
|
{
|
|
562
|
-
ref: useMergedRefs(
|
|
563
|
-
|
|
564
|
-
resizeRef
|
|
565
|
-
|
|
549
|
+
ref: useMergedRefs(
|
|
550
|
+
tableRef,
|
|
551
|
+
resizeRef,
|
|
552
|
+
React.useCallback((element) => {
|
|
553
|
+
ownerDocument.current = element?.ownerDocument;
|
|
554
|
+
}, []),
|
|
555
|
+
),
|
|
566
556
|
id: id,
|
|
567
557
|
...getTableProps({
|
|
568
558
|
className: cx('iui-table', className),
|
|
@@ -572,7 +562,7 @@ export const Table = (props) => {
|
|
|
572
562
|
},
|
|
573
563
|
}),
|
|
574
564
|
onScroll: () => updateStickyState(),
|
|
575
|
-
'data-iui-size':
|
|
565
|
+
'data-iui-size': 'default' === density ? void 0 : density,
|
|
576
566
|
...ariaDataAttributes,
|
|
577
567
|
},
|
|
578
568
|
headerGroups.map((headerGroup) => {
|
|
@@ -581,7 +571,7 @@ export const Table = (props) => {
|
|
|
581
571
|
!header.id.includes('iui-table-checkbox-selector_placeholder') &&
|
|
582
572
|
!header.id.includes('iui-table-expander_placeholder'),
|
|
583
573
|
);
|
|
584
|
-
|
|
574
|
+
let headerGroupProps = headerGroup.getHeaderGroupProps({
|
|
585
575
|
className: 'iui-table-row',
|
|
586
576
|
});
|
|
587
577
|
return React.createElement(
|
|
@@ -606,20 +596,19 @@ export const Table = (props) => {
|
|
|
606
596
|
Box,
|
|
607
597
|
headerGroupProps,
|
|
608
598
|
headerGroup.headers.map((column, index) => {
|
|
609
|
-
|
|
599
|
+
let { onClick, ...restSortProps } =
|
|
610
600
|
column.getSortByToggleProps();
|
|
611
|
-
|
|
601
|
+
let columnHasExpanders =
|
|
612
602
|
hasAnySubRows &&
|
|
613
603
|
index ===
|
|
614
604
|
headerGroup.headers.findIndex(
|
|
615
605
|
(c) => c.id !== SELECTION_CELL_ID,
|
|
616
606
|
);
|
|
617
|
-
if ([
|
|
607
|
+
if ([void 0, 0].includes(column.minWidth))
|
|
618
608
|
column.minWidth = columnHasExpanders
|
|
619
609
|
? COLUMN_MIN_WIDTHS.withExpander
|
|
620
610
|
: COLUMN_MIN_WIDTHS.default;
|
|
621
|
-
|
|
622
|
-
const columnProps = column.getHeaderProps({
|
|
611
|
+
let columnProps = column.getHeaderProps({
|
|
623
612
|
...restSortProps,
|
|
624
613
|
className: cx(
|
|
625
614
|
'iui-table-cell',
|
|
@@ -647,12 +636,9 @@ export const Table = (props) => {
|
|
|
647
636
|
...columnProps,
|
|
648
637
|
...column.getDragAndDropProps(),
|
|
649
638
|
key: columnProps.key,
|
|
650
|
-
title:
|
|
639
|
+
title: void 0,
|
|
651
640
|
ref: (el) => {
|
|
652
|
-
|
|
653
|
-
columnRefs.current[column.id] = el;
|
|
654
|
-
column.resizeWidth = el.getBoundingClientRect().width;
|
|
655
|
-
}
|
|
641
|
+
columnResizeRef(el, column);
|
|
656
642
|
},
|
|
657
643
|
onMouseDown: () => {
|
|
658
644
|
isHeaderDirectClick.current = true;
|
|
@@ -663,97 +649,100 @@ export const Table = (props) => {
|
|
|
663
649
|
isHeaderDirectClick.current = false;
|
|
664
650
|
}
|
|
665
651
|
},
|
|
666
|
-
tabIndex: showSortButton(column) ? 0 :
|
|
652
|
+
tabIndex: showSortButton(column) ? 0 : void 0,
|
|
667
653
|
onKeyDown: (e) => {
|
|
668
|
-
if (e.key
|
|
654
|
+
if ('Enter' == e.key && showSortButton(column))
|
|
669
655
|
column.toggleSortBy();
|
|
670
|
-
}
|
|
671
656
|
},
|
|
672
657
|
},
|
|
673
658
|
React.createElement(
|
|
674
|
-
|
|
659
|
+
React.Fragment,
|
|
675
660
|
null,
|
|
676
|
-
typeof column.Header === 'string'
|
|
677
|
-
? React.createElement(
|
|
678
|
-
LineClamp,
|
|
679
|
-
null,
|
|
680
|
-
React.createElement('slot', null),
|
|
681
|
-
)
|
|
682
|
-
: React.createElement('slot', null),
|
|
683
|
-
React.createElement('slot', {
|
|
684
|
-
name: 'actions',
|
|
685
|
-
}),
|
|
686
|
-
React.createElement('slot', {
|
|
687
|
-
name: 'resizers',
|
|
688
|
-
}),
|
|
689
|
-
React.createElement('slot', {
|
|
690
|
-
name: 'shadows',
|
|
691
|
-
}),
|
|
692
|
-
),
|
|
693
|
-
column.render('Header'),
|
|
694
|
-
(showFilterButton(column) || showSortButton(column)) &&
|
|
695
661
|
React.createElement(
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
? React.createElement(SvgSortDown, {
|
|
715
|
-
className: 'iui-table-sort',
|
|
716
|
-
'aria-hidden': true,
|
|
717
|
-
})
|
|
718
|
-
: React.createElement(SvgSortUp, {
|
|
719
|
-
className: 'iui-table-sort',
|
|
720
|
-
'aria-hidden': true,
|
|
721
|
-
}),
|
|
722
|
-
),
|
|
662
|
+
ShadowRoot,
|
|
663
|
+
null,
|
|
664
|
+
'string' == typeof column.Header
|
|
665
|
+
? React.createElement(
|
|
666
|
+
LineClamp,
|
|
667
|
+
null,
|
|
668
|
+
React.createElement('slot', null),
|
|
669
|
+
)
|
|
670
|
+
: React.createElement('slot', null),
|
|
671
|
+
React.createElement('slot', {
|
|
672
|
+
name: 'actions',
|
|
673
|
+
}),
|
|
674
|
+
React.createElement('slot', {
|
|
675
|
+
name: 'resizers',
|
|
676
|
+
}),
|
|
677
|
+
React.createElement('slot', {
|
|
678
|
+
name: 'shadows',
|
|
679
|
+
}),
|
|
723
680
|
),
|
|
724
|
-
|
|
725
|
-
column
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
681
|
+
column.render('Header'),
|
|
682
|
+
(showFilterButton(column) || showSortButton(column)) &&
|
|
683
|
+
React.createElement(
|
|
684
|
+
Box,
|
|
685
|
+
{
|
|
686
|
+
className: 'iui-table-header-actions-container',
|
|
687
|
+
onKeyDown: (e) => e.stopPropagation(),
|
|
688
|
+
slot: 'actions',
|
|
689
|
+
},
|
|
690
|
+
showFilterButton(column) &&
|
|
691
|
+
React.createElement(FilterToggle, {
|
|
692
|
+
column: column,
|
|
693
|
+
}),
|
|
694
|
+
showSortButton(column) &&
|
|
695
|
+
React.createElement(
|
|
696
|
+
Box,
|
|
697
|
+
{
|
|
698
|
+
className: 'iui-table-cell-end-icon',
|
|
699
|
+
},
|
|
700
|
+
column.isSortedDesc ||
|
|
701
|
+
(!column.isSorted && column.sortDescFirst)
|
|
702
|
+
? React.createElement(SvgSortDown, {
|
|
703
|
+
className: 'iui-table-sort',
|
|
704
|
+
'aria-hidden': true,
|
|
705
|
+
})
|
|
706
|
+
: React.createElement(SvgSortUp, {
|
|
707
|
+
className: 'iui-table-sort',
|
|
708
|
+
'aria-hidden': true,
|
|
709
|
+
}),
|
|
710
|
+
),
|
|
711
|
+
),
|
|
712
|
+
isResizable &&
|
|
713
|
+
column.isResizerVisible &&
|
|
714
|
+
(index !== headerGroup.headers.length - 1 ||
|
|
715
|
+
'expand' === columnResizeMode) &&
|
|
716
|
+
React.createElement(
|
|
717
|
+
Box,
|
|
718
|
+
{
|
|
719
|
+
...column.getResizerProps(),
|
|
720
|
+
className: 'iui-table-resizer',
|
|
721
|
+
slot: 'resizers',
|
|
722
|
+
},
|
|
723
|
+
React.createElement(Box, {
|
|
724
|
+
className: 'iui-table-resizer-bar',
|
|
725
|
+
}),
|
|
726
|
+
),
|
|
727
|
+
enableColumnReordering &&
|
|
728
|
+
!column.disableReordering &&
|
|
729
|
+
React.createElement(Box, {
|
|
730
|
+
className: 'iui-table-reorder-bar',
|
|
733
731
|
slot: 'resizers',
|
|
734
|
-
},
|
|
732
|
+
}),
|
|
733
|
+
'left' === column.sticky &&
|
|
734
|
+
state.sticky.isScrolledToRight &&
|
|
735
735
|
React.createElement(Box, {
|
|
736
|
-
className: 'iui-table-
|
|
736
|
+
className: 'iui-table-cell-shadow-right',
|
|
737
|
+
slot: 'shadows',
|
|
737
738
|
}),
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
column.sticky === 'left' &&
|
|
746
|
-
state.sticky.isScrolledToRight &&
|
|
747
|
-
React.createElement(Box, {
|
|
748
|
-
className: 'iui-table-cell-shadow-right',
|
|
749
|
-
slot: 'shadows',
|
|
750
|
-
}),
|
|
751
|
-
column.sticky === 'right' &&
|
|
752
|
-
state.sticky.isScrolledToLeft &&
|
|
753
|
-
React.createElement(Box, {
|
|
754
|
-
className: 'iui-table-cell-shadow-left',
|
|
755
|
-
slot: 'shadows',
|
|
756
|
-
}),
|
|
739
|
+
'right' === column.sticky &&
|
|
740
|
+
state.sticky.isScrolledToLeft &&
|
|
741
|
+
React.createElement(Box, {
|
|
742
|
+
className: 'iui-table-cell-shadow-left',
|
|
743
|
+
slot: 'shadows',
|
|
744
|
+
}),
|
|
745
|
+
),
|
|
757
746
|
);
|
|
758
747
|
}),
|
|
759
748
|
),
|
|
@@ -769,7 +758,7 @@ export const Table = (props) => {
|
|
|
769
758
|
className: cx(
|
|
770
759
|
'iui-table-body',
|
|
771
760
|
{
|
|
772
|
-
'iui-zebra-striping':
|
|
761
|
+
'iui-zebra-striping': 'zebra-rows' === styleType,
|
|
773
762
|
},
|
|
774
763
|
bodyProps?.className,
|
|
775
764
|
),
|
|
@@ -779,22 +768,46 @@ export const Table = (props) => {
|
|
|
779
768
|
}),
|
|
780
769
|
tabIndex: -1,
|
|
781
770
|
'aria-multiselectable':
|
|
782
|
-
(isSelectable &&
|
|
771
|
+
(isSelectable && 'multi' === selectionMode) || void 0,
|
|
783
772
|
},
|
|
784
|
-
|
|
773
|
+
React.createElement(
|
|
774
|
+
ShadowRoot,
|
|
775
|
+
{
|
|
776
|
+
css: `
|
|
777
|
+
div,
|
|
778
|
+
slot {
|
|
779
|
+
border-radius: inherit;
|
|
780
|
+
}
|
|
781
|
+
`,
|
|
782
|
+
},
|
|
783
|
+
enableVirtualization
|
|
784
|
+
? React.createElement(
|
|
785
|
+
'div',
|
|
786
|
+
{
|
|
787
|
+
style: {
|
|
788
|
+
minBlockSize: virtualizer.getTotalSize(),
|
|
789
|
+
minInlineSize: '100%',
|
|
790
|
+
contain: 'strict',
|
|
791
|
+
},
|
|
792
|
+
},
|
|
793
|
+
React.createElement('slot', null),
|
|
794
|
+
)
|
|
795
|
+
: React.createElement('slot', null),
|
|
796
|
+
),
|
|
797
|
+
0 !== data.length &&
|
|
785
798
|
React.createElement(
|
|
786
799
|
React.Fragment,
|
|
787
800
|
null,
|
|
788
801
|
enableVirtualization
|
|
789
|
-
?
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
802
|
+
? virtualizer
|
|
803
|
+
.getVirtualItems()
|
|
804
|
+
.map((virtualItem) =>
|
|
805
|
+
getPreparedRow(virtualItem.index, virtualItem, virtualizer),
|
|
806
|
+
)
|
|
794
807
|
: page.map((_, index) => getPreparedRow(index)),
|
|
795
808
|
),
|
|
796
809
|
isLoading &&
|
|
797
|
-
data.length
|
|
810
|
+
0 === data.length &&
|
|
798
811
|
React.createElement(
|
|
799
812
|
Box,
|
|
800
813
|
{
|
|
@@ -810,7 +823,7 @@ export const Table = (props) => {
|
|
|
810
823
|
}),
|
|
811
824
|
),
|
|
812
825
|
!isLoading &&
|
|
813
|
-
data.length
|
|
826
|
+
0 === data.length &&
|
|
814
827
|
!areFiltersSet &&
|
|
815
828
|
React.createElement(
|
|
816
829
|
Box,
|
|
@@ -825,7 +838,7 @@ export const Table = (props) => {
|
|
|
825
838
|
React.createElement('div', null, emptyTableContent),
|
|
826
839
|
),
|
|
827
840
|
!isLoading &&
|
|
828
|
-
(data.length
|
|
841
|
+
(0 === data.length || 0 === rows.length) &&
|
|
829
842
|
areFiltersSet &&
|
|
830
843
|
React.createElement(
|
|
831
844
|
Box,
|
|
@@ -841,7 +854,7 @@ export const Table = (props) => {
|
|
|
841
854
|
),
|
|
842
855
|
),
|
|
843
856
|
isLoading &&
|
|
844
|
-
data.length
|
|
857
|
+
0 !== data.length &&
|
|
845
858
|
React.createElement(
|
|
846
859
|
Box,
|
|
847
860
|
{
|