@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,6 +27,7 @@ export const Select = React.forwardRef((props, forwardedRef) => {
|
|
|
27
27
|
ref: forwardedRef,
|
|
28
28
|
});
|
|
29
29
|
});
|
|
30
|
+
if ('development' === process.env.NODE_ENV) Select.displayName = 'Select';
|
|
30
31
|
let NativeSelect = React.forwardRef((props, forwardedRef) => {
|
|
31
32
|
let {
|
|
32
33
|
triggerProps,
|
|
@@ -131,6 +132,36 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
131
132
|
});
|
|
132
133
|
popoverProps?.onVisibleChange?.(false);
|
|
133
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
|
+
);
|
|
134
165
|
let menuItems = React.useMemo(
|
|
135
166
|
() =>
|
|
136
167
|
options.map((option, index) => {
|
|
@@ -156,34 +187,9 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
156
187
|
: null,
|
|
157
188
|
onClick: () => {
|
|
158
189
|
if (option.disabled) return;
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
hide();
|
|
163
|
-
} else {
|
|
164
|
-
setUncontrolledValue((prev) =>
|
|
165
|
-
isSelected
|
|
166
|
-
? prev?.filter((i) => option.value !== i)
|
|
167
|
-
: [...(prev ?? []), option.value],
|
|
168
|
-
);
|
|
169
|
-
onChangeRef.current?.(
|
|
170
|
-
option.value,
|
|
171
|
-
isSelected ? 'removed' : 'added',
|
|
172
|
-
);
|
|
173
|
-
}
|
|
174
|
-
if (isMultipleEnabled(value, multiple)) {
|
|
175
|
-
let prevSelectedValue = value || [];
|
|
176
|
-
let newSelectedValue = isSelected
|
|
177
|
-
? prevSelectedValue.filter((i) => option.value !== i)
|
|
178
|
-
: [...prevSelectedValue, option.value];
|
|
179
|
-
setLiveRegionSelection(
|
|
180
|
-
options
|
|
181
|
-
.filter((i) => newSelectedValue.includes(i.value))
|
|
182
|
-
.map((item) => item.label)
|
|
183
|
-
.filter(Boolean)
|
|
184
|
-
.join(', '),
|
|
185
|
-
);
|
|
186
|
-
}
|
|
190
|
+
handleOptionSelection(option, {
|
|
191
|
+
isSelected,
|
|
192
|
+
});
|
|
187
193
|
},
|
|
188
194
|
ref: (el) => {
|
|
189
195
|
if (isSelected && !multiple)
|
|
@@ -196,7 +202,7 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
196
202
|
...menuItem.props,
|
|
197
203
|
});
|
|
198
204
|
}),
|
|
199
|
-
[
|
|
205
|
+
[handleOptionSelection, itemRenderer, multiple, options, value],
|
|
200
206
|
);
|
|
201
207
|
let selectedItems = React.useMemo(() => {
|
|
202
208
|
if (null == value) return;
|
|
@@ -213,12 +219,18 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
213
219
|
return index >= 0 ? index : 0;
|
|
214
220
|
}, [options, value]);
|
|
215
221
|
let tagRenderer = React.useCallback(
|
|
216
|
-
(
|
|
222
|
+
(option) =>
|
|
217
223
|
React.createElement(SelectTag, {
|
|
218
|
-
key:
|
|
219
|
-
label:
|
|
224
|
+
key: option.label,
|
|
225
|
+
label: option.label,
|
|
226
|
+
onRemove: () => {
|
|
227
|
+
handleOptionSelection(option, {
|
|
228
|
+
isSelected: true,
|
|
229
|
+
});
|
|
230
|
+
selectRef.current?.focus();
|
|
231
|
+
},
|
|
220
232
|
}),
|
|
221
|
-
[],
|
|
233
|
+
[handleOptionSelection],
|
|
222
234
|
);
|
|
223
235
|
let popover = usePopover({
|
|
224
236
|
visible: isOpen,
|
|
@@ -269,6 +281,7 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
269
281
|
},
|
|
270
282
|
triggerProps?.className,
|
|
271
283
|
),
|
|
284
|
+
'data-iui-multi': multiple,
|
|
272
285
|
},
|
|
273
286
|
(!selectedItems || 0 === selectedItems.length) &&
|
|
274
287
|
React.createElement(
|
|
@@ -280,10 +293,8 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
280
293
|
placeholder,
|
|
281
294
|
),
|
|
282
295
|
isMultipleEnabled(selectedItems, multiple)
|
|
283
|
-
? React.createElement(
|
|
284
|
-
|
|
285
|
-
selectedItemsRenderer: selectedItemRenderer,
|
|
286
|
-
tagRenderer: tagRenderer,
|
|
296
|
+
? React.createElement(AutoclearingHiddenLiveRegion, {
|
|
297
|
+
text: liveRegionSelection,
|
|
287
298
|
})
|
|
288
299
|
: React.createElement(SingleSelectButton, {
|
|
289
300
|
selectedItem: selectedItems,
|
|
@@ -294,9 +305,12 @@ let CustomSelect = React.forwardRef((props, forwardedRef) => {
|
|
|
294
305
|
disabled: disabled,
|
|
295
306
|
isOpen: isOpen,
|
|
296
307
|
}),
|
|
297
|
-
multiple
|
|
298
|
-
? React.createElement(
|
|
299
|
-
|
|
308
|
+
isMultipleEnabled(selectedItems, multiple)
|
|
309
|
+
? React.createElement(MultipleSelectButton, {
|
|
310
|
+
selectedItems: selectedItems,
|
|
311
|
+
selectedItemsRenderer: selectedItemRenderer,
|
|
312
|
+
tagRenderer: tagRenderer,
|
|
313
|
+
size: 'small' === size ? 'small' : void 0,
|
|
300
314
|
})
|
|
301
315
|
: null,
|
|
302
316
|
),
|
|
@@ -395,6 +409,7 @@ let MultipleSelectButton = ({
|
|
|
395
409
|
selectedItems,
|
|
396
410
|
selectedItemsRenderer,
|
|
397
411
|
tagRenderer,
|
|
412
|
+
size,
|
|
398
413
|
}) => {
|
|
399
414
|
let selectedItemsElements = React.useMemo(() => {
|
|
400
415
|
if (!selectedItems) return [];
|
|
@@ -404,19 +419,18 @@ let MultipleSelectButton = ({
|
|
|
404
419
|
React.Fragment,
|
|
405
420
|
null,
|
|
406
421
|
selectedItems &&
|
|
407
|
-
selectedItemsRenderer &&
|
|
408
|
-
selectedItemsRenderer(selectedItems),
|
|
409
|
-
selectedItems &&
|
|
410
|
-
!selectedItemsRenderer &&
|
|
411
422
|
React.createElement(
|
|
412
423
|
Box,
|
|
413
424
|
{
|
|
414
425
|
as: 'span',
|
|
415
426
|
className: 'iui-content',
|
|
416
427
|
},
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
428
|
+
selectedItemsRenderer
|
|
429
|
+
? selectedItemsRenderer(selectedItems)
|
|
430
|
+
: React.createElement(SelectTagContainer, {
|
|
431
|
+
tags: selectedItemsElements,
|
|
432
|
+
'data-iui-size': size,
|
|
433
|
+
}),
|
|
420
434
|
),
|
|
421
435
|
);
|
|
422
436
|
};
|
|
@@ -52,7 +52,7 @@ type SideNavigationProps = {
|
|
|
52
52
|
/**
|
|
53
53
|
* Passes props for SideNav wrapper.
|
|
54
54
|
*/
|
|
55
|
-
wrapperProps?: React.ComponentProps<'
|
|
55
|
+
wrapperProps?: React.ComponentProps<'nav'>;
|
|
56
56
|
/**
|
|
57
57
|
* Passes props for SideNav content.
|
|
58
58
|
*/
|
|
@@ -68,6 +68,10 @@ type SideNavigationProps = {
|
|
|
68
68
|
};
|
|
69
69
|
/**
|
|
70
70
|
* Left side navigation menu component.
|
|
71
|
+
*
|
|
72
|
+
* Renders a `<nav>` landmark, which can be labelled using `wrapperProps['aria-labelledby']`
|
|
73
|
+
* or `wrapperProps['aria-label']`.
|
|
74
|
+
*
|
|
71
75
|
* @example
|
|
72
76
|
* <SideNavigation
|
|
73
77
|
* items={[
|
|
@@ -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,3 +101,5 @@ export const SideNavigation = React.forwardRef((props, forwardedRef) => {
|
|
|
101
101
|
),
|
|
102
102
|
);
|
|
103
103
|
});
|
|
104
|
+
if ('development' === process.env.NODE_ENV)
|
|
105
|
+
SideNavigation.displayName = 'SideNavigation';
|
|
@@ -39,6 +39,8 @@ let SurfaceHeader = React.forwardRef((props, ref) => {
|
|
|
39
39
|
children,
|
|
40
40
|
);
|
|
41
41
|
});
|
|
42
|
+
if ('development' === process.env.NODE_ENV)
|
|
43
|
+
SurfaceHeader.displayName = 'Surface.Header';
|
|
42
44
|
let SurfaceBody = React.forwardRef((props, ref) => {
|
|
43
45
|
let { children, className, isPadded = false, ...rest } = props;
|
|
44
46
|
let { setHasLayout } = useSafeContext(SurfaceContext);
|
|
@@ -56,6 +58,8 @@ let SurfaceBody = React.forwardRef((props, ref) => {
|
|
|
56
58
|
children,
|
|
57
59
|
);
|
|
58
60
|
});
|
|
61
|
+
if ('development' === process.env.NODE_ENV)
|
|
62
|
+
SurfaceBody.displayName = 'Surface.Body';
|
|
59
63
|
export const Surface = Object.assign(
|
|
60
64
|
React.forwardRef((props, ref) => {
|
|
61
65
|
let {
|
|
@@ -97,4 +101,7 @@ export const Surface = Object.assign(
|
|
|
97
101
|
Body: SurfaceBody,
|
|
98
102
|
},
|
|
99
103
|
);
|
|
104
|
+
if ('development' === process.env.NODE_ENV) Surface.displayName = 'Surface';
|
|
100
105
|
let SurfaceContext = React.createContext(void 0);
|
|
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(
|
|
@@ -44,7 +44,7 @@ export type TablePaginatorRendererProps = {
|
|
|
44
44
|
* Table props.
|
|
45
45
|
* columns and data must be memoized.
|
|
46
46
|
*/
|
|
47
|
-
export type TableProps<T extends Record<string, unknown> = Record<string, unknown>> = Omit<TableOptions<T>, 'disableSortBy'> & {
|
|
47
|
+
export type TableProps<T extends Record<string, unknown> = Record<string, unknown>> = Omit<TableOptions<T>, 'disableSortBy'> & Omit<React.ComponentPropsWithoutRef<'div'>, 'role' | 'onSelect'> & {
|
|
48
48
|
/**
|
|
49
49
|
* Flag whether data is loading.
|
|
50
50
|
* @default false
|
|
@@ -203,6 +203,13 @@ export type TableProps<T extends Record<string, unknown> = Record<string, unknow
|
|
|
203
203
|
* Passes custom props to Table body.
|
|
204
204
|
*/
|
|
205
205
|
bodyProps?: React.ComponentProps<'div'>;
|
|
206
|
+
/**
|
|
207
|
+
* Passes props to the `role="table"` element within the wrapper.
|
|
208
|
+
*
|
|
209
|
+
* If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
|
|
210
|
+
* Else, all ARIA attributes will be passed to the inner element with `role="table"`.
|
|
211
|
+
*/
|
|
212
|
+
tableProps?: React.ComponentProps<'div'>;
|
|
206
213
|
/**
|
|
207
214
|
* Passes custom props to empty table.
|
|
208
215
|
*/
|
|
@@ -231,9 +238,28 @@ export type TableProps<T extends Record<string, unknown> = Record<string, unknow
|
|
|
231
238
|
* />
|
|
232
239
|
*/
|
|
233
240
|
scrollToRow?: (rows: Row<T>[], data: T[]) => number;
|
|
241
|
+
/**
|
|
242
|
+
* Caption for the table.
|
|
243
|
+
*
|
|
244
|
+
* Although optional for backward compatibility, it is **recommended** to use it for accessibility purposes.
|
|
245
|
+
*
|
|
246
|
+
* @default "Table"
|
|
247
|
+
*/
|
|
248
|
+
caption?: string;
|
|
249
|
+
/**
|
|
250
|
+
* If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
|
|
251
|
+
* Else, all ARIA attributes will be passed to the inner element with `role="table"`.
|
|
252
|
+
*/
|
|
253
|
+
role?: React.AriaRole;
|
|
234
254
|
} & Omit<CommonProps, 'title'>;
|
|
235
255
|
/**
|
|
236
256
|
* Table based on [react-table](https://react-table.tanstack.com/docs/api/overview).
|
|
257
|
+
*
|
|
258
|
+
* **Note**: If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
|
|
259
|
+
* Else, all ARIA attributes will be passed to the inner element with `role="table"`.
|
|
260
|
+
*
|
|
261
|
+
* ---
|
|
262
|
+
*
|
|
237
263
|
* @example
|
|
238
264
|
* const columns = React.useMemo(() => [
|
|
239
265
|
* {
|