@itwin/itwinui-react 3.17.4 → 3.18.1
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 +75 -0
- package/DEV-cjs/core/Alert/Alert.js +12 -6
- package/DEV-cjs/core/Avatar/Avatar.js +1 -1
- package/DEV-cjs/core/AvatarGroup/AvatarGroup.js +2 -1
- package/DEV-cjs/core/Backdrop/Backdrop.js +1 -1
- package/DEV-cjs/core/Badge/Badge.js +1 -1
- package/DEV-cjs/core/Breadcrumbs/Breadcrumbs.js +8 -5
- package/DEV-cjs/core/ButtonGroup/ButtonGroup.js +4 -2
- package/DEV-cjs/core/Buttons/Button.js +1 -1
- package/DEV-cjs/core/Buttons/DropdownButton.js +2 -1
- package/DEV-cjs/core/Buttons/IconButton.js +8 -2
- package/DEV-cjs/core/Buttons/IdeasButton.js +2 -1
- package/DEV-cjs/core/Buttons/SplitButton.js +2 -1
- package/DEV-cjs/core/Carousel/Carousel.js +2 -1
- package/DEV-cjs/core/Carousel/CarouselContext.js +2 -1
- package/DEV-cjs/core/Carousel/CarouselDot.js +2 -1
- package/DEV-cjs/core/Carousel/CarouselDotsList.js +2 -1
- package/DEV-cjs/core/Carousel/CarouselNavigation.js +6 -3
- package/DEV-cjs/core/Carousel/CarouselSlide.js +2 -1
- package/DEV-cjs/core/Carousel/CarouselSlider.js +2 -1
- package/DEV-cjs/core/Checkbox/Checkbox.js +1 -1
- package/DEV-cjs/core/ColorPicker/ColorBuilder.js +2 -1
- package/DEV-cjs/core/ColorPicker/ColorInputPanel.js +4 -2
- package/DEV-cjs/core/ColorPicker/ColorPalette.js +2 -1
- package/DEV-cjs/core/ColorPicker/ColorPicker.js +2 -1
- package/DEV-cjs/core/ColorPicker/ColorSwatch.js +2 -1
- package/DEV-cjs/core/ComboBox/ComboBox.js +61 -29
- package/DEV-cjs/core/ComboBox/ComboBoxEndIcon.js +2 -1
- package/DEV-cjs/core/ComboBox/ComboBoxInput.js +2 -3
- package/DEV-cjs/core/ComboBox/ComboBoxInputContainer.js +2 -1
- package/DEV-cjs/core/ComboBox/ComboBoxMenu.js +2 -1
- package/DEV-cjs/core/ComboBox/ComboBoxMenuItem.js +3 -2
- package/DEV-cjs/core/ComboBox/ComboBoxMultipleContainer.js +2 -1
- package/DEV-cjs/core/ComboBox/helpers.js +4 -2
- package/DEV-cjs/core/DatePicker/DatePicker.js +5 -4
- package/DEV-cjs/core/Dialog/Dialog.js +22 -12
- package/DEV-cjs/core/Dialog/DialogBackdrop.js +7 -6
- package/DEV-cjs/core/Dialog/DialogButtonBar.js +2 -1
- package/DEV-cjs/core/Dialog/DialogContent.js +2 -1
- package/DEV-cjs/core/Dialog/DialogContext.js +1 -1
- package/DEV-cjs/core/Dialog/DialogMain.js +20 -14
- package/DEV-cjs/core/Dialog/DialogTitleBar.js +5 -4
- package/DEV-cjs/core/Dialog/DialogTitleBarTitle.js +2 -1
- package/DEV-cjs/core/Divider/Divider.js +1 -1
- package/DEV-cjs/core/DropdownMenu/DropdownMenu.js +32 -24
- package/DEV-cjs/core/ExpandableBlock/ExpandableBlock.js +38 -13
- package/DEV-cjs/core/Fieldset/Fieldset.js +1 -1
- package/DEV-cjs/core/FileUpload/FileEmptyCard.js +6 -3
- package/DEV-cjs/core/FileUpload/FileUpload.js +2 -1
- package/DEV-cjs/core/FileUpload/FileUploadCard.js +18 -9
- package/DEV-cjs/core/FileUpload/FileUploadTemplate.js +2 -1
- package/DEV-cjs/core/Flex/Flex.js +4 -3
- package/DEV-cjs/core/Footer/Footer.js +1 -1
- package/DEV-cjs/core/Footer/FooterItem.js +2 -1
- package/DEV-cjs/core/Footer/FooterList.js +2 -1
- package/DEV-cjs/core/Footer/FooterSeparator.js +2 -1
- package/DEV-cjs/core/Header/Header.js +1 -1
- package/DEV-cjs/core/Header/HeaderBreadcrumbs.js +2 -1
- package/DEV-cjs/core/Header/HeaderButton.js +2 -1
- package/DEV-cjs/core/Header/HeaderLogo.js +3 -2
- package/DEV-cjs/core/Icon/Icon.js +1 -1
- package/DEV-cjs/core/InformationPanel/InformationPanel.js +2 -1
- package/DEV-cjs/core/InformationPanel/InformationPanelBody.js +2 -1
- package/DEV-cjs/core/InformationPanel/InformationPanelContent.js +2 -1
- package/DEV-cjs/core/InformationPanel/InformationPanelHeader.js +2 -1
- package/DEV-cjs/core/InformationPanel/InformationPanelWrapper.js +2 -1
- package/DEV-cjs/core/Input/Input.js +1 -1
- package/DEV-cjs/core/InputGrid/InputGrid.js +1 -1
- package/DEV-cjs/core/InputGroup/InputGroup.js +2 -1
- package/DEV-cjs/core/InputWithDecorations/InputWithDecorations.js +10 -5
- package/DEV-cjs/core/Label/Label.js +1 -1
- package/DEV-cjs/core/LabeledInput/LabeledInput.js +2 -1
- package/DEV-cjs/core/LabeledSelect/LabeledSelect.js +5 -2
- package/DEV-cjs/core/LabeledTextarea/LabeledTextarea.js +2 -1
- package/DEV-cjs/core/LinkAction/LinkAction.js +4 -3
- package/DEV-cjs/core/List/List.js +1 -1
- package/DEV-cjs/core/List/ListItem.js +10 -5
- package/DEV-cjs/core/Menu/Menu.js +3 -1
- package/DEV-cjs/core/Menu/MenuDivider.js +2 -1
- package/DEV-cjs/core/Menu/MenuExtraContent.js +3 -4
- package/DEV-cjs/core/Menu/MenuItem.js +20 -12
- package/DEV-cjs/core/Menu/MenuItemSkeleton.js +2 -1
- package/DEV-cjs/core/Modal/Modal.js +1 -1
- package/DEV-cjs/core/Modal/ModalButtonBar.js +2 -1
- package/DEV-cjs/core/Modal/ModalContent.js +2 -1
- package/DEV-cjs/core/NonIdealState/ErrorPage.js +1 -1
- package/DEV-cjs/core/NonIdealState/NonIdealState.js +2 -1
- package/DEV-cjs/core/NotificationMarker/NotificationMarker.js +2 -1
- package/DEV-cjs/core/Overlay/Overlay.js +8 -4
- package/DEV-cjs/core/Panels/Panels.js +13 -7
- package/DEV-cjs/core/Panels/helpers.js +2 -1
- package/DEV-cjs/core/Popover/Popover.js +35 -28
- package/DEV-cjs/core/ProgressIndicators/ProgressLinear.js +2 -1
- package/DEV-cjs/core/ProgressIndicators/ProgressRadial.js +2 -1
- package/DEV-cjs/core/Radio/Radio.js +1 -1
- package/DEV-cjs/core/RadioTiles/RadioTile.js +1 -1
- package/DEV-cjs/core/RadioTiles/RadioTileGroup.js +2 -1
- package/DEV-cjs/core/SearchBox/SearchBox.js +15 -8
- package/DEV-cjs/core/Select/Select.js +61 -48
- package/DEV-cjs/core/Select/SelectTag.js +1 -0
- package/DEV-cjs/core/SideNavigation/SideNavigation.js +3 -2
- package/DEV-cjs/core/SideNavigation/SidenavButton.js +2 -1
- package/DEV-cjs/core/SideNavigation/SidenavSubmenu.js +2 -1
- package/DEV-cjs/core/SideNavigation/SidenavSubmenuHeader.js +2 -1
- package/DEV-cjs/core/SkipToContentLink/SkipToContentLink.js +2 -1
- package/DEV-cjs/core/Slider/Slider.js +1 -1
- package/DEV-cjs/core/StatusMessage/StatusMessage.js +2 -1
- package/DEV-cjs/core/Stepper/Stepper.js +1 -1
- package/DEV-cjs/core/Stepper/WorkflowDiagram.js +2 -1
- package/DEV-cjs/core/Surface/Surface.js +7 -4
- package/DEV-cjs/core/Table/ColumnHeader.js +17 -17
- package/DEV-cjs/core/Table/Table.js +149 -57
- package/DEV-cjs/core/Table/TableCell.js +6 -4
- package/DEV-cjs/core/Table/actionHandlers/expandHandler.js +2 -4
- package/DEV-cjs/core/Table/actionHandlers/selectHandler.js +1 -4
- package/DEV-cjs/core/Table/cells/DefaultCell.js +31 -15
- package/DEV-cjs/core/Table/cells/EditableCell.js +2 -1
- package/DEV-cjs/core/Table/columns/expanderColumn.js +16 -17
- package/DEV-cjs/core/Table/columns/selectionColumn.js +4 -2
- package/DEV-cjs/core/Tabs/Tabs.js +82 -27
- package/DEV-cjs/core/Tag/Tag.js +1 -1
- package/DEV-cjs/core/Tag/TagContainer.js +2 -1
- package/DEV-cjs/core/Textarea/Textarea.js +1 -1
- package/DEV-cjs/core/ThemeProvider/ThemeProvider.js +34 -22
- package/DEV-cjs/core/Tile/Tile.js +56 -44
- package/DEV-cjs/core/TimePicker/TimePicker.js +2 -1
- package/DEV-cjs/core/Toast/Toaster.js +4 -2
- package/DEV-cjs/core/ToggleSwitch/ToggleSwitch.js +2 -1
- package/DEV-cjs/core/Tooltip/Tooltip.js +2 -2
- package/DEV-cjs/core/TransferList/TransferList.js +15 -11
- package/DEV-cjs/core/Tree/Tree.js +1 -1
- package/DEV-cjs/core/Tree/TreeNode.js +1 -1
- package/DEV-cjs/core/Tree/TreeNodeExpander.js +2 -1
- package/DEV-cjs/core/Typography/Anchor.js +1 -1
- package/DEV-cjs/core/Typography/Blockquote.js +2 -1
- package/DEV-cjs/core/Typography/Code.js +1 -1
- package/DEV-cjs/core/Typography/Kbd.js +1 -1
- package/DEV-cjs/core/Typography/Text.js +1 -1
- package/DEV-cjs/core/VisuallyHidden/VisuallyHidden.js +2 -1
- package/DEV-cjs/index.js +3 -0
- package/DEV-cjs/styles.js +1 -1
- package/DEV-cjs/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
- package/DEV-cjs/utils/components/ButtonBase.js +2 -1
- package/DEV-cjs/utils/components/InputWithIcon.js +2 -1
- package/DEV-cjs/utils/components/LineClamp.js +6 -0
- package/DEV-cjs/utils/components/MiddleTextTruncation.js +2 -1
- package/DEV-cjs/utils/components/OverflowContainer.js +6 -9
- package/DEV-cjs/utils/components/Portal.js +4 -8
- package/DEV-cjs/utils/components/ShadowRoot.js +10 -8
- package/DEV-cjs/utils/functions/polymorphic.js +2 -1
- package/DEV-cjs/utils/hooks/useGlobals.js +11 -2
- package/DEV-cjs/utils/hooks/useWarningLogger.js +29 -28
- package/DEV-cjs/utils/providers/index.js +0 -1
- package/DEV-esm/core/Alert/Alert.js +12 -6
- package/DEV-esm/core/Avatar/Avatar.js +1 -1
- package/DEV-esm/core/AvatarGroup/AvatarGroup.js +2 -1
- package/DEV-esm/core/Backdrop/Backdrop.js +1 -1
- package/DEV-esm/core/Badge/Badge.js +1 -1
- package/DEV-esm/core/Breadcrumbs/Breadcrumbs.js +8 -5
- package/DEV-esm/core/ButtonGroup/ButtonGroup.js +4 -2
- package/DEV-esm/core/Buttons/Button.js +1 -1
- package/DEV-esm/core/Buttons/DropdownButton.js +2 -1
- package/DEV-esm/core/Buttons/IconButton.js +8 -2
- package/DEV-esm/core/Buttons/IdeasButton.js +2 -1
- package/DEV-esm/core/Buttons/SplitButton.js +2 -1
- package/DEV-esm/core/Carousel/Carousel.js +2 -1
- package/DEV-esm/core/Carousel/CarouselContext.js +2 -1
- package/DEV-esm/core/Carousel/CarouselDot.js +2 -1
- package/DEV-esm/core/Carousel/CarouselDotsList.js +2 -1
- package/DEV-esm/core/Carousel/CarouselNavigation.js +6 -3
- package/DEV-esm/core/Carousel/CarouselSlide.js +2 -1
- package/DEV-esm/core/Carousel/CarouselSlider.js +2 -1
- package/DEV-esm/core/Checkbox/Checkbox.js +1 -1
- package/DEV-esm/core/ColorPicker/ColorBuilder.js +2 -1
- package/DEV-esm/core/ColorPicker/ColorInputPanel.js +4 -2
- package/DEV-esm/core/ColorPicker/ColorPalette.js +2 -1
- package/DEV-esm/core/ColorPicker/ColorPicker.js +2 -1
- package/DEV-esm/core/ColorPicker/ColorSwatch.js +2 -1
- package/DEV-esm/core/ComboBox/ComboBox.js +61 -29
- package/DEV-esm/core/ComboBox/ComboBoxEndIcon.js +2 -1
- package/DEV-esm/core/ComboBox/ComboBoxInput.js +2 -3
- package/DEV-esm/core/ComboBox/ComboBoxInputContainer.js +2 -1
- package/DEV-esm/core/ComboBox/ComboBoxMenu.js +2 -1
- package/DEV-esm/core/ComboBox/ComboBoxMenuItem.js +3 -2
- package/DEV-esm/core/ComboBox/ComboBoxMultipleContainer.js +2 -1
- package/DEV-esm/core/ComboBox/helpers.js +4 -2
- package/DEV-esm/core/DatePicker/DatePicker.js +5 -4
- package/DEV-esm/core/Dialog/Dialog.js +25 -10
- package/DEV-esm/core/Dialog/DialogBackdrop.js +7 -6
- package/DEV-esm/core/Dialog/DialogButtonBar.js +2 -1
- package/DEV-esm/core/Dialog/DialogContent.js +2 -1
- package/DEV-esm/core/Dialog/DialogContext.js +1 -1
- package/DEV-esm/core/Dialog/DialogMain.js +15 -14
- package/DEV-esm/core/Dialog/DialogTitleBar.js +5 -4
- package/DEV-esm/core/Dialog/DialogTitleBarTitle.js +2 -1
- package/DEV-esm/core/Divider/Divider.js +1 -1
- package/DEV-esm/core/DropdownMenu/DropdownMenu.js +32 -24
- package/DEV-esm/core/ExpandableBlock/ExpandableBlock.js +107 -91
- package/DEV-esm/core/Fieldset/Fieldset.js +1 -1
- package/DEV-esm/core/FileUpload/FileEmptyCard.js +6 -3
- package/DEV-esm/core/FileUpload/FileUpload.js +2 -1
- package/DEV-esm/core/FileUpload/FileUploadCard.js +18 -9
- package/DEV-esm/core/FileUpload/FileUploadTemplate.js +2 -1
- package/DEV-esm/core/Flex/Flex.js +4 -3
- package/DEV-esm/core/Footer/Footer.js +1 -1
- package/DEV-esm/core/Footer/FooterItem.js +2 -1
- package/DEV-esm/core/Footer/FooterList.js +2 -1
- package/DEV-esm/core/Footer/FooterSeparator.js +2 -1
- package/DEV-esm/core/Header/Header.js +1 -1
- package/DEV-esm/core/Header/HeaderBreadcrumbs.js +2 -1
- package/DEV-esm/core/Header/HeaderButton.js +2 -1
- package/DEV-esm/core/Header/HeaderLogo.js +3 -2
- package/DEV-esm/core/Icon/Icon.js +1 -1
- package/DEV-esm/core/InformationPanel/InformationPanel.js +2 -1
- package/DEV-esm/core/InformationPanel/InformationPanelBody.js +2 -1
- package/DEV-esm/core/InformationPanel/InformationPanelContent.js +2 -1
- package/DEV-esm/core/InformationPanel/InformationPanelHeader.js +2 -1
- package/DEV-esm/core/InformationPanel/InformationPanelWrapper.js +2 -1
- package/DEV-esm/core/Input/Input.js +1 -1
- package/DEV-esm/core/InputGrid/InputGrid.js +1 -1
- package/DEV-esm/core/InputGroup/InputGroup.js +2 -1
- package/DEV-esm/core/InputWithDecorations/InputWithDecorations.js +10 -5
- package/DEV-esm/core/Label/Label.js +1 -1
- package/DEV-esm/core/LabeledInput/LabeledInput.js +2 -1
- package/DEV-esm/core/LabeledSelect/LabeledSelect.js +5 -2
- package/DEV-esm/core/LabeledTextarea/LabeledTextarea.js +2 -1
- package/DEV-esm/core/LinkAction/LinkAction.js +4 -3
- package/DEV-esm/core/List/List.js +1 -1
- package/DEV-esm/core/List/ListItem.js +10 -5
- package/DEV-esm/core/Menu/Menu.js +4 -1
- package/DEV-esm/core/Menu/MenuDivider.js +2 -1
- package/DEV-esm/core/Menu/MenuExtraContent.js +3 -4
- package/DEV-esm/core/Menu/MenuItem.js +19 -12
- package/DEV-esm/core/Menu/MenuItemSkeleton.js +2 -1
- package/DEV-esm/core/Modal/Modal.js +1 -1
- package/DEV-esm/core/Modal/ModalButtonBar.js +2 -1
- package/DEV-esm/core/Modal/ModalContent.js +2 -1
- package/DEV-esm/core/NonIdealState/ErrorPage.js +1 -1
- package/DEV-esm/core/NonIdealState/NonIdealState.js +2 -1
- package/DEV-esm/core/NotificationMarker/NotificationMarker.js +2 -1
- package/DEV-esm/core/Overlay/Overlay.js +8 -4
- package/DEV-esm/core/Panels/Panels.js +13 -7
- package/DEV-esm/core/Panels/helpers.js +2 -1
- package/DEV-esm/core/Popover/Popover.js +39 -29
- package/DEV-esm/core/ProgressIndicators/ProgressLinear.js +2 -1
- package/DEV-esm/core/ProgressIndicators/ProgressRadial.js +2 -1
- package/DEV-esm/core/Radio/Radio.js +1 -1
- package/DEV-esm/core/RadioTiles/RadioTile.js +1 -1
- package/DEV-esm/core/RadioTiles/RadioTileGroup.js +2 -1
- package/DEV-esm/core/SearchBox/SearchBox.js +15 -8
- package/DEV-esm/core/Select/Select.js +61 -48
- package/DEV-esm/core/Select/SelectTag.js +1 -0
- package/DEV-esm/core/SideNavigation/SideNavigation.js +3 -2
- package/DEV-esm/core/SideNavigation/SidenavButton.js +2 -1
- package/DEV-esm/core/SideNavigation/SidenavSubmenu.js +2 -1
- package/DEV-esm/core/SideNavigation/SidenavSubmenuHeader.js +2 -1
- package/DEV-esm/core/SkipToContentLink/SkipToContentLink.js +2 -1
- package/DEV-esm/core/Slider/Slider.js +1 -1
- package/DEV-esm/core/StatusMessage/StatusMessage.js +2 -1
- package/DEV-esm/core/Stepper/Stepper.js +1 -1
- package/DEV-esm/core/Stepper/WorkflowDiagram.js +2 -1
- package/DEV-esm/core/Surface/Surface.js +7 -4
- package/DEV-esm/core/Table/ColumnHeader.js +17 -17
- package/DEV-esm/core/Table/Table.js +147 -57
- package/DEV-esm/core/Table/TableCell.js +6 -4
- package/DEV-esm/core/Table/actionHandlers/expandHandler.js +2 -4
- package/DEV-esm/core/Table/actionHandlers/selectHandler.js +1 -4
- package/DEV-esm/core/Table/cells/DefaultCell.js +31 -15
- package/DEV-esm/core/Table/cells/EditableCell.js +2 -1
- package/DEV-esm/core/Table/columns/expanderColumn.js +16 -17
- package/DEV-esm/core/Table/columns/selectionColumn.js +4 -2
- package/DEV-esm/core/Tabs/Tabs.js +75 -23
- package/DEV-esm/core/Tag/Tag.js +1 -1
- package/DEV-esm/core/Tag/TagContainer.js +2 -1
- package/DEV-esm/core/Textarea/Textarea.js +1 -1
- package/DEV-esm/core/ThemeProvider/ThemeProvider.js +34 -21
- package/DEV-esm/core/Tile/Tile.js +57 -48
- package/DEV-esm/core/TimePicker/TimePicker.js +2 -1
- package/DEV-esm/core/Toast/Toaster.js +4 -2
- package/DEV-esm/core/ToggleSwitch/ToggleSwitch.js +2 -1
- package/DEV-esm/core/Tooltip/Tooltip.js +2 -2
- package/DEV-esm/core/TransferList/TransferList.js +15 -11
- package/DEV-esm/core/Tree/Tree.js +1 -1
- package/DEV-esm/core/Tree/TreeNode.js +1 -1
- package/DEV-esm/core/Tree/TreeNodeExpander.js +2 -1
- package/DEV-esm/core/Typography/Anchor.js +1 -1
- package/DEV-esm/core/Typography/Blockquote.js +2 -1
- package/DEV-esm/core/Typography/Code.js +1 -1
- package/DEV-esm/core/Typography/Kbd.js +1 -1
- package/DEV-esm/core/Typography/Text.js +1 -1
- package/DEV-esm/core/VisuallyHidden/VisuallyHidden.js +2 -1
- package/DEV-esm/index.js +1 -1
- package/DEV-esm/styles.js +1 -1
- package/DEV-esm/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
- package/DEV-esm/utils/components/ButtonBase.js +2 -1
- package/DEV-esm/utils/components/InputWithIcon.js +2 -1
- package/DEV-esm/utils/components/LineClamp.js +3 -0
- package/DEV-esm/utils/components/MiddleTextTruncation.js +2 -1
- package/DEV-esm/utils/components/OverflowContainer.js +6 -9
- package/DEV-esm/utils/components/Portal.js +2 -4
- package/DEV-esm/utils/components/ShadowRoot.js +10 -8
- package/DEV-esm/utils/functions/polymorphic.js +2 -1
- package/DEV-esm/utils/hooks/useGlobals.js +11 -2
- package/DEV-esm/utils/hooks/useWarningLogger.js +29 -27
- package/DEV-esm/utils/providers/index.js +0 -1
- package/cjs/core/Alert/Alert.js +12 -0
- package/cjs/core/Avatar/Avatar.js +1 -0
- package/cjs/core/AvatarGroup/AvatarGroup.js +2 -0
- package/cjs/core/Backdrop/Backdrop.js +1 -0
- package/cjs/core/Badge/Badge.js +1 -0
- package/cjs/core/Breadcrumbs/Breadcrumbs.js +10 -1
- package/cjs/core/ButtonGroup/ButtonGroup.js +4 -0
- package/cjs/core/Buttons/Button.js +1 -0
- package/cjs/core/Buttons/DropdownButton.js +2 -0
- package/cjs/core/Buttons/IconButton.js +9 -0
- package/cjs/core/Buttons/IdeasButton.js +2 -0
- package/cjs/core/Buttons/SplitButton.js +2 -0
- package/cjs/core/Carousel/Carousel.js +2 -0
- package/cjs/core/Carousel/CarouselContext.js +2 -0
- package/cjs/core/Carousel/CarouselDot.js +2 -0
- package/cjs/core/Carousel/CarouselDotsList.js +2 -0
- package/cjs/core/Carousel/CarouselNavigation.js +6 -0
- package/cjs/core/Carousel/CarouselSlide.js +2 -0
- package/cjs/core/Carousel/CarouselSlider.js +2 -0
- package/cjs/core/Checkbox/Checkbox.js +1 -0
- package/cjs/core/ColorPicker/ColorBuilder.js +2 -0
- package/cjs/core/ColorPicker/ColorInputPanel.js +4 -1
- package/cjs/core/ColorPicker/ColorPalette.js +2 -0
- package/cjs/core/ColorPicker/ColorPicker.js +2 -0
- package/cjs/core/ColorPicker/ColorSwatch.js +2 -0
- package/cjs/core/ComboBox/ComboBox.js +61 -28
- package/cjs/core/ComboBox/ComboBoxEndIcon.js +2 -0
- package/cjs/core/ComboBox/ComboBoxInput.js +2 -2
- package/cjs/core/ComboBox/ComboBoxInputContainer.js +2 -0
- package/cjs/core/ComboBox/ComboBoxMenu.js +2 -0
- package/cjs/core/ComboBox/ComboBoxMenuItem.js +3 -1
- package/cjs/core/ComboBox/ComboBoxMultipleContainer.js +2 -0
- package/cjs/core/ComboBox/helpers.js +4 -0
- package/cjs/core/DatePicker/DatePicker.js +11 -2
- package/cjs/core/Dialog/Dialog.js +22 -11
- package/cjs/core/Dialog/DialogBackdrop.js +7 -5
- package/cjs/core/Dialog/DialogButtonBar.js +2 -0
- package/cjs/core/Dialog/DialogContent.js +2 -0
- package/cjs/core/Dialog/DialogContext.d.ts +8 -7
- package/cjs/core/Dialog/DialogContext.js +1 -1
- package/cjs/core/Dialog/DialogMain.d.ts +1 -1
- package/cjs/core/Dialog/DialogMain.js +20 -13
- package/cjs/core/Dialog/DialogTitleBar.js +5 -3
- package/cjs/core/Dialog/DialogTitleBarTitle.js +2 -0
- package/cjs/core/Divider/Divider.js +1 -0
- package/cjs/core/DropdownMenu/DropdownMenu.d.ts +7 -1
- package/cjs/core/DropdownMenu/DropdownMenu.js +32 -23
- package/cjs/core/ExpandableBlock/ExpandableBlock.d.ts +3 -0
- package/cjs/core/ExpandableBlock/ExpandableBlock.js +38 -3
- package/cjs/core/Fieldset/Fieldset.js +1 -0
- package/cjs/core/FileUpload/FileEmptyCard.js +6 -0
- package/cjs/core/FileUpload/FileUpload.js +2 -0
- package/cjs/core/FileUpload/FileUploadCard.js +18 -0
- package/cjs/core/FileUpload/FileUploadTemplate.js +2 -0
- package/cjs/core/Flex/Flex.js +4 -0
- package/cjs/core/Footer/Footer.js +1 -0
- package/cjs/core/Footer/FooterItem.js +2 -0
- package/cjs/core/Footer/FooterList.js +2 -0
- package/cjs/core/Footer/FooterSeparator.js +2 -0
- package/cjs/core/Header/Header.js +1 -0
- package/cjs/core/Header/HeaderBreadcrumbs.js +2 -0
- package/cjs/core/Header/HeaderButton.js +2 -0
- package/cjs/core/Header/HeaderLogo.js +3 -1
- package/cjs/core/Icon/Icon.js +1 -0
- package/cjs/core/InformationPanel/InformationPanel.js +2 -0
- package/cjs/core/InformationPanel/InformationPanelBody.js +2 -0
- package/cjs/core/InformationPanel/InformationPanelContent.js +2 -0
- package/cjs/core/InformationPanel/InformationPanelHeader.js +2 -0
- package/cjs/core/InformationPanel/InformationPanelWrapper.js +2 -0
- package/cjs/core/Input/Input.js +1 -0
- package/cjs/core/InputGrid/InputGrid.js +1 -0
- package/cjs/core/InputGroup/InputGroup.js +2 -0
- package/cjs/core/InputWithDecorations/InputWithDecorations.js +10 -0
- package/cjs/core/Label/Label.js +1 -0
- package/cjs/core/LabeledInput/LabeledInput.js +2 -0
- package/cjs/core/LabeledSelect/LabeledSelect.js +5 -1
- package/cjs/core/LabeledTextarea/LabeledTextarea.js +2 -0
- package/cjs/core/LinkAction/LinkAction.js +4 -1
- package/cjs/core/List/List.js +1 -0
- package/cjs/core/List/ListItem.js +10 -0
- package/cjs/core/Menu/Menu.d.ts +3 -1
- package/cjs/core/Menu/Menu.js +3 -1
- package/cjs/core/Menu/MenuDivider.js +2 -0
- package/cjs/core/Menu/MenuExtraContent.d.ts +1 -1
- package/cjs/core/Menu/MenuExtraContent.js +3 -3
- package/cjs/core/Menu/MenuItem.js +23 -10
- package/cjs/core/Menu/MenuItemSkeleton.js +2 -0
- package/cjs/core/Modal/Modal.d.ts +1 -1
- package/cjs/core/Modal/Modal.js +1 -0
- package/cjs/core/Modal/ModalButtonBar.js +2 -0
- package/cjs/core/Modal/ModalContent.js +2 -0
- package/cjs/core/NonIdealState/ErrorPage.js +1 -0
- package/cjs/core/NonIdealState/NonIdealState.js +2 -0
- package/cjs/core/NotificationMarker/NotificationMarker.js +2 -0
- package/cjs/core/Overlay/Overlay.js +8 -0
- package/cjs/core/Panels/Panels.js +13 -0
- package/cjs/core/Panels/helpers.js +2 -0
- package/cjs/core/Popover/Popover.js +35 -27
- package/cjs/core/ProgressIndicators/ProgressLinear.js +2 -0
- package/cjs/core/ProgressIndicators/ProgressRadial.js +2 -0
- package/cjs/core/Radio/Radio.js +1 -0
- package/cjs/core/RadioTiles/RadioTile.js +1 -0
- package/cjs/core/RadioTiles/RadioTileGroup.js +2 -0
- package/cjs/core/SearchBox/SearchBox.js +15 -0
- package/cjs/core/Select/Select.js +61 -47
- package/cjs/core/Select/SelectTag.js +1 -0
- package/cjs/core/SideNavigation/SideNavigation.d.ts +5 -1
- package/cjs/core/SideNavigation/SideNavigation.js +3 -1
- package/cjs/core/SideNavigation/SidenavButton.js +2 -0
- package/cjs/core/SideNavigation/SidenavSubmenu.js +2 -0
- package/cjs/core/SideNavigation/SidenavSubmenuHeader.js +2 -0
- package/cjs/core/SkipToContentLink/SkipToContentLink.js +2 -0
- package/cjs/core/Slider/Slider.js +1 -0
- package/cjs/core/StatusMessage/StatusMessage.js +2 -0
- package/cjs/core/Stepper/Stepper.js +1 -0
- package/cjs/core/Stepper/WorkflowDiagram.js +2 -0
- package/cjs/core/Surface/Surface.js +7 -0
- package/cjs/core/Table/ColumnHeader.js +17 -17
- package/cjs/core/Table/Table.d.ts +27 -1
- package/cjs/core/Table/Table.js +154 -53
- package/cjs/core/Table/TableCell.js +6 -4
- package/cjs/core/Table/actionHandlers/expandHandler.js +2 -4
- package/cjs/core/Table/actionHandlers/selectHandler.js +1 -4
- package/cjs/core/Table/cells/DefaultCell.js +31 -14
- package/cjs/core/Table/cells/EditableCell.js +2 -0
- package/cjs/core/Table/columns/expanderColumn.js +16 -17
- package/cjs/core/Table/columns/selectionColumn.js +4 -2
- package/cjs/core/Tabs/Tabs.d.ts +37 -0
- package/cjs/core/Tabs/Tabs.js +82 -16
- package/cjs/core/Tag/Tag.js +1 -0
- package/cjs/core/Tag/TagContainer.js +2 -0
- package/cjs/core/Textarea/Textarea.js +1 -0
- package/cjs/core/ThemeProvider/ThemeProvider.js +57 -21
- package/cjs/core/Tile/Tile.js +56 -26
- package/cjs/core/TimePicker/TimePicker.js +2 -0
- package/cjs/core/Toast/Toaster.js +4 -0
- package/cjs/core/ToggleSwitch/ToggleSwitch.js +2 -0
- package/cjs/core/Tooltip/Tooltip.js +2 -1
- package/cjs/core/TransferList/TransferList.js +15 -4
- package/cjs/core/Tree/Tree.js +1 -0
- package/cjs/core/Tree/TreeNode.js +1 -0
- package/cjs/core/Tree/TreeNodeExpander.js +2 -0
- package/cjs/core/Typography/Anchor.js +1 -0
- package/cjs/core/Typography/Blockquote.js +2 -0
- package/cjs/core/Typography/Code.js +1 -0
- package/cjs/core/Typography/Kbd.js +1 -0
- package/cjs/core/Typography/Text.js +1 -0
- package/cjs/core/VisuallyHidden/VisuallyHidden.js +2 -0
- package/cjs/index.d.ts +1 -1
- package/cjs/index.js +3 -0
- package/cjs/styles.js +1 -1
- package/cjs/utils/components/AutoclearingHiddenLiveRegion.d.ts +2 -2
- package/cjs/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
- package/cjs/utils/components/ButtonBase.js +2 -0
- package/cjs/utils/components/InputWithIcon.js +2 -0
- package/cjs/utils/components/LineClamp.js +6 -0
- package/cjs/utils/components/MiddleTextTruncation.js +2 -0
- package/cjs/utils/components/OverflowContainer.js +6 -8
- package/cjs/utils/components/Portal.d.ts +3 -5
- package/cjs/utils/components/Portal.js +4 -8
- package/cjs/utils/components/ShadowRoot.d.ts +11 -2
- package/cjs/utils/components/ShadowRoot.js +10 -8
- package/cjs/utils/functions/polymorphic.js +2 -0
- package/cjs/utils/hooks/useGlobals.js +29 -2
- package/cjs/utils/hooks/useWarningLogger.js +29 -1
- package/cjs/utils/providers/index.d.ts +0 -1
- package/cjs/utils/providers/index.js +0 -1
- package/esm/core/Alert/Alert.js +12 -0
- package/esm/core/Avatar/Avatar.js +1 -0
- package/esm/core/AvatarGroup/AvatarGroup.js +2 -0
- package/esm/core/Backdrop/Backdrop.js +1 -0
- package/esm/core/Badge/Badge.js +1 -0
- package/esm/core/Breadcrumbs/Breadcrumbs.js +10 -1
- package/esm/core/ButtonGroup/ButtonGroup.js +4 -0
- package/esm/core/Buttons/Button.js +1 -0
- package/esm/core/Buttons/DropdownButton.js +2 -0
- package/esm/core/Buttons/IconButton.js +9 -0
- package/esm/core/Buttons/IdeasButton.js +2 -0
- package/esm/core/Buttons/SplitButton.js +2 -0
- package/esm/core/Carousel/Carousel.js +2 -0
- package/esm/core/Carousel/CarouselContext.js +2 -0
- package/esm/core/Carousel/CarouselDot.js +2 -0
- package/esm/core/Carousel/CarouselDotsList.js +2 -0
- package/esm/core/Carousel/CarouselNavigation.js +6 -0
- package/esm/core/Carousel/CarouselSlide.js +2 -0
- package/esm/core/Carousel/CarouselSlider.js +2 -0
- package/esm/core/Checkbox/Checkbox.js +1 -0
- package/esm/core/ColorPicker/ColorBuilder.js +2 -0
- package/esm/core/ColorPicker/ColorInputPanel.js +4 -1
- package/esm/core/ColorPicker/ColorPalette.js +2 -0
- package/esm/core/ColorPicker/ColorPicker.js +2 -0
- package/esm/core/ColorPicker/ColorSwatch.js +2 -0
- package/esm/core/ComboBox/ComboBox.js +61 -28
- package/esm/core/ComboBox/ComboBoxEndIcon.js +2 -0
- package/esm/core/ComboBox/ComboBoxInput.js +2 -2
- package/esm/core/ComboBox/ComboBoxInputContainer.js +2 -0
- package/esm/core/ComboBox/ComboBoxMenu.js +2 -0
- package/esm/core/ComboBox/ComboBoxMenuItem.js +3 -1
- package/esm/core/ComboBox/ComboBoxMultipleContainer.js +2 -0
- package/esm/core/ComboBox/helpers.js +4 -0
- package/esm/core/DatePicker/DatePicker.js +11 -2
- package/esm/core/Dialog/Dialog.js +25 -9
- package/esm/core/Dialog/DialogBackdrop.js +7 -5
- package/esm/core/Dialog/DialogButtonBar.js +2 -0
- package/esm/core/Dialog/DialogContent.js +2 -0
- package/esm/core/Dialog/DialogContext.d.ts +8 -7
- package/esm/core/Dialog/DialogContext.js +1 -1
- package/esm/core/Dialog/DialogMain.d.ts +1 -1
- package/esm/core/Dialog/DialogMain.js +15 -13
- package/esm/core/Dialog/DialogTitleBar.js +5 -3
- package/esm/core/Dialog/DialogTitleBarTitle.js +2 -0
- package/esm/core/Divider/Divider.js +1 -0
- package/esm/core/DropdownMenu/DropdownMenu.d.ts +7 -1
- package/esm/core/DropdownMenu/DropdownMenu.js +32 -23
- package/esm/core/ExpandableBlock/ExpandableBlock.d.ts +3 -0
- package/esm/core/ExpandableBlock/ExpandableBlock.js +107 -81
- package/esm/core/Fieldset/Fieldset.js +1 -0
- package/esm/core/FileUpload/FileEmptyCard.js +6 -0
- package/esm/core/FileUpload/FileUpload.js +2 -0
- package/esm/core/FileUpload/FileUploadCard.js +18 -0
- package/esm/core/FileUpload/FileUploadTemplate.js +2 -0
- package/esm/core/Flex/Flex.js +4 -0
- package/esm/core/Footer/Footer.js +1 -0
- package/esm/core/Footer/FooterItem.js +2 -0
- package/esm/core/Footer/FooterList.js +2 -0
- package/esm/core/Footer/FooterSeparator.js +2 -0
- package/esm/core/Header/Header.js +1 -0
- package/esm/core/Header/HeaderBreadcrumbs.js +2 -0
- package/esm/core/Header/HeaderButton.js +2 -0
- package/esm/core/Header/HeaderLogo.js +3 -1
- package/esm/core/Icon/Icon.js +1 -0
- package/esm/core/InformationPanel/InformationPanel.js +2 -0
- package/esm/core/InformationPanel/InformationPanelBody.js +2 -0
- package/esm/core/InformationPanel/InformationPanelContent.js +2 -0
- package/esm/core/InformationPanel/InformationPanelHeader.js +2 -0
- package/esm/core/InformationPanel/InformationPanelWrapper.js +2 -0
- package/esm/core/Input/Input.js +1 -0
- package/esm/core/InputGrid/InputGrid.js +1 -0
- package/esm/core/InputGroup/InputGroup.js +2 -0
- package/esm/core/InputWithDecorations/InputWithDecorations.js +10 -0
- package/esm/core/Label/Label.js +1 -0
- package/esm/core/LabeledInput/LabeledInput.js +2 -0
- package/esm/core/LabeledSelect/LabeledSelect.js +5 -1
- package/esm/core/LabeledTextarea/LabeledTextarea.js +2 -0
- package/esm/core/LinkAction/LinkAction.js +4 -1
- package/esm/core/List/List.js +1 -0
- package/esm/core/List/ListItem.js +10 -0
- package/esm/core/Menu/Menu.d.ts +3 -1
- package/esm/core/Menu/Menu.js +4 -1
- package/esm/core/Menu/MenuDivider.js +2 -0
- package/esm/core/Menu/MenuExtraContent.d.ts +1 -1
- package/esm/core/Menu/MenuExtraContent.js +3 -3
- package/esm/core/Menu/MenuItem.js +22 -10
- package/esm/core/Menu/MenuItemSkeleton.js +2 -0
- package/esm/core/Modal/Modal.d.ts +1 -1
- package/esm/core/Modal/Modal.js +1 -0
- package/esm/core/Modal/ModalButtonBar.js +2 -0
- package/esm/core/Modal/ModalContent.js +2 -0
- package/esm/core/NonIdealState/ErrorPage.js +1 -0
- package/esm/core/NonIdealState/NonIdealState.js +2 -0
- package/esm/core/NotificationMarker/NotificationMarker.js +2 -0
- package/esm/core/Overlay/Overlay.js +8 -0
- package/esm/core/Panels/Panels.js +13 -0
- package/esm/core/Panels/helpers.js +2 -0
- package/esm/core/Popover/Popover.js +39 -28
- package/esm/core/ProgressIndicators/ProgressLinear.js +2 -0
- package/esm/core/ProgressIndicators/ProgressRadial.js +2 -0
- package/esm/core/Radio/Radio.js +1 -0
- package/esm/core/RadioTiles/RadioTile.js +1 -0
- package/esm/core/RadioTiles/RadioTileGroup.js +2 -0
- package/esm/core/SearchBox/SearchBox.js +15 -0
- package/esm/core/Select/Select.js +61 -47
- package/esm/core/Select/SelectTag.js +1 -0
- package/esm/core/SideNavigation/SideNavigation.d.ts +5 -1
- package/esm/core/SideNavigation/SideNavigation.js +3 -1
- package/esm/core/SideNavigation/SidenavButton.js +2 -0
- package/esm/core/SideNavigation/SidenavSubmenu.js +2 -0
- package/esm/core/SideNavigation/SidenavSubmenuHeader.js +2 -0
- package/esm/core/SkipToContentLink/SkipToContentLink.js +2 -0
- package/esm/core/Slider/Slider.js +1 -0
- package/esm/core/StatusMessage/StatusMessage.js +2 -0
- package/esm/core/Stepper/Stepper.js +1 -0
- package/esm/core/Stepper/WorkflowDiagram.js +2 -0
- package/esm/core/Surface/Surface.js +7 -0
- package/esm/core/Table/ColumnHeader.js +17 -17
- package/esm/core/Table/Table.d.ts +27 -1
- package/esm/core/Table/Table.js +152 -53
- package/esm/core/Table/TableCell.js +6 -4
- package/esm/core/Table/actionHandlers/expandHandler.js +2 -4
- package/esm/core/Table/actionHandlers/selectHandler.js +1 -4
- package/esm/core/Table/cells/DefaultCell.js +31 -14
- package/esm/core/Table/cells/EditableCell.js +2 -0
- package/esm/core/Table/columns/expanderColumn.js +16 -17
- package/esm/core/Table/columns/selectionColumn.js +4 -2
- package/esm/core/Tabs/Tabs.d.ts +37 -0
- package/esm/core/Tabs/Tabs.js +75 -12
- package/esm/core/Tag/Tag.js +1 -0
- package/esm/core/Tag/TagContainer.js +2 -0
- package/esm/core/Textarea/Textarea.js +1 -0
- package/esm/core/ThemeProvider/ThemeProvider.js +57 -20
- package/esm/core/Tile/Tile.js +57 -30
- package/esm/core/TimePicker/TimePicker.js +2 -0
- package/esm/core/Toast/Toaster.js +4 -0
- package/esm/core/ToggleSwitch/ToggleSwitch.js +2 -0
- package/esm/core/Tooltip/Tooltip.js +2 -1
- package/esm/core/TransferList/TransferList.js +15 -4
- package/esm/core/Tree/Tree.js +1 -0
- package/esm/core/Tree/TreeNode.js +1 -0
- package/esm/core/Tree/TreeNodeExpander.js +2 -0
- package/esm/core/Typography/Anchor.js +1 -0
- package/esm/core/Typography/Blockquote.js +2 -0
- package/esm/core/Typography/Code.js +1 -0
- package/esm/core/Typography/Kbd.js +1 -0
- package/esm/core/Typography/Text.js +1 -0
- package/esm/core/VisuallyHidden/VisuallyHidden.js +2 -0
- package/esm/index.d.ts +1 -1
- package/esm/index.js +1 -1
- package/esm/styles.js +1 -1
- package/esm/utils/components/AutoclearingHiddenLiveRegion.d.ts +2 -2
- package/esm/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
- package/esm/utils/components/ButtonBase.js +2 -0
- package/esm/utils/components/InputWithIcon.js +2 -0
- package/esm/utils/components/LineClamp.js +3 -0
- package/esm/utils/components/MiddleTextTruncation.js +2 -0
- package/esm/utils/components/OverflowContainer.js +6 -8
- package/esm/utils/components/Portal.d.ts +3 -5
- package/esm/utils/components/Portal.js +2 -4
- package/esm/utils/components/ShadowRoot.d.ts +11 -2
- package/esm/utils/components/ShadowRoot.js +10 -8
- package/esm/utils/functions/polymorphic.js +2 -0
- package/esm/utils/hooks/useGlobals.js +29 -2
- package/esm/utils/hooks/useWarningLogger.js +29 -1
- package/esm/utils/providers/index.d.ts +0 -1
- package/esm/utils/providers/index.js +0 -1
- package/package.json +11 -12
- package/styles.css +10 -10
- package/DEV-cjs/utils/providers/ScopeProvider.js +0 -66
- package/DEV-esm/utils/providers/ScopeProvider.js +0 -43
- package/cjs/utils/providers/ScopeProvider.d.ts +0 -26
- package/cjs/utils/providers/ScopeProvider.js +0 -66
- package/esm/utils/providers/ScopeProvider.d.ts +0 -26
- package/esm/utils/providers/ScopeProvider.js +0 -43
|
@@ -27,7 +27,7 @@ export const Select = React.forwardRef((props, forwardedRef) => {
|
|
|
27
27
|
ref: forwardedRef,
|
|
28
28
|
});
|
|
29
29
|
});
|
|
30
|
-
Select.displayName = 'Select';
|
|
30
|
+
if ('development' === process.env.NODE_ENV) Select.displayName = 'Select';
|
|
31
31
|
let NativeSelect = React.forwardRef((props, forwardedRef) => {
|
|
32
32
|
let {
|
|
33
33
|
triggerProps,
|
|
@@ -132,6 +132,36 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
132
132
|
});
|
|
133
133
|
popoverProps?.onVisibleChange?.(false);
|
|
134
134
|
}, [popoverProps]);
|
|
135
|
+
let handleOptionSelection = React.useCallback(
|
|
136
|
+
(option, { isSelected = false } = {}) => {
|
|
137
|
+
if (isSingleOnChange(onChangeRef.current, multiple)) {
|
|
138
|
+
setUncontrolledValue(option.value);
|
|
139
|
+
onChangeRef.current?.(option.value);
|
|
140
|
+
hide();
|
|
141
|
+
} else {
|
|
142
|
+
setUncontrolledValue((prev) =>
|
|
143
|
+
isSelected
|
|
144
|
+
? prev?.filter((i) => option.value !== i)
|
|
145
|
+
: [...(prev ?? []), option.value],
|
|
146
|
+
);
|
|
147
|
+
onChangeRef.current?.(option.value, isSelected ? 'removed' : 'added');
|
|
148
|
+
}
|
|
149
|
+
if (isMultipleEnabled(value, multiple)) {
|
|
150
|
+
let prevSelectedValue = value || [];
|
|
151
|
+
let newSelectedValue = isSelected
|
|
152
|
+
? prevSelectedValue.filter((i) => option.value !== i)
|
|
153
|
+
: [...prevSelectedValue, option.value];
|
|
154
|
+
setLiveRegionSelection(
|
|
155
|
+
options
|
|
156
|
+
.filter((i) => newSelectedValue.includes(i.value))
|
|
157
|
+
.map((item) => item.label)
|
|
158
|
+
.filter(Boolean)
|
|
159
|
+
.join(', '),
|
|
160
|
+
);
|
|
161
|
+
}
|
|
162
|
+
},
|
|
163
|
+
[hide, multiple, onChangeRef, options, value],
|
|
164
|
+
);
|
|
135
165
|
let menuItems = React.useMemo(
|
|
136
166
|
() =>
|
|
137
167
|
options.map((option, index) => {
|
|
@@ -157,34 +187,9 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
157
187
|
: null,
|
|
158
188
|
onClick: () => {
|
|
159
189
|
if (option.disabled) return;
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
hide();
|
|
164
|
-
} else {
|
|
165
|
-
setUncontrolledValue((prev) =>
|
|
166
|
-
isSelected
|
|
167
|
-
? prev?.filter((i) => option.value !== i)
|
|
168
|
-
: [...(prev ?? []), option.value],
|
|
169
|
-
);
|
|
170
|
-
onChangeRef.current?.(
|
|
171
|
-
option.value,
|
|
172
|
-
isSelected ? 'removed' : 'added',
|
|
173
|
-
);
|
|
174
|
-
}
|
|
175
|
-
if (isMultipleEnabled(value, multiple)) {
|
|
176
|
-
let prevSelectedValue = value || [];
|
|
177
|
-
let newSelectedValue = isSelected
|
|
178
|
-
? prevSelectedValue.filter((i) => option.value !== i)
|
|
179
|
-
: [...prevSelectedValue, option.value];
|
|
180
|
-
setLiveRegionSelection(
|
|
181
|
-
options
|
|
182
|
-
.filter((i) => newSelectedValue.includes(i.value))
|
|
183
|
-
.map((item) => item.label)
|
|
184
|
-
.filter(Boolean)
|
|
185
|
-
.join(', '),
|
|
186
|
-
);
|
|
187
|
-
}
|
|
190
|
+
handleOptionSelection(option, {
|
|
191
|
+
isSelected,
|
|
192
|
+
});
|
|
188
193
|
},
|
|
189
194
|
ref: (el) => {
|
|
190
195
|
if (isSelected && !multiple)
|
|
@@ -197,7 +202,7 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
197
202
|
...menuItem.props,
|
|
198
203
|
});
|
|
199
204
|
}),
|
|
200
|
-
[
|
|
205
|
+
[handleOptionSelection, itemRenderer, multiple, options, value],
|
|
201
206
|
);
|
|
202
207
|
let selectedItems = React.useMemo(() => {
|
|
203
208
|
if (null == value) return;
|
|
@@ -214,12 +219,18 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
214
219
|
return index >= 0 ? index : 0;
|
|
215
220
|
}, [options, value]);
|
|
216
221
|
let tagRenderer = React.useCallback(
|
|
217
|
-
(
|
|
222
|
+
(option) =>
|
|
218
223
|
React.createElement(SelectTag, {
|
|
219
|
-
key:
|
|
220
|
-
label:
|
|
224
|
+
key: option.label,
|
|
225
|
+
label: option.label,
|
|
226
|
+
onRemove: () => {
|
|
227
|
+
handleOptionSelection(option, {
|
|
228
|
+
isSelected: true,
|
|
229
|
+
});
|
|
230
|
+
selectRef.current?.focus();
|
|
231
|
+
},
|
|
221
232
|
}),
|
|
222
|
-
[],
|
|
233
|
+
[handleOptionSelection],
|
|
223
234
|
);
|
|
224
235
|
let popover = usePopover({
|
|
225
236
|
visible: isOpen,
|
|
@@ -270,6 +281,7 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
270
281
|
},
|
|
271
282
|
triggerProps?.className,
|
|
272
283
|
),
|
|
284
|
+
'data-iui-multi': multiple,
|
|
273
285
|
},
|
|
274
286
|
(!selectedItems || 0 === selectedItems.length) &&
|
|
275
287
|
React.createElement(
|
|
@@ -281,10 +293,8 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
281
293
|
placeholder,
|
|
282
294
|
),
|
|
283
295
|
isMultipleEnabled(selectedItems, multiple)
|
|
284
|
-
? React.createElement(
|
|
285
|
-
|
|
286
|
-
selectedItemsRenderer: selectedItemRenderer,
|
|
287
|
-
tagRenderer: tagRenderer,
|
|
296
|
+
? React.createElement(AutoclearingHiddenLiveRegion, {
|
|
297
|
+
text: liveRegionSelection,
|
|
288
298
|
})
|
|
289
299
|
: React.createElement(SingleSelectButton, {
|
|
290
300
|
selectedItem: selectedItems,
|
|
@@ -295,9 +305,12 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
295
305
|
disabled: disabled,
|
|
296
306
|
isOpen: isOpen,
|
|
297
307
|
}),
|
|
298
|
-
multiple
|
|
299
|
-
? React.createElement(
|
|
300
|
-
|
|
308
|
+
isMultipleEnabled(selectedItems, multiple)
|
|
309
|
+
? React.createElement(MultipleSelectButton, {
|
|
310
|
+
selectedItems: selectedItems,
|
|
311
|
+
selectedItemsRenderer: selectedItemRenderer,
|
|
312
|
+
tagRenderer: tagRenderer,
|
|
313
|
+
size: 'small' === size ? 'small' : void 0,
|
|
301
314
|
})
|
|
302
315
|
: null,
|
|
303
316
|
),
|
|
@@ -396,6 +409,7 @@ let MultipleSelectButton = ({
|
|
|
396
409
|
selectedItems,
|
|
397
410
|
selectedItemsRenderer,
|
|
398
411
|
tagRenderer,
|
|
412
|
+
size,
|
|
399
413
|
}) => {
|
|
400
414
|
let selectedItemsElements = React.useMemo(() => {
|
|
401
415
|
if (!selectedItems) return [];
|
|
@@ -405,19 +419,18 @@ let MultipleSelectButton = ({
|
|
|
405
419
|
React.Fragment,
|
|
406
420
|
null,
|
|
407
421
|
selectedItems &&
|
|
408
|
-
selectedItemsRenderer &&
|
|
409
|
-
selectedItemsRenderer(selectedItems),
|
|
410
|
-
selectedItems &&
|
|
411
|
-
!selectedItemsRenderer &&
|
|
412
422
|
React.createElement(
|
|
413
423
|
Box,
|
|
414
424
|
{
|
|
415
425
|
as: 'span',
|
|
416
426
|
className: 'iui-content',
|
|
417
427
|
},
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
428
|
+
selectedItemsRenderer
|
|
429
|
+
? selectedItemsRenderer(selectedItems)
|
|
430
|
+
: React.createElement(SelectTagContainer, {
|
|
431
|
+
tags: selectedItemsElements,
|
|
432
|
+
'data-iui-size': size,
|
|
433
|
+
}),
|
|
421
434
|
),
|
|
422
435
|
);
|
|
423
436
|
};
|
|
@@ -44,6 +44,7 @@ export const SideNavigation = React.forwardRef((props, forwardedRef) => {
|
|
|
44
44
|
React.createElement(
|
|
45
45
|
Box,
|
|
46
46
|
{
|
|
47
|
+
as: 'nav',
|
|
47
48
|
...wrapperProps,
|
|
48
49
|
className: cx('iui-side-navigation-wrapper', wrapperProps?.className),
|
|
49
50
|
ref: forwardedRef,
|
|
@@ -56,7 +57,6 @@ export const SideNavigation = React.forwardRef((props, forwardedRef) => {
|
|
|
56
57
|
React.createElement(
|
|
57
58
|
Box,
|
|
58
59
|
{
|
|
59
|
-
as: 'div',
|
|
60
60
|
className: cx(
|
|
61
61
|
'iui-side-navigation',
|
|
62
62
|
{
|
|
@@ -101,4 +101,5 @@ export const SideNavigation = React.forwardRef((props, forwardedRef) => {
|
|
|
101
101
|
),
|
|
102
102
|
);
|
|
103
103
|
});
|
|
104
|
-
|
|
104
|
+
if ('development' === process.env.NODE_ENV)
|
|
105
|
+
SideNavigation.displayName = 'SideNavigation';
|
|
@@ -27,4 +27,5 @@ export const SidenavSubmenuHeader = React.forwardRef((props, forwardedRef) => {
|
|
|
27
27
|
),
|
|
28
28
|
);
|
|
29
29
|
});
|
|
30
|
-
|
|
30
|
+
if ('development' === process.env.NODE_ENV)
|
|
31
|
+
SidenavSubmenuHeader.displayName = 'SidenavSubmenuHeader';
|
|
@@ -35,4 +35,5 @@ export const StatusMessage = React.forwardRef((props, ref) => {
|
|
|
35
35
|
React.createElement(Box, contentProps, children),
|
|
36
36
|
);
|
|
37
37
|
});
|
|
38
|
-
|
|
38
|
+
if ('development' === process.env.NODE_ENV)
|
|
39
|
+
StatusMessage.displayName = 'StatusMessage';
|
|
@@ -39,7 +39,8 @@ let SurfaceHeader = React.forwardRef((props, ref) => {
|
|
|
39
39
|
children,
|
|
40
40
|
);
|
|
41
41
|
});
|
|
42
|
-
|
|
42
|
+
if ('development' === process.env.NODE_ENV)
|
|
43
|
+
SurfaceHeader.displayName = 'Surface.Header';
|
|
43
44
|
let SurfaceBody = React.forwardRef((props, ref) => {
|
|
44
45
|
let { children, className, isPadded = false, ...rest } = props;
|
|
45
46
|
let { setHasLayout } = useSafeContext(SurfaceContext);
|
|
@@ -57,7 +58,8 @@ let SurfaceBody = React.forwardRef((props, ref) => {
|
|
|
57
58
|
children,
|
|
58
59
|
);
|
|
59
60
|
});
|
|
60
|
-
|
|
61
|
+
if ('development' === process.env.NODE_ENV)
|
|
62
|
+
SurfaceBody.displayName = 'Surface.Body';
|
|
61
63
|
export const Surface = Object.assign(
|
|
62
64
|
React.forwardRef((props, ref) => {
|
|
63
65
|
let {
|
|
@@ -99,6 +101,7 @@ export const Surface = Object.assign(
|
|
|
99
101
|
Body: SurfaceBody,
|
|
100
102
|
},
|
|
101
103
|
);
|
|
102
|
-
Surface.displayName = 'Surface';
|
|
104
|
+
if ('development' === process.env.NODE_ENV) Surface.displayName = 'Surface';
|
|
103
105
|
let SurfaceContext = React.createContext(void 0);
|
|
104
|
-
|
|
106
|
+
if ('development' === process.env.NODE_ENV)
|
|
107
|
+
SurfaceContext.displayName = 'SurfaceContext';
|
|
@@ -100,26 +100,26 @@ export const ColumnHeader = React.forwardRef((props, forwardedRef) => {
|
|
|
100
100
|
React.createElement(
|
|
101
101
|
React.Fragment,
|
|
102
102
|
null,
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
103
|
+
'string' == typeof column.Header
|
|
104
|
+
? React.createElement(
|
|
105
|
+
ShadowRoot,
|
|
106
|
+
null,
|
|
107
|
+
React.createElement(
|
|
108
108
|
LineClamp,
|
|
109
109
|
null,
|
|
110
110
|
React.createElement('slot', null),
|
|
111
|
-
)
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
111
|
+
),
|
|
112
|
+
React.createElement('slot', {
|
|
113
|
+
name: 'actions',
|
|
114
|
+
}),
|
|
115
|
+
React.createElement('slot', {
|
|
116
|
+
name: 'resizers',
|
|
117
|
+
}),
|
|
118
|
+
React.createElement('slot', {
|
|
119
|
+
name: 'shadows',
|
|
120
|
+
}),
|
|
121
|
+
)
|
|
122
|
+
: null,
|
|
123
123
|
column.render('Header'),
|
|
124
124
|
(showFilterButton(column) || showSortButton(column)) &&
|
|
125
125
|
React.createElement(
|
|
@@ -23,6 +23,7 @@ import {
|
|
|
23
23
|
useMergedRefs,
|
|
24
24
|
useLatestRef,
|
|
25
25
|
useVirtualScroll,
|
|
26
|
+
useId,
|
|
26
27
|
} from '../../utils/index.js';
|
|
27
28
|
import { TableInstanceContext } from './utils.js';
|
|
28
29
|
import { TableRowMemoized } from './TableRowMemoized.js';
|
|
@@ -49,6 +50,7 @@ import {
|
|
|
49
50
|
import { SELECTION_CELL_ID } from './columns/index.js';
|
|
50
51
|
import { ColumnHeader } from './ColumnHeader.js';
|
|
51
52
|
import { TableExpandableContentMemoized } from './TableExpandableContentMemoized.js';
|
|
53
|
+
import { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden.js';
|
|
52
54
|
let singleRowSelectedAction = 'singleRowSelected';
|
|
53
55
|
let shiftRowSelectedAction = 'shiftRowSelected';
|
|
54
56
|
export const tableResizeStartAction = 'tableResizeStart';
|
|
@@ -105,10 +107,45 @@ export const Table = (props) => {
|
|
|
105
107
|
headerWrapperProps,
|
|
106
108
|
headerProps,
|
|
107
109
|
bodyProps,
|
|
110
|
+
tableProps,
|
|
108
111
|
emptyTableContentProps,
|
|
109
112
|
getRowId,
|
|
110
|
-
|
|
113
|
+
caption = 'Table',
|
|
114
|
+
role,
|
|
115
|
+
scrollToRow,
|
|
116
|
+
..._rest
|
|
111
117
|
} = props;
|
|
118
|
+
let { ariaRestAttributes, nonAriaRestAttributes } = React.useMemo(
|
|
119
|
+
() =>
|
|
120
|
+
Object.entries(_rest).reduce(
|
|
121
|
+
(result, [key, value]) => {
|
|
122
|
+
if (key.startsWith('aria-')) result.ariaRestAttributes[key] = value;
|
|
123
|
+
else result.nonAriaRestAttributes[key] = value;
|
|
124
|
+
return result;
|
|
125
|
+
},
|
|
126
|
+
{
|
|
127
|
+
ariaRestAttributes: {},
|
|
128
|
+
nonAriaRestAttributes: {},
|
|
129
|
+
},
|
|
130
|
+
),
|
|
131
|
+
[_rest],
|
|
132
|
+
);
|
|
133
|
+
let { outerAriaRestAttributes, innerAriaRestAttributes } =
|
|
134
|
+
React.useMemo(() => {
|
|
135
|
+
if (tableProps || role)
|
|
136
|
+
return {
|
|
137
|
+
outerAriaRestAttributes: {
|
|
138
|
+
...ariaRestAttributes,
|
|
139
|
+
},
|
|
140
|
+
innerAriaRestAttributes: {},
|
|
141
|
+
};
|
|
142
|
+
return {
|
|
143
|
+
outerAriaRestAttributes: {},
|
|
144
|
+
innerAriaRestAttributes: {
|
|
145
|
+
...ariaRestAttributes,
|
|
146
|
+
},
|
|
147
|
+
};
|
|
148
|
+
}, [ariaRestAttributes, role, tableProps]);
|
|
112
149
|
useGlobals();
|
|
113
150
|
let ownerDocument = React.useRef(void 0);
|
|
114
151
|
let defaultColumn = React.useMemo(
|
|
@@ -322,22 +359,19 @@ export const Table = (props) => {
|
|
|
322
359
|
let logWarning = useWarningLogger();
|
|
323
360
|
if (1 === columns.length && 'columns' in columns[0]) {
|
|
324
361
|
headerGroups = _headerGroups.slice(1);
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
362
|
+
if ('development' === process.env.NODE_ENV)
|
|
363
|
+
logWarning(
|
|
364
|
+
"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",
|
|
365
|
+
);
|
|
328
366
|
}
|
|
329
|
-
if (
|
|
367
|
+
if (
|
|
368
|
+
'development' === process.env.NODE_ENV &&
|
|
369
|
+
subComponent &&
|
|
370
|
+
data.some((item) => !!item.subRows?.length)
|
|
371
|
+
)
|
|
330
372
|
logWarning(
|
|
331
373
|
'Passing both `subComponent` and `data` with `subRows` is not supported. There are features designed for `subRows` that are not compatible with `subComponent` and vice versa.',
|
|
332
374
|
);
|
|
333
|
-
let ariaDataAttributes = Object.entries(rest).reduce(
|
|
334
|
-
(result, [key, value]) => {
|
|
335
|
-
if (key.startsWith('data-') || key.startsWith('aria-'))
|
|
336
|
-
result[key] = value;
|
|
337
|
-
return result;
|
|
338
|
-
},
|
|
339
|
-
{},
|
|
340
|
-
);
|
|
341
375
|
let areFiltersSet =
|
|
342
376
|
allColumns.some(
|
|
343
377
|
(column) => null != column.filterValue && '' !== column.filterValue,
|
|
@@ -352,7 +386,7 @@ export const Table = (props) => {
|
|
|
352
386
|
!isDisabled &&
|
|
353
387
|
selectRowOnClick &&
|
|
354
388
|
!event.isDefaultPrevented()
|
|
355
|
-
)
|
|
389
|
+
)
|
|
356
390
|
if ('multi' === selectionMode && event.shiftKey)
|
|
357
391
|
dispatch({
|
|
358
392
|
type: shiftRowSelectedAction,
|
|
@@ -366,7 +400,6 @@ export const Table = (props) => {
|
|
|
366
400
|
type: singleRowSelectedAction,
|
|
367
401
|
id: row.id,
|
|
368
402
|
});
|
|
369
|
-
}
|
|
370
403
|
},
|
|
371
404
|
[
|
|
372
405
|
isRowDisabled,
|
|
@@ -425,6 +458,7 @@ export const Table = (props) => {
|
|
|
425
458
|
let tableRef = React.useRef(null);
|
|
426
459
|
let { scrollToIndex, tableRowRef } = useScrollToRow({
|
|
427
460
|
...props,
|
|
461
|
+
scrollToRow,
|
|
428
462
|
page,
|
|
429
463
|
});
|
|
430
464
|
let columnRefs = React.useRef({});
|
|
@@ -567,6 +601,7 @@ export const Table = (props) => {
|
|
|
567
601
|
React.useEffect(() => {
|
|
568
602
|
updateStickyState();
|
|
569
603
|
}, []);
|
|
604
|
+
let captionId = useId();
|
|
570
605
|
return React.createElement(
|
|
571
606
|
TableInstanceContext.Provider,
|
|
572
607
|
{
|
|
@@ -590,10 +625,46 @@ export const Table = (props) => {
|
|
|
590
625
|
...style,
|
|
591
626
|
},
|
|
592
627
|
}),
|
|
628
|
+
role: role,
|
|
629
|
+
'aria-labelledby': captionId,
|
|
593
630
|
onScroll: () => updateStickyState(),
|
|
594
631
|
'data-iui-size': 'default' === density ? void 0 : density,
|
|
595
|
-
...
|
|
632
|
+
...outerAriaRestAttributes,
|
|
633
|
+
...nonAriaRestAttributes,
|
|
596
634
|
},
|
|
635
|
+
React.createElement(
|
|
636
|
+
ShadowRoot,
|
|
637
|
+
null,
|
|
638
|
+
React.createElement(
|
|
639
|
+
'div',
|
|
640
|
+
{
|
|
641
|
+
role: 'table',
|
|
642
|
+
...innerAriaRestAttributes,
|
|
643
|
+
...tableProps,
|
|
644
|
+
},
|
|
645
|
+
React.createElement('slot', {
|
|
646
|
+
name: 'caption',
|
|
647
|
+
}),
|
|
648
|
+
React.createElement('slot', {
|
|
649
|
+
name: 'iui-table-header-wrapper',
|
|
650
|
+
}),
|
|
651
|
+
React.createElement('slot', {
|
|
652
|
+
name: 'iui-table-body',
|
|
653
|
+
}),
|
|
654
|
+
),
|
|
655
|
+
React.createElement('slot', {
|
|
656
|
+
name: 'iui-table-body-extra',
|
|
657
|
+
}),
|
|
658
|
+
React.createElement('slot', null),
|
|
659
|
+
),
|
|
660
|
+
React.createElement(
|
|
661
|
+
VisuallyHidden,
|
|
662
|
+
{
|
|
663
|
+
slot: 'caption',
|
|
664
|
+
id: captionId,
|
|
665
|
+
},
|
|
666
|
+
caption,
|
|
667
|
+
),
|
|
597
668
|
headerGroups.map((headerGroup) => {
|
|
598
669
|
headerGroup.headers = headerGroup.headers.filter(
|
|
599
670
|
(header) =>
|
|
@@ -606,6 +677,7 @@ export const Table = (props) => {
|
|
|
606
677
|
return React.createElement(
|
|
607
678
|
Box,
|
|
608
679
|
{
|
|
680
|
+
slot: 'iui-table-header-wrapper',
|
|
609
681
|
as: 'div',
|
|
610
682
|
key: headerGroupProps.key,
|
|
611
683
|
...headerWrapperProps,
|
|
@@ -658,6 +730,7 @@ export const Table = (props) => {
|
|
|
658
730
|
React.createElement(
|
|
659
731
|
Box,
|
|
660
732
|
{
|
|
733
|
+
slot: 'iui-table-body',
|
|
661
734
|
as: 'div',
|
|
662
735
|
...bodyProps,
|
|
663
736
|
...getTableBodyProps({
|
|
@@ -669,13 +742,13 @@ export const Table = (props) => {
|
|
|
669
742
|
bodyProps?.className,
|
|
670
743
|
),
|
|
671
744
|
}),
|
|
672
|
-
|
|
673
|
-
(isSelectable && 'multi' === selectionMode) || void 0,
|
|
745
|
+
role: void 0,
|
|
674
746
|
},
|
|
675
747
|
React.createElement(
|
|
676
748
|
ShadowRoot,
|
|
677
749
|
{
|
|
678
750
|
css: virtualizerCss,
|
|
751
|
+
flush: false,
|
|
679
752
|
},
|
|
680
753
|
enableVirtualization && 0 !== data.length
|
|
681
754
|
? React.createElement(
|
|
@@ -702,59 +775,49 @@ export const Table = (props) => {
|
|
|
702
775
|
)
|
|
703
776
|
: page.map((_, index) => getPreparedRow(index)),
|
|
704
777
|
),
|
|
705
|
-
|
|
706
|
-
|
|
778
|
+
),
|
|
779
|
+
isLoading &&
|
|
780
|
+
0 === data.length &&
|
|
781
|
+
React.createElement(
|
|
782
|
+
TableBodyExtraWrapper,
|
|
783
|
+
null,
|
|
707
784
|
React.createElement(
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
as: 'div',
|
|
711
|
-
...emptyTableContentProps,
|
|
712
|
-
className: cx(
|
|
713
|
-
'iui-table-empty',
|
|
714
|
-
emptyTableContentProps?.className,
|
|
715
|
-
),
|
|
716
|
-
},
|
|
785
|
+
TableEmptyWrapper,
|
|
786
|
+
emptyTableContentProps,
|
|
717
787
|
React.createElement(ProgressRadial, {
|
|
718
788
|
indeterminate: true,
|
|
719
789
|
}),
|
|
720
790
|
),
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
791
|
+
),
|
|
792
|
+
!isLoading &&
|
|
793
|
+
0 === data.length &&
|
|
794
|
+
!areFiltersSet &&
|
|
795
|
+
React.createElement(
|
|
796
|
+
TableBodyExtraWrapper,
|
|
797
|
+
null,
|
|
724
798
|
React.createElement(
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
as: 'div',
|
|
728
|
-
...emptyTableContentProps,
|
|
729
|
-
className: cx(
|
|
730
|
-
'iui-table-empty',
|
|
731
|
-
emptyTableContentProps?.className,
|
|
732
|
-
),
|
|
733
|
-
},
|
|
799
|
+
TableEmptyWrapper,
|
|
800
|
+
emptyTableContentProps,
|
|
734
801
|
React.createElement('div', null, emptyTableContent),
|
|
735
802
|
),
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
803
|
+
),
|
|
804
|
+
!isLoading &&
|
|
805
|
+
(0 === data.length || 0 === rows.length) &&
|
|
806
|
+
areFiltersSet &&
|
|
807
|
+
React.createElement(
|
|
808
|
+
TableBodyExtraWrapper,
|
|
809
|
+
null,
|
|
739
810
|
React.createElement(
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
as: 'div',
|
|
743
|
-
...emptyTableContentProps,
|
|
744
|
-
className: cx(
|
|
745
|
-
'iui-table-empty',
|
|
746
|
-
emptyTableContentProps?.className,
|
|
747
|
-
),
|
|
748
|
-
},
|
|
811
|
+
TableEmptyWrapper,
|
|
812
|
+
emptyTableContentProps,
|
|
749
813
|
React.createElement('div', null, emptyFilteredTableContent),
|
|
750
814
|
),
|
|
751
|
-
|
|
815
|
+
),
|
|
752
816
|
isLoading &&
|
|
753
817
|
0 !== data.length &&
|
|
754
818
|
React.createElement(
|
|
755
|
-
|
|
819
|
+
TableBodyExtraWrapper,
|
|
756
820
|
{
|
|
757
|
-
className: 'iui-table-body-extra',
|
|
758
821
|
'data-iui-loading': 'true',
|
|
759
822
|
},
|
|
760
823
|
React.createElement(ProgressRadial, {
|
|
@@ -766,4 +829,31 @@ export const Table = (props) => {
|
|
|
766
829
|
),
|
|
767
830
|
);
|
|
768
831
|
};
|
|
769
|
-
Table.displayName = 'Table';
|
|
832
|
+
if ('development' === process.env.NODE_ENV) Table.displayName = 'Table';
|
|
833
|
+
let TableBodyExtraWrapper = React.forwardRef((props, ref) => {
|
|
834
|
+
let { children, ...rest } = props;
|
|
835
|
+
return React.createElement(
|
|
836
|
+
Box,
|
|
837
|
+
{
|
|
838
|
+
as: 'div',
|
|
839
|
+
ref: ref,
|
|
840
|
+
slot: 'iui-table-body-extra',
|
|
841
|
+
...rest,
|
|
842
|
+
className: cx('iui-table-body-extra', rest.className),
|
|
843
|
+
},
|
|
844
|
+
children,
|
|
845
|
+
);
|
|
846
|
+
});
|
|
847
|
+
let TableEmptyWrapper = React.forwardRef((props, ref) => {
|
|
848
|
+
let { children, ...rest } = props;
|
|
849
|
+
return React.createElement(
|
|
850
|
+
Box,
|
|
851
|
+
{
|
|
852
|
+
as: 'div',
|
|
853
|
+
ref: ref,
|
|
854
|
+
...rest,
|
|
855
|
+
className: cx('iui-table-empty', rest.className),
|
|
856
|
+
},
|
|
857
|
+
children,
|
|
858
|
+
);
|
|
859
|
+
});
|