@carbon/react 1.83.0-rc.0 → 1.83.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +1008 -938
- package/es/components/AILabel/index.js +13 -13
- package/es/components/AISkeleton/AISkeletonIcon.js +2 -2
- package/es/components/AISkeleton/AISkeletonPlaceholder.js +2 -2
- package/es/components/AISkeleton/AISkeletonText.js +2 -2
- package/es/components/Accordion/Accordion.Skeleton.js +15 -15
- package/es/components/Accordion/Accordion.js +3 -3
- package/es/components/Accordion/AccordionItem.js +9 -9
- package/es/components/Accordion/AccordionProvider.js +2 -2
- package/es/components/AspectRatio/AspectRatio.js +2 -2
- package/es/components/BadgeIndicator/index.js +3 -3
- package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +5 -5
- package/es/components/Breadcrumb/Breadcrumb.js +3 -3
- package/es/components/Breadcrumb/BreadcrumbItem.js +9 -9
- package/es/components/Button/Button.Skeleton.js +3 -3
- package/es/components/Button/Button.js +5 -5
- package/es/components/Button/ButtonBase.js +5 -5
- package/es/components/ButtonSet/ButtonSet.js +2 -2
- package/es/components/ChatButton/ChatButton.Skeleton.js +2 -2
- package/es/components/ChatButton/ChatButton.js +3 -3
- package/es/components/Checkbox/Checkbox.Skeleton.js +4 -4
- package/es/components/Checkbox/Checkbox.js +15 -15
- package/es/components/CheckboxGroup/CheckboxGroup.js +12 -12
- package/es/components/ClassPrefix/index.js +2 -2
- package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +7 -7
- package/es/components/CodeSnippet/CodeSnippet.js +16 -16
- package/es/components/ComboBox/ComboBox.js +18 -18
- package/es/components/ComboButton/index.js +7 -7
- package/es/components/ComposedModal/ComposedModal.js +20 -20
- package/es/components/ComposedModal/ModalFooter.js +8 -8
- package/es/components/ComposedModal/ModalHeader.js +8 -8
- package/es/components/ContainedList/ContainedList.js +7 -7
- package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +7 -7
- package/es/components/ContentSwitcher/ContentSwitcher.d.ts +8 -0
- package/es/components/ContentSwitcher/ContentSwitcher.js +13 -7
- package/es/components/Copy/Copy.js +2 -2
- package/es/components/CopyButton/CopyButton.js +4 -4
- package/es/components/DangerButton/DangerButton.js +2 -2
- package/es/components/DataTable/DataTable.d.ts +81 -283
- package/es/components/DataTable/DataTable.js +83 -123
- package/es/components/DataTable/Table.d.ts +2 -2
- package/es/components/DataTable/Table.js +4 -4
- package/es/components/DataTable/TableActionList.d.ts +1 -1
- package/es/components/DataTable/TableBatchAction.js +2 -2
- package/es/components/DataTable/TableBatchActions.js +9 -9
- package/es/components/DataTable/TableBody.d.ts +3 -3
- package/es/components/DataTable/TableBody.js +2 -2
- package/es/components/DataTable/TableCell.d.ts +3 -4
- package/es/components/DataTable/TableCell.js +2 -2
- package/es/components/DataTable/TableContainer.d.ts +2 -3
- package/es/components/DataTable/TableContainer.js +6 -6
- package/es/components/DataTable/TableDecoratorRow.js +4 -4
- package/es/components/DataTable/TableExpandHeader.d.ts +2 -3
- package/es/components/DataTable/TableExpandHeader.js +4 -4
- package/es/components/DataTable/TableExpandRow.js +8 -8
- package/es/components/DataTable/TableExpandedRow.d.ts +3 -3
- package/es/components/DataTable/TableExpandedRow.js +4 -4
- package/es/components/DataTable/TableHead.d.ts +1 -1
- package/es/components/DataTable/TableHeader.d.ts +4 -4
- package/es/components/DataTable/TableHeader.js +15 -15
- package/es/components/DataTable/TableRow.d.ts +3 -4
- package/es/components/DataTable/TableRow.js +4 -4
- package/es/components/DataTable/TableSelectAll.js +3 -3
- package/es/components/DataTable/TableSelectRow.js +4 -4
- package/es/components/DataTable/TableSlugRow.js +3 -3
- package/es/components/DataTable/TableToolbar.js +2 -2
- package/es/components/DataTable/TableToolbarAction.js +2 -2
- package/es/components/DataTable/TableToolbarContent.d.ts +1 -1
- package/es/components/DataTable/TableToolbarMenu.js +2 -2
- package/es/components/DataTable/TableToolbarSearch.js +2 -2
- package/es/components/DataTable/index.d.ts +1 -1
- package/es/components/DataTableSkeleton/DataTableSkeleton.js +15 -15
- package/es/components/DatePicker/DatePicker.Skeleton.js +8 -8
- package/es/components/DatePicker/DatePicker.js +17 -17
- package/es/components/DatePickerInput/DatePickerInput.d.ts +3 -4
- package/es/components/DatePickerInput/DatePickerInput.js +19 -19
- package/es/components/Dialog/index.d.ts +5 -6
- package/es/components/Dialog/index.js +10 -10
- package/es/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
- package/es/components/Dropdown/Dropdown.Skeleton.js +4 -4
- package/es/components/Dropdown/Dropdown.d.ts +3 -3
- package/es/components/Dropdown/Dropdown.js +18 -18
- package/es/components/ErrorBoundary/ErrorBoundary.js +2 -2
- package/es/components/ExpandableSearch/ExpandableSearch.js +3 -3
- package/es/components/FeatureFlags/index.js +2 -2
- package/es/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
- package/es/components/FileUploader/FileUploader.Skeleton.js +5 -5
- package/es/components/FileUploader/FileUploader.d.ts +2 -3
- package/es/components/FileUploader/FileUploader.js +12 -12
- package/es/components/FileUploader/FileUploaderButton.d.ts +2 -3
- package/es/components/FileUploader/FileUploaderButton.js +4 -4
- package/es/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
- package/es/components/FileUploader/FileUploaderDropContainer.js +5 -5
- package/es/components/FileUploader/FileUploaderItem.d.ts +2 -3
- package/es/components/FileUploader/FileUploaderItem.js +13 -13
- package/es/components/FileUploader/Filename.d.ts +3 -4
- package/es/components/FileUploader/Filename.js +7 -7
- package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +5 -5
- package/es/components/FluidComboBox/FluidComboBox.js +4 -4
- package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +11 -11
- package/es/components/FluidDatePicker/FluidDatePicker.js +4 -4
- package/es/components/FluidDatePickerInput/FluidDatePickerInput.js +3 -3
- package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +5 -5
- package/es/components/FluidDropdown/FluidDropdown.js +4 -4
- package/es/components/FluidForm/FluidForm.d.ts +3 -4
- package/es/components/FluidForm/FluidForm.js +3 -3
- package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +5 -5
- package/es/components/FluidMultiSelect/FluidMultiSelect.js +5 -5
- package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +5 -5
- package/es/components/FluidNumberInput/FluidNumberInput.js +4 -4
- package/es/components/FluidSearch/FluidSearch.Skeleton.js +5 -5
- package/es/components/FluidSearch/FluidSearch.js +4 -4
- package/es/components/FluidSelect/FluidSelect.Skeleton.js +5 -5
- package/es/components/FluidSelect/FluidSelect.js +4 -4
- package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +5 -5
- package/es/components/FluidTextArea/FluidTextArea.js +3 -3
- package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +5 -5
- package/es/components/FluidTextInput/FluidTextInput.js +5 -5
- package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +3 -3
- package/es/components/FluidTimePicker/FluidTimePicker.js +13 -13
- package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +3 -3
- package/es/components/Form/Form.js +2 -2
- package/es/components/FormGroup/FormGroup.d.ts +3 -4
- package/es/components/FormGroup/FormGroup.js +4 -4
- package/es/components/FormItem/FormItem.js +2 -2
- package/es/components/FormLabel/FormLabel.js +2 -2
- package/es/components/Grid/CSSGrid.js +8 -8
- package/es/components/Grid/Column.js +5 -5
- package/es/components/Grid/ColumnHang.js +2 -2
- package/es/components/Grid/FlexGrid.js +4 -4
- package/es/components/Grid/Grid.js +3 -3
- package/es/components/Grid/GridContext.d.ts +2 -2
- package/es/components/Grid/GridContext.js +1 -1
- package/es/components/Grid/Row.js +2 -2
- package/es/components/Heading/index.js +9 -9
- package/es/components/Icon/Icon.Skeleton.js +2 -2
- package/es/components/IconButton/index.js +11 -6
- package/es/components/IconIndicator/index.js +4 -4
- package/es/components/IdPrefix/index.js +2 -2
- package/es/components/InlineCheckbox/InlineCheckbox.js +6 -6
- package/es/components/InlineLoading/InlineLoading.js +10 -10
- package/es/components/Layer/LayerContext.js +2 -2
- package/es/components/Layer/index.d.ts +4 -0
- package/es/components/Layer/index.js +15 -8
- package/es/components/Layout/index.js +5 -5
- package/es/components/LayoutDirection/LayoutDirection.js +4 -4
- package/es/components/LayoutDirection/LayoutDirectionContext.js +2 -2
- package/es/components/Link/Link.js +6 -6
- package/es/components/ListBox/ListBox.d.ts +2 -3
- package/es/components/ListBox/ListBox.js +5 -5
- package/es/components/ListBox/ListBoxField.d.ts +3 -4
- package/es/components/ListBox/ListBoxField.js +2 -2
- package/es/components/ListBox/ListBoxMenu.d.ts +2 -3
- package/es/components/ListBox/ListBoxMenu.js +2 -2
- package/es/components/ListBox/ListBoxMenuIcon.js +4 -4
- package/es/components/ListBox/ListBoxMenuItem.d.ts +2 -3
- package/es/components/ListBox/ListBoxMenuItem.js +3 -3
- package/es/components/ListBox/ListBoxSelection.js +6 -6
- package/es/components/ListBox/next/ListBoxSelection.js +7 -7
- package/es/components/ListBox/next/ListBoxTrigger.js +4 -4
- package/es/components/ListItem/ListItem.js +2 -2
- package/es/components/Loading/Loading.d.ts +3 -3
- package/es/components/Loading/Loading.js +6 -6
- package/es/components/Menu/Menu.js +3 -3
- package/es/components/Menu/MenuItem.js +16 -16
- package/es/components/MenuButton/index.js +4 -4
- package/es/components/Modal/Modal.d.ts +2 -3
- package/es/components/Modal/Modal.js +35 -35
- package/es/components/ModalWrapper/ModalWrapper.js +7 -7
- package/es/components/MultiSelect/FilterableMultiSelect.js +22 -26
- package/es/components/MultiSelect/MultiSelect.js +23 -23
- package/es/components/Notification/Notification.js +41 -41
- package/es/components/NumberInput/NumberInput.Skeleton.js +4 -4
- package/es/components/NumberInput/NumberInput.js +22 -22
- package/es/components/OrderedList/OrderedList.js +2 -2
- package/es/components/OverflowMenu/OverflowMenu.js +7 -7
- package/es/components/OverflowMenu/index.js +3 -3
- package/es/components/OverflowMenu/next/index.js +6 -6
- package/es/components/OverflowMenuItem/OverflowMenuItem.js +4 -4
- package/es/components/OverflowMenuV2/index.js +3 -3
- package/es/components/PageHeader/PageHeader.js +29 -29
- package/es/components/Pagination/Pagination.Skeleton.js +8 -8
- package/es/components/Pagination/Pagination.js +17 -17
- package/es/components/Pagination/experimental/PageSelector.js +3 -3
- package/es/components/Pagination/experimental/Pagination.js +14 -14
- package/es/components/PaginationNav/PaginationNav.js +31 -31
- package/es/components/Popover/index.js +15 -15
- package/es/components/PrimaryButton/PrimaryButton.js +2 -2
- package/es/components/ProgressBar/ProgressBar.js +13 -13
- package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +7 -7
- package/es/components/ProgressIndicator/ProgressIndicator.js +20 -20
- package/es/components/RadioButton/RadioButton.Skeleton.js +4 -4
- package/es/components/RadioButton/RadioButton.js +10 -10
- package/es/components/RadioButtonGroup/RadioButtonGroup.js +16 -16
- package/es/components/RadioTile/RadioTile.js +12 -12
- package/es/components/Search/Search.Skeleton.js +4 -4
- package/es/components/Search/Search.js +11 -11
- package/es/components/SecondaryButton/SecondaryButton.js +2 -2
- package/es/components/Select/Select.Skeleton.js +5 -5
- package/es/components/Select/Select.js +19 -19
- package/es/components/SelectItem/SelectItem.js +2 -2
- package/es/components/SelectItemGroup/SelectItemGroup.js +2 -2
- package/es/components/ShapeIndicator/index.js +7 -7
- package/es/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
- package/es/components/SkeletonIcon/SkeletonIcon.js +3 -7
- package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +2 -2
- package/es/components/SkeletonText/SkeletonText.js +4 -4
- package/es/components/Slider/Slider.Skeleton.js +17 -17
- package/es/components/Slider/Slider.js +38 -38
- package/es/components/Slider/SliderHandles.js +19 -19
- package/es/components/Stack/HStack.js +2 -2
- package/es/components/Stack/Stack.js +2 -2
- package/es/components/Stack/VStack.js +2 -2
- package/es/components/StructuredList/StructuredList.Skeleton.js +12 -12
- package/es/components/StructuredList/StructuredList.js +24 -24
- package/es/components/Switch/IconSwitch.js +3 -3
- package/es/components/Switch/Switch.js +4 -4
- package/es/components/TabContent/TabContent.js +2 -2
- package/es/components/Tabs/Tabs.Skeleton.js +7 -7
- package/es/components/Tabs/Tabs.js +60 -60
- package/es/components/Tag/DismissibleTag.js +10 -10
- package/es/components/Tag/OperationalTag.js +6 -6
- package/es/components/Tag/SelectableTag.js +6 -6
- package/es/components/Tag/Tag.Skeleton.js +2 -2
- package/es/components/Tag/Tag.js +15 -15
- package/es/components/Text/Text.js +4 -4
- package/es/components/Text/TextDirection.js +2 -2
- package/es/components/Text/createTextComponent.js +2 -2
- package/es/components/TextArea/TextArea.Skeleton.js +4 -4
- package/es/components/TextArea/TextArea.js +19 -19
- package/es/components/TextInput/ControlledPasswordInput.d.ts +2 -3
- package/es/components/TextInput/ControlledPasswordInput.js +13 -13
- package/es/components/TextInput/PasswordInput.js +15 -15
- package/es/components/TextInput/TextInput.Skeleton.js +4 -4
- package/es/components/TextInput/TextInput.js +17 -17
- package/es/components/Theme/index.js +10 -10
- package/es/components/Tile/Tile.js +36 -36
- package/es/components/TileGroup/TileGroup.d.ts +3 -4
- package/es/components/TileGroup/TileGroup.js +8 -8
- package/es/components/TimePicker/TimePicker.d.ts +2 -3
- package/es/components/TimePicker/TimePicker.js +14 -14
- package/es/components/TimePickerSelect/TimePickerSelect.js +4 -4
- package/es/components/Toggle/Toggle.Skeleton.js +4 -4
- package/es/components/Toggle/Toggle.js +10 -10
- package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +8 -8
- package/es/components/Toggletip/index.js +12 -12
- package/es/components/Tooltip/DefinitionTooltip.js +4 -4
- package/es/components/Tooltip/Tooltip.d.ts +3 -0
- package/es/components/Tooltip/Tooltip.js +25 -13
- package/es/components/TreeView/TreeNode.js +45 -36
- package/es/components/TreeView/TreeView.js +30 -21
- package/es/components/UIShell/Content.js +2 -2
- package/es/components/UIShell/Header.js +2 -2
- package/es/components/UIShell/HeaderContainer.js +2 -2
- package/es/components/UIShell/HeaderGlobalAction.js +3 -3
- package/es/components/UIShell/HeaderGlobalBar.d.ts +1 -1
- package/es/components/UIShell/HeaderMenu.js +14 -14
- package/es/components/UIShell/HeaderMenuButton.js +4 -4
- package/es/components/UIShell/HeaderMenuItem.js +11 -9
- package/es/components/UIShell/HeaderName.js +3 -3
- package/es/components/UIShell/HeaderNavigation.js +3 -3
- package/es/components/UIShell/HeaderPanel.js +3 -3
- package/es/components/UIShell/HeaderSideNavItems.js +2 -2
- package/es/components/UIShell/Link.js +3 -3
- package/es/components/UIShell/SideNav.js +7 -7
- package/es/components/UIShell/SideNavDetails.js +3 -3
- package/es/components/UIShell/SideNavDivider.js +3 -3
- package/es/components/UIShell/SideNavFooter.js +7 -7
- package/es/components/UIShell/SideNavHeader.js +3 -3
- package/es/components/UIShell/SideNavIcon.js +2 -2
- package/es/components/UIShell/SideNavItem.js +2 -2
- package/es/components/UIShell/SideNavItems.js +5 -5
- package/es/components/UIShell/SideNavLink.js +5 -5
- package/es/components/UIShell/SideNavLinkText.js +2 -2
- package/es/components/UIShell/SideNavMenu.js +10 -10
- package/es/components/UIShell/SideNavMenuItem.js +5 -5
- package/es/components/UIShell/SideNavSwitcher.js +8 -8
- package/es/components/UIShell/SkipToContent.js +2 -2
- package/es/components/UIShell/Switcher.js +8 -8
- package/es/components/UIShell/SwitcherDivider.js +2 -2
- package/es/components/UIShell/SwitcherItem.js +3 -3
- package/es/components/UnorderedList/UnorderedList.js +2 -2
- package/es/index.js +23 -24
- package/es/internal/FloatingMenu.js +4 -4
- package/es/internal/__mocks__/mockHTMLElement.d.ts +9 -0
- package/es/internal/createClassWrapper.js +2 -2
- package/es/internal/useId.js +2 -2
- package/es/internal/useIdPrefix.js +3 -3
- package/es/internal/useNormalizedInputProps.js +3 -3
- package/es/internal/usePrefix.js +3 -3
- package/es/internal/useResizeObserver.d.ts +14 -0
- package/es/internal/useResizeObserver.js +74 -0
- package/es/internal/wrapFocus.js +3 -6
- package/es/tools/wrapComponent.d.ts +3 -4
- package/es/tools/wrapComponent.js +2 -2
- package/es/types/common.d.ts +0 -2
- package/lib/components/CodeSnippet/CodeSnippet.js +2 -3
- package/lib/components/ContentSwitcher/ContentSwitcher.d.ts +8 -0
- package/lib/components/ContentSwitcher/ContentSwitcher.js +7 -1
- package/lib/components/DataTable/DataTable.d.ts +81 -283
- package/lib/components/DataTable/DataTable.js +82 -123
- package/lib/components/DataTable/Table.d.ts +2 -2
- package/lib/components/DataTable/TableActionList.d.ts +1 -1
- package/lib/components/DataTable/TableBody.d.ts +3 -3
- package/lib/components/DataTable/TableCell.d.ts +3 -4
- package/lib/components/DataTable/TableContainer.d.ts +2 -3
- package/lib/components/DataTable/TableExpandHeader.d.ts +2 -3
- package/lib/components/DataTable/TableExpandedRow.d.ts +3 -3
- package/lib/components/DataTable/TableHead.d.ts +1 -1
- package/lib/components/DataTable/TableHeader.d.ts +4 -4
- package/lib/components/DataTable/TableRow.d.ts +3 -4
- package/lib/components/DataTable/TableToolbarContent.d.ts +1 -1
- package/lib/components/DataTable/index.d.ts +1 -1
- package/lib/components/DatePickerInput/DatePickerInput.d.ts +3 -4
- package/lib/components/Dialog/index.d.ts +5 -6
- package/lib/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
- package/lib/components/Dropdown/Dropdown.d.ts +3 -3
- package/lib/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
- package/lib/components/FileUploader/FileUploader.d.ts +2 -3
- package/lib/components/FileUploader/FileUploaderButton.d.ts +2 -3
- package/lib/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
- package/lib/components/FileUploader/FileUploaderItem.d.ts +2 -3
- package/lib/components/FileUploader/Filename.d.ts +3 -4
- package/lib/components/FluidForm/FluidForm.d.ts +3 -4
- package/lib/components/FormGroup/FormGroup.d.ts +3 -4
- package/lib/components/Grid/GridContext.d.ts +2 -2
- package/lib/components/Grid/GridContext.js +5 -23
- package/lib/components/IconButton/index.js +6 -1
- package/lib/components/Layer/index.d.ts +4 -0
- package/lib/components/Layer/index.js +9 -2
- package/lib/components/Link/Link.js +1 -1
- package/lib/components/ListBox/ListBox.d.ts +2 -3
- package/lib/components/ListBox/ListBoxField.d.ts +3 -4
- package/lib/components/ListBox/ListBoxMenu.d.ts +2 -3
- package/lib/components/ListBox/ListBoxMenuItem.d.ts +2 -3
- package/lib/components/Loading/Loading.d.ts +3 -3
- package/lib/components/Modal/Modal.d.ts +2 -3
- package/lib/components/MultiSelect/FilterableMultiSelect.js +1 -5
- package/lib/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
- package/lib/components/SkeletonIcon/SkeletonIcon.js +1 -5
- package/lib/components/TextInput/ControlledPasswordInput.d.ts +2 -3
- package/lib/components/TileGroup/TileGroup.d.ts +3 -4
- package/lib/components/TimePicker/TimePicker.d.ts +2 -3
- package/lib/components/Tooltip/Tooltip.d.ts +3 -0
- package/lib/components/Tooltip/Tooltip.js +18 -6
- package/lib/components/TreeView/TreeNode.js +20 -11
- package/lib/components/TreeView/TreeView.js +27 -18
- package/lib/components/UIShell/HeaderGlobalBar.d.ts +1 -1
- package/lib/components/UIShell/HeaderMenuItem.js +7 -5
- package/lib/index.js +46 -47
- package/lib/internal/__mocks__/mockHTMLElement.d.ts +9 -0
- package/lib/internal/useResizeObserver.d.ts +14 -0
- package/lib/internal/useResizeObserver.js +78 -0
- package/lib/internal/wrapFocus.js +3 -6
- package/lib/tools/wrapComponent.d.ts +3 -4
- package/lib/types/common.d.ts +0 -2
- package/package.json +5 -6
- package/scss/components/content-switcher/_tokens.scss +9 -0
- package/telemetry.yml +4 -1
- package/es/components/DataTable/index.js +0 -76
- package/lib/components/DataTable/index.js +0 -82
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
|
|
8
8
|
import { extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
|
|
9
9
|
import PropTypes from 'prop-types';
|
|
10
|
-
import
|
|
10
|
+
import React, { useRef, useState, useEffect } from 'react';
|
|
11
11
|
import cx from 'classnames';
|
|
12
12
|
import { Close } from '@carbon/icons-react';
|
|
13
13
|
import { toggleClass } from '../../tools/toggleClass.js';
|
|
@@ -36,7 +36,7 @@ import { debounce } from '../../node_modules/es-toolkit/dist/compat/function/deb
|
|
|
36
36
|
import { Text } from '../Text/Text.js';
|
|
37
37
|
|
|
38
38
|
const ModalSizes = ['xs', 'sm', 'md', 'lg'];
|
|
39
|
-
const Modal = /*#__PURE__*/
|
|
39
|
+
const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
|
|
40
40
|
let {
|
|
41
41
|
'aria-label': ariaLabelProp,
|
|
42
42
|
children,
|
|
@@ -250,22 +250,22 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
250
250
|
}, []);
|
|
251
251
|
|
|
252
252
|
// AILabel always size `sm`
|
|
253
|
-
let normalizedDecorator = /*#__PURE__*/
|
|
253
|
+
let normalizedDecorator = /*#__PURE__*/React.isValidElement(slug ?? decorator) ? slug ?? decorator : null;
|
|
254
254
|
if (normalizedDecorator && normalizedDecorator['type']?.displayName === 'AILabel') {
|
|
255
|
-
normalizedDecorator = /*#__PURE__*/
|
|
255
|
+
normalizedDecorator = /*#__PURE__*/React.cloneElement(normalizedDecorator, {
|
|
256
256
|
size: 'sm'
|
|
257
257
|
});
|
|
258
258
|
}
|
|
259
|
-
const modalButton = /*#__PURE__*/
|
|
259
|
+
const modalButton = /*#__PURE__*/React.createElement("div", {
|
|
260
260
|
className: `${prefix}--modal-close-button`
|
|
261
|
-
}, /*#__PURE__*/
|
|
261
|
+
}, /*#__PURE__*/React.createElement(IconButton, {
|
|
262
262
|
className: modalCloseButtonClass,
|
|
263
263
|
label: closeButtonLabel,
|
|
264
264
|
onClick: onRequestClose,
|
|
265
265
|
"aria-label": closeButtonLabel,
|
|
266
266
|
align: "left",
|
|
267
267
|
ref: button
|
|
268
|
-
}, /*#__PURE__*/
|
|
268
|
+
}, /*#__PURE__*/React.createElement(Close, {
|
|
269
269
|
size: 20,
|
|
270
270
|
"aria-hidden": "true",
|
|
271
271
|
tabIndex: "-1",
|
|
@@ -275,7 +275,7 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
275
275
|
// alertdialog is the only permitted aria role for a native dialog element
|
|
276
276
|
// https://www.w3.org/TR/html-aria/#docconformance:~:text=Role%3A-,alertdialog,-.%20(dialog%20is
|
|
277
277
|
const isAlertDialog = alert && !passiveModal;
|
|
278
|
-
const modalBody = enableDialogElement ? /*#__PURE__*/
|
|
278
|
+
const modalBody = enableDialogElement ? /*#__PURE__*/React.createElement(unstable__Dialog, {
|
|
279
279
|
open: open,
|
|
280
280
|
modal: true,
|
|
281
281
|
ref: innerModal,
|
|
@@ -283,37 +283,37 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
283
283
|
"aria-describedby": isAlertDialog ? modalBodyId : '',
|
|
284
284
|
className: containerClasses,
|
|
285
285
|
"aria-label": ariaLabel
|
|
286
|
-
}, /*#__PURE__*/
|
|
286
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
287
287
|
className: `${prefix}--modal-header`
|
|
288
|
-
}, modalLabel && /*#__PURE__*/
|
|
288
|
+
}, modalLabel && /*#__PURE__*/React.createElement(Text, {
|
|
289
289
|
as: "h2",
|
|
290
290
|
id: modalLabelId,
|
|
291
291
|
className: `${prefix}--modal-header__label`
|
|
292
|
-
}, modalLabel), /*#__PURE__*/
|
|
292
|
+
}, modalLabel), /*#__PURE__*/React.createElement(Text, {
|
|
293
293
|
as: "h2",
|
|
294
294
|
id: modalHeadingId,
|
|
295
295
|
className: `${prefix}--modal-header__heading`
|
|
296
|
-
}, modalHeading), decorator ? /*#__PURE__*/
|
|
296
|
+
}, modalHeading), decorator ? /*#__PURE__*/React.createElement("div", {
|
|
297
297
|
className: `${prefix}--modal--inner__decorator`
|
|
298
|
-
}, normalizedDecorator) : '', /*#__PURE__*/
|
|
298
|
+
}, normalizedDecorator) : '', /*#__PURE__*/React.createElement("div", {
|
|
299
299
|
className: `${prefix}--modal-close-button`
|
|
300
|
-
}, /*#__PURE__*/
|
|
300
|
+
}, /*#__PURE__*/React.createElement(IconButton, {
|
|
301
301
|
className: modalCloseButtonClass,
|
|
302
302
|
label: closeButtonLabel,
|
|
303
303
|
onClick: onRequestClose,
|
|
304
304
|
"aria-label": closeButtonLabel,
|
|
305
305
|
align: "left",
|
|
306
306
|
ref: button
|
|
307
|
-
}, /*#__PURE__*/
|
|
307
|
+
}, /*#__PURE__*/React.createElement(Close, {
|
|
308
308
|
size: 20,
|
|
309
309
|
"aria-hidden": "true",
|
|
310
310
|
tabIndex: "-1",
|
|
311
311
|
className: `${modalCloseButtonClass}__icon`
|
|
312
|
-
})))), /*#__PURE__*/
|
|
312
|
+
})))), /*#__PURE__*/React.createElement(Layer, _extends({
|
|
313
313
|
ref: contentRef,
|
|
314
314
|
id: modalBodyId,
|
|
315
315
|
className: contentClasses
|
|
316
|
-
}, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/
|
|
316
|
+
}, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/React.createElement(ButtonSet, {
|
|
317
317
|
className: footerClasses,
|
|
318
318
|
"aria-busy": loadingActive
|
|
319
319
|
}, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map((_ref3, i) => {
|
|
@@ -321,34 +321,34 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
321
321
|
buttonText,
|
|
322
322
|
onClick: onButtonClick
|
|
323
323
|
} = _ref3;
|
|
324
|
-
return /*#__PURE__*/
|
|
324
|
+
return /*#__PURE__*/React.createElement(Button, {
|
|
325
325
|
key: `${buttonText}-${i}`,
|
|
326
326
|
kind: "secondary",
|
|
327
327
|
onClick: onButtonClick
|
|
328
328
|
}, buttonText);
|
|
329
|
-
}) : secondaryButtonText && /*#__PURE__*/
|
|
329
|
+
}) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
|
|
330
330
|
disabled: loadingActive,
|
|
331
331
|
kind: "secondary",
|
|
332
332
|
onClick: onSecondaryButtonClick,
|
|
333
333
|
ref: secondaryButton
|
|
334
|
-
}, secondaryButtonText), /*#__PURE__*/
|
|
334
|
+
}, secondaryButtonText), /*#__PURE__*/React.createElement(Button, {
|
|
335
335
|
className: primaryButtonClass,
|
|
336
336
|
kind: danger ? 'danger' : 'primary',
|
|
337
337
|
disabled: loadingActive || primaryButtonDisabled,
|
|
338
338
|
onClick: onRequestSubmit,
|
|
339
339
|
ref: button
|
|
340
|
-
}, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/
|
|
340
|
+
}, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/React.createElement(InlineLoading, {
|
|
341
341
|
status: loadingStatus,
|
|
342
342
|
description: loadingDescription,
|
|
343
343
|
iconDescription: loadingIconDescription,
|
|
344
344
|
className: `${prefix}--inline-loading--btn`,
|
|
345
345
|
onSuccess: onLoadingSuccess
|
|
346
|
-
})))) : /*#__PURE__*/
|
|
346
|
+
})))) : /*#__PURE__*/React.createElement(React.Fragment, null, !enableDialogElement && !focusTrapWithoutSentinels && /*#__PURE__*/React.createElement("span", {
|
|
347
347
|
ref: startTrap,
|
|
348
348
|
tabIndex: 0,
|
|
349
349
|
role: "link",
|
|
350
350
|
className: `${prefix}--visually-hidden`
|
|
351
|
-
}, "Focus sentinel"), /*#__PURE__*/
|
|
351
|
+
}, "Focus sentinel"), /*#__PURE__*/React.createElement("div", _extends({
|
|
352
352
|
ref: innerModal,
|
|
353
353
|
role: "dialog"
|
|
354
354
|
}, alertDialogProps, {
|
|
@@ -356,23 +356,23 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
356
356
|
"aria-label": ariaLabel,
|
|
357
357
|
"aria-modal": "true",
|
|
358
358
|
tabIndex: -1
|
|
359
|
-
}), /*#__PURE__*/
|
|
359
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
360
360
|
className: `${prefix}--modal-header`
|
|
361
|
-
}, passiveModal && modalButton, modalLabel && /*#__PURE__*/
|
|
361
|
+
}, passiveModal && modalButton, modalLabel && /*#__PURE__*/React.createElement(Text, {
|
|
362
362
|
as: "h2",
|
|
363
363
|
id: modalLabelId,
|
|
364
364
|
className: `${prefix}--modal-header__label`
|
|
365
|
-
}, modalLabel), /*#__PURE__*/
|
|
365
|
+
}, modalLabel), /*#__PURE__*/React.createElement(Text, {
|
|
366
366
|
as: "h2",
|
|
367
367
|
id: modalHeadingId,
|
|
368
368
|
className: `${prefix}--modal-header__heading`
|
|
369
|
-
}, modalHeading), slug ? normalizedDecorator : decorator ? /*#__PURE__*/
|
|
369
|
+
}, modalHeading), slug ? normalizedDecorator : decorator ? /*#__PURE__*/React.createElement("div", {
|
|
370
370
|
className: `${prefix}--modal--inner__decorator`
|
|
371
|
-
}, normalizedDecorator) : '', !passiveModal && modalButton), /*#__PURE__*/
|
|
371
|
+
}, normalizedDecorator) : '', !passiveModal && modalButton), /*#__PURE__*/React.createElement(Layer, _extends({
|
|
372
372
|
ref: contentRef,
|
|
373
373
|
id: modalBodyId,
|
|
374
374
|
className: contentClasses
|
|
375
|
-
}, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/
|
|
375
|
+
}, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/React.createElement(ButtonSet, {
|
|
376
376
|
className: footerClasses,
|
|
377
377
|
"aria-busy": loadingActive
|
|
378
378
|
}, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map((_ref4, i) => {
|
|
@@ -380,35 +380,35 @@ const Modal = /*#__PURE__*/React__default.forwardRef(function Modal(_ref, ref) {
|
|
|
380
380
|
buttonText,
|
|
381
381
|
onClick: onButtonClick
|
|
382
382
|
} = _ref4;
|
|
383
|
-
return /*#__PURE__*/
|
|
383
|
+
return /*#__PURE__*/React.createElement(Button, {
|
|
384
384
|
key: `${buttonText}-${i}`,
|
|
385
385
|
kind: "secondary",
|
|
386
386
|
onClick: onButtonClick
|
|
387
387
|
}, buttonText);
|
|
388
|
-
}) : secondaryButtonText && /*#__PURE__*/
|
|
388
|
+
}) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
|
|
389
389
|
disabled: loadingActive,
|
|
390
390
|
kind: "secondary",
|
|
391
391
|
onClick: onSecondaryButtonClick,
|
|
392
392
|
ref: secondaryButton
|
|
393
|
-
}, secondaryButtonText), /*#__PURE__*/
|
|
393
|
+
}, secondaryButtonText), /*#__PURE__*/React.createElement(Button, {
|
|
394
394
|
className: primaryButtonClass,
|
|
395
395
|
kind: danger ? 'danger' : 'primary',
|
|
396
396
|
disabled: loadingActive || primaryButtonDisabled,
|
|
397
397
|
onClick: onRequestSubmit,
|
|
398
398
|
ref: button
|
|
399
|
-
}, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/
|
|
399
|
+
}, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/React.createElement(InlineLoading, {
|
|
400
400
|
status: loadingStatus,
|
|
401
401
|
description: loadingDescription,
|
|
402
402
|
iconDescription: loadingIconDescription,
|
|
403
403
|
className: `${prefix}--inline-loading--btn`,
|
|
404
404
|
onSuccess: onLoadingSuccess
|
|
405
|
-
})))), !enableDialogElement && !focusTrapWithoutSentinels && /*#__PURE__*/
|
|
405
|
+
})))), !enableDialogElement && !focusTrapWithoutSentinels && /*#__PURE__*/React.createElement("span", {
|
|
406
406
|
ref: endTrap,
|
|
407
407
|
tabIndex: 0,
|
|
408
408
|
role: "link",
|
|
409
409
|
className: `${prefix}--visually-hidden`
|
|
410
410
|
}, "Focus sentinel"));
|
|
411
|
-
return /*#__PURE__*/
|
|
411
|
+
return /*#__PURE__*/React.createElement(Layer, _extends({}, rest, {
|
|
412
412
|
level: 0,
|
|
413
413
|
onKeyDown: handleKeyDown,
|
|
414
414
|
onClick: composeEventHandlers([rest?.onClick, handleOnClick]),
|
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
|
|
8
8
|
import { defineProperty as _defineProperty, extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
|
|
9
9
|
import PropTypes from 'prop-types';
|
|
10
|
-
import
|
|
10
|
+
import React from 'react';
|
|
11
11
|
import Modal from '../Modal/Modal.js';
|
|
12
12
|
import Button, { ButtonKinds } from '../Button/Button.js';
|
|
13
13
|
import '../Button/Button.Skeleton.js';
|
|
@@ -18,11 +18,11 @@ import { match } from '../../internal/keyboard/match.js';
|
|
|
18
18
|
|
|
19
19
|
let didWarnAboutDeprecation = false;
|
|
20
20
|
process.env.NODE_ENV !== 'production';
|
|
21
|
-
class ModalWrapper extends
|
|
21
|
+
class ModalWrapper extends React.Component {
|
|
22
22
|
constructor() {
|
|
23
23
|
super(...arguments);
|
|
24
|
-
_defineProperty(this, "triggerButton", /*#__PURE__*/
|
|
25
|
-
_defineProperty(this, "modal", /*#__PURE__*/
|
|
24
|
+
_defineProperty(this, "triggerButton", /*#__PURE__*/React.createRef());
|
|
25
|
+
_defineProperty(this, "modal", /*#__PURE__*/React.createRef());
|
|
26
26
|
_defineProperty(this, "state", {
|
|
27
27
|
isOpen: false
|
|
28
28
|
});
|
|
@@ -85,7 +85,7 @@ class ModalWrapper extends React__default.Component {
|
|
|
85
85
|
onRequestClose: this.handleClose,
|
|
86
86
|
onRequestSubmit: this.handleOnRequestSubmit
|
|
87
87
|
};
|
|
88
|
-
return /*#__PURE__*/
|
|
88
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
89
89
|
role: "presentation",
|
|
90
90
|
onKeyDown: evt => {
|
|
91
91
|
if (match(evt, Escape)) {
|
|
@@ -93,7 +93,7 @@ class ModalWrapper extends React__default.Component {
|
|
|
93
93
|
onKeyDown(evt);
|
|
94
94
|
}
|
|
95
95
|
}
|
|
96
|
-
}, /*#__PURE__*/
|
|
96
|
+
}, /*#__PURE__*/React.createElement(Button, {
|
|
97
97
|
className: buttonTriggerClassName,
|
|
98
98
|
disabled: disabled,
|
|
99
99
|
kind: triggerButtonKind,
|
|
@@ -101,7 +101,7 @@ class ModalWrapper extends React__default.Component {
|
|
|
101
101
|
iconDescription: triggerButtonIconDescription,
|
|
102
102
|
onClick: this.handleOpen,
|
|
103
103
|
ref: this.triggerButton
|
|
104
|
-
}, buttonTriggerText), /*#__PURE__*/
|
|
104
|
+
}, buttonTriggerText), /*#__PURE__*/React.createElement(Modal, _extends({
|
|
105
105
|
ref: this.modal,
|
|
106
106
|
primaryButtonText: primaryButtonText,
|
|
107
107
|
secondaryButtonText: secondaryButtonText
|
|
@@ -11,7 +11,7 @@ import cx from 'classnames';
|
|
|
11
11
|
import Downshift, { useCombobox, useMultipleSelection } from 'downshift';
|
|
12
12
|
import isEqual from 'react-fast-compare';
|
|
13
13
|
import PropTypes from 'prop-types';
|
|
14
|
-
import
|
|
14
|
+
import React, { forwardRef, useContext, useRef, useState, useLayoutEffect, useMemo, useEffect } from 'react';
|
|
15
15
|
import { defaultFilterItems } from '../ComboBox/tools/filter.js';
|
|
16
16
|
import { sortingPropTypes } from './MultiSelectPropTypes.js';
|
|
17
17
|
import ListBox from '../ListBox/index.js';
|
|
@@ -217,7 +217,7 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
217
217
|
[`${prefix}--text-input--empty`]: !inputValue,
|
|
218
218
|
[`${prefix}--text-input--light`]: light
|
|
219
219
|
});
|
|
220
|
-
const helper = helperText ? /*#__PURE__*/
|
|
220
|
+
const helper = helperText ? /*#__PURE__*/React.createElement("div", {
|
|
221
221
|
id: helperId,
|
|
222
222
|
className: helperClasses
|
|
223
223
|
}, helperText) : null;
|
|
@@ -425,9 +425,9 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
425
425
|
}
|
|
426
426
|
|
|
427
427
|
// AILabel always size `mini`
|
|
428
|
-
let normalizedDecorator = /*#__PURE__*/
|
|
428
|
+
let normalizedDecorator = /*#__PURE__*/React.isValidElement(slug ?? decorator) ? slug ?? decorator : null;
|
|
429
429
|
if (normalizedDecorator && normalizedDecorator['type']?.displayName === 'AILabel') {
|
|
430
|
-
normalizedDecorator = /*#__PURE__*/
|
|
430
|
+
normalizedDecorator = /*#__PURE__*/React.cloneElement(normalizedDecorator, {
|
|
431
431
|
size: 'mini'
|
|
432
432
|
});
|
|
433
433
|
}
|
|
@@ -543,18 +543,14 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
543
543
|
}
|
|
544
544
|
}
|
|
545
545
|
} : {};
|
|
546
|
-
const clearSelectionContent = controlledSelectedItems.length > 0 ?
|
|
547
|
-
|
|
548
|
-
}, clearSelectionDescription, " ", controlledSelectedItems.length, ",", clearSelectionText) : /*#__PURE__*/React__default.createElement("span", {
|
|
549
|
-
className: `${prefix}--visually-hidden`
|
|
550
|
-
}, clearSelectionDescription, ": 0");
|
|
551
|
-
return /*#__PURE__*/React__default.createElement("div", {
|
|
546
|
+
const clearSelectionContent = controlledSelectedItems.length > 0 ? `${clearSelectionDescription} ${controlledSelectedItems.length}. ${clearSelectionText}.` : `${clearSelectionDescription} 0.`;
|
|
547
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
552
548
|
className: wrapperClasses
|
|
553
|
-
}, titleText ? /*#__PURE__*/
|
|
549
|
+
}, titleText ? /*#__PURE__*/React.createElement("label", _extends({
|
|
554
550
|
className: titleClasses
|
|
555
|
-
}, labelProps), titleText, /*#__PURE__*/
|
|
551
|
+
}, labelProps), titleText, /*#__PURE__*/React.createElement("span", {
|
|
556
552
|
className: `${prefix}--visually-hidden`
|
|
557
|
-
}, clearSelectionContent)) : null, /*#__PURE__*/
|
|
553
|
+
}, clearSelectionContent)) : null, /*#__PURE__*/React.createElement(ListBox, {
|
|
558
554
|
onFocus: isFluid ? handleFocus : undefined,
|
|
559
555
|
onBlur: isFluid ? handleFocus : undefined,
|
|
560
556
|
className: className,
|
|
@@ -568,10 +564,10 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
568
564
|
warnText: warnText,
|
|
569
565
|
isOpen: !readOnly && isOpen,
|
|
570
566
|
size: size$1
|
|
571
|
-
}, /*#__PURE__*/
|
|
567
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
572
568
|
className: `${prefix}--list-box__field`,
|
|
573
569
|
ref: autoAlign ? refs.setReference : null
|
|
574
|
-
}, controlledSelectedItems.length > 0 && /*#__PURE__*/
|
|
570
|
+
}, controlledSelectedItems.length > 0 && /*#__PURE__*/React.createElement(ListBoxSelection, {
|
|
575
571
|
readOnly: readOnly,
|
|
576
572
|
clearSelection: () => {
|
|
577
573
|
clearSelection();
|
|
@@ -582,17 +578,17 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
582
578
|
selectionCount: controlledSelectedItems.length,
|
|
583
579
|
translateWithId: translateWithId,
|
|
584
580
|
disabled: disabled
|
|
585
|
-
}), /*#__PURE__*/
|
|
581
|
+
}), /*#__PURE__*/React.createElement("input", _extends({
|
|
586
582
|
className: inputClasses
|
|
587
583
|
}, inputProps, {
|
|
588
584
|
ref: mergedRef
|
|
589
585
|
}, readOnlyEventHandlers, {
|
|
590
586
|
readOnly: readOnly
|
|
591
|
-
})), invalid && /*#__PURE__*/
|
|
587
|
+
})), invalid && /*#__PURE__*/React.createElement(WarningFilled, {
|
|
592
588
|
className: `${prefix}--list-box__invalid-icon`
|
|
593
|
-
}), showWarning && /*#__PURE__*/
|
|
589
|
+
}), showWarning && /*#__PURE__*/React.createElement(WarningAltFilled, {
|
|
594
590
|
className: `${prefix}--list-box__invalid-icon ${prefix}--list-box__invalid-icon--warning`
|
|
595
|
-
}), inputValue && /*#__PURE__*/
|
|
591
|
+
}), inputValue && /*#__PURE__*/React.createElement(ListBoxSelection, {
|
|
596
592
|
clearSelection: clearInputValue,
|
|
597
593
|
disabled: disabled,
|
|
598
594
|
translateWithId: translateWithId,
|
|
@@ -605,12 +601,12 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
605
601
|
// ListBoxSelection
|
|
606
602
|
event.stopPropagation();
|
|
607
603
|
}
|
|
608
|
-
}), /*#__PURE__*/
|
|
604
|
+
}), /*#__PURE__*/React.createElement(ListBoxTrigger, _extends({}, buttonProps, {
|
|
609
605
|
isOpen: isOpen,
|
|
610
606
|
translateWithId: translateWithId
|
|
611
|
-
}))), slug ? normalizedDecorator : decorator ? /*#__PURE__*/
|
|
607
|
+
}))), slug ? normalizedDecorator : decorator ? /*#__PURE__*/React.createElement("div", {
|
|
612
608
|
className: `${prefix}--list-box__inner-wrapper--decorator`
|
|
613
|
-
}, normalizedDecorator) : '', /*#__PURE__*/
|
|
609
|
+
}, normalizedDecorator) : '', /*#__PURE__*/React.createElement(ListBox.Menu, menuProps, isOpen ? sortedItems.map((item, index) => {
|
|
614
610
|
const isChecked = controlledSelectedItems.filter(selected => isEqual(selected, item)).length > 0;
|
|
615
611
|
const itemProps = getItemProps({
|
|
616
612
|
item,
|
|
@@ -628,21 +624,21 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
|
|
|
628
624
|
// eslint-disable-line @typescript-eslint/no-unused-vars
|
|
629
625
|
...modifiedItemProps
|
|
630
626
|
} = itemProps;
|
|
631
|
-
return /*#__PURE__*/
|
|
627
|
+
return /*#__PURE__*/React.createElement(ListBox.MenuItem, _extends({
|
|
632
628
|
key: itemProps.id,
|
|
633
629
|
"aria-label": itemText,
|
|
634
630
|
isActive: isChecked,
|
|
635
631
|
isHighlighted: highlightedIndex === index,
|
|
636
632
|
title: itemText,
|
|
637
633
|
disabled: disabled
|
|
638
|
-
}, modifiedItemProps), /*#__PURE__*/
|
|
634
|
+
}, modifiedItemProps), /*#__PURE__*/React.createElement("div", {
|
|
639
635
|
className: `${prefix}--checkbox-wrapper`
|
|
640
|
-
}, /*#__PURE__*/
|
|
636
|
+
}, /*#__PURE__*/React.createElement("span", {
|
|
641
637
|
title: useTitleInItem ? itemText : undefined,
|
|
642
638
|
className: `${prefix}--checkbox-label`,
|
|
643
639
|
"data-contained-checkbox-state": isChecked,
|
|
644
640
|
id: `${itemProps.id}-item`
|
|
645
|
-
}, ItemToElement ? /*#__PURE__*/
|
|
641
|
+
}, ItemToElement ? /*#__PURE__*/React.createElement(ItemToElement, _extends({
|
|
646
642
|
key: itemProps.id
|
|
647
643
|
}, item)) : itemText)));
|
|
648
644
|
}) : null)), !inline && !invalid && !warn ? helper : null);
|
|
@@ -11,7 +11,7 @@ import cx from 'classnames';
|
|
|
11
11
|
import { useSelect } from 'downshift';
|
|
12
12
|
import isEqual from 'react-fast-compare';
|
|
13
13
|
import PropTypes from 'prop-types';
|
|
14
|
-
import
|
|
14
|
+
import React, { useMemo, useContext, useState, useLayoutEffect, isValidElement, useCallback } from 'react';
|
|
15
15
|
import ListBox from '../ListBox/index.js';
|
|
16
16
|
import { sortingPropTypes } from './MultiSelectPropTypes.js';
|
|
17
17
|
import { defaultSortItems, defaultCompareItems } from './tools/sorting.js';
|
|
@@ -58,7 +58,7 @@ const defaultItemToString = item => {
|
|
|
58
58
|
}
|
|
59
59
|
return '';
|
|
60
60
|
};
|
|
61
|
-
const MultiSelect = /*#__PURE__*/
|
|
61
|
+
const MultiSelect = /*#__PURE__*/React.forwardRef((_ref, ref) => {
|
|
62
62
|
let {
|
|
63
63
|
autoAlign = false,
|
|
64
64
|
className: containerClassName,
|
|
@@ -411,9 +411,9 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
411
411
|
} : {};
|
|
412
412
|
|
|
413
413
|
// AILabel always size `mini`
|
|
414
|
-
let normalizedDecorator = /*#__PURE__*/
|
|
414
|
+
let normalizedDecorator = /*#__PURE__*/React.isValidElement(slug ?? decorator) ? slug ?? decorator : null;
|
|
415
415
|
if (normalizedDecorator && normalizedDecorator['type']?.displayName === 'AILabel') {
|
|
416
|
-
normalizedDecorator = /*#__PURE__*/
|
|
416
|
+
normalizedDecorator = /*#__PURE__*/React.cloneElement(normalizedDecorator, {
|
|
417
417
|
size: 'mini'
|
|
418
418
|
});
|
|
419
419
|
}
|
|
@@ -438,13 +438,13 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
438
438
|
totalSelectableCount
|
|
439
439
|
};
|
|
440
440
|
}, [selectedItems, filteredItems]);
|
|
441
|
-
return /*#__PURE__*/
|
|
441
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
442
442
|
className: wrapperClasses
|
|
443
|
-
}, /*#__PURE__*/
|
|
443
|
+
}, /*#__PURE__*/React.createElement("label", _extends({
|
|
444
444
|
className: titleClasses
|
|
445
|
-
}, labelProps), titleText && titleText, selectedItems.length > 0 && /*#__PURE__*/
|
|
445
|
+
}, labelProps), titleText && titleText, selectedItems.length > 0 && /*#__PURE__*/React.createElement("span", {
|
|
446
446
|
className: `${prefix}--visually-hidden`
|
|
447
|
-
}, clearSelectionDescription, " ", selectedItems.length, ' ', itemsSelectedText, ",", clearSelectionText)), /*#__PURE__*/
|
|
447
|
+
}, clearSelectionDescription, " ", selectedItems.length, ' ', itemsSelectedText, ",", clearSelectionText)), /*#__PURE__*/React.createElement(ListBox, {
|
|
448
448
|
onFocus: isFluid ? handleFocus : undefined,
|
|
449
449
|
onBlur: isFluid ? handleFocus : undefined,
|
|
450
450
|
type: type,
|
|
@@ -458,14 +458,14 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
458
458
|
warnText: warnText,
|
|
459
459
|
isOpen: isOpen,
|
|
460
460
|
id: id
|
|
461
|
-
}, invalid && /*#__PURE__*/
|
|
461
|
+
}, invalid && /*#__PURE__*/React.createElement(WarningFilled, {
|
|
462
462
|
className: `${prefix}--list-box__invalid-icon`
|
|
463
|
-
}), showWarning && /*#__PURE__*/
|
|
463
|
+
}), showWarning && /*#__PURE__*/React.createElement(WarningAltFilled, {
|
|
464
464
|
className: `${prefix}--list-box__invalid-icon ${prefix}--list-box__invalid-icon--warning`
|
|
465
|
-
}), /*#__PURE__*/
|
|
465
|
+
}), /*#__PURE__*/React.createElement("div", {
|
|
466
466
|
className: multiSelectFieldWrapperClasses,
|
|
467
467
|
ref: enableFloatingStyles ? refs.setReference : null
|
|
468
|
-
}, selectedItems.length > 0 && /*#__PURE__*/
|
|
468
|
+
}, selectedItems.length > 0 && /*#__PURE__*/React.createElement(ListBox.Selection, {
|
|
469
469
|
readOnly: readOnly,
|
|
470
470
|
clearSelection: !disabled && !readOnly ? clearSelection : noopFn,
|
|
471
471
|
selectionCount: selectedItemsLength
|
|
@@ -473,7 +473,7 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
473
473
|
,
|
|
474
474
|
translateWithId: translateWithId,
|
|
475
475
|
disabled: disabled
|
|
476
|
-
}), /*#__PURE__*/
|
|
476
|
+
}), /*#__PURE__*/React.createElement("button", _extends({
|
|
477
477
|
type: "button",
|
|
478
478
|
className: `${prefix}--list-box__field`,
|
|
479
479
|
disabled: disabled,
|
|
@@ -481,15 +481,15 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
481
481
|
"aria-describedby": !inline && !invalid && !warn && helperText ? helperId : undefined
|
|
482
482
|
}, toggleButtonProps, {
|
|
483
483
|
ref: mergedRef
|
|
484
|
-
}, readOnlyEventHandlers), /*#__PURE__*/
|
|
484
|
+
}, readOnlyEventHandlers), /*#__PURE__*/React.createElement("span", {
|
|
485
485
|
id: fieldLabelId,
|
|
486
486
|
className: `${prefix}--list-box__label`
|
|
487
|
-
}, label), /*#__PURE__*/
|
|
487
|
+
}, label), /*#__PURE__*/React.createElement(ListBox.MenuIcon, {
|
|
488
488
|
isOpen: isOpen,
|
|
489
489
|
translateWithId: translateWithId
|
|
490
|
-
})), slug ? normalizedDecorator : decorator ? /*#__PURE__*/
|
|
490
|
+
})), slug ? normalizedDecorator : decorator ? /*#__PURE__*/React.createElement("div", {
|
|
491
491
|
className: `${prefix}--list-box__inner-wrapper--decorator`
|
|
492
|
-
}, normalizedDecorator) : ''), /*#__PURE__*/
|
|
492
|
+
}, normalizedDecorator) : ''), /*#__PURE__*/React.createElement(ListBox.Menu, menuProps, isOpen && sortItems(filteredItems, sortOptions).map((item, index) => {
|
|
493
493
|
const isChecked = selectedItems.filter(selected => isEqual(selected, item)).length > 0;
|
|
494
494
|
const {
|
|
495
495
|
hasIndividualSelections,
|
|
@@ -504,18 +504,18 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
504
504
|
['aria-selected']: isChecked
|
|
505
505
|
});
|
|
506
506
|
const itemText = itemToString(item);
|
|
507
|
-
return /*#__PURE__*/
|
|
507
|
+
return /*#__PURE__*/React.createElement(ListBox.MenuItem, _extends({
|
|
508
508
|
key: itemProps.id,
|
|
509
509
|
isActive: isChecked && !item['isSelectAll'],
|
|
510
510
|
"aria-label": itemText,
|
|
511
511
|
isHighlighted: highlightedIndex === index,
|
|
512
512
|
title: itemText,
|
|
513
513
|
disabled: itemProps['aria-disabled']
|
|
514
|
-
}, itemProps), /*#__PURE__*/
|
|
514
|
+
}, itemProps), /*#__PURE__*/React.createElement("div", {
|
|
515
515
|
className: `${prefix}--checkbox-wrapper`
|
|
516
|
-
}, /*#__PURE__*/
|
|
516
|
+
}, /*#__PURE__*/React.createElement(Checkbox, {
|
|
517
517
|
id: `${itemProps.id}__checkbox`,
|
|
518
|
-
labelText: itemToElement ? /*#__PURE__*/
|
|
518
|
+
labelText: itemToElement ? /*#__PURE__*/React.createElement(ItemToElement, _extends({
|
|
519
519
|
key: itemProps.id
|
|
520
520
|
}, item)) : itemText,
|
|
521
521
|
checked: isChecked,
|
|
@@ -523,10 +523,10 @@ const MultiSelect = /*#__PURE__*/React__default.forwardRef((_ref, ref) => {
|
|
|
523
523
|
indeterminate: isIndeterminate,
|
|
524
524
|
disabled: disabled
|
|
525
525
|
})));
|
|
526
|
-
})), itemsCleared && /*#__PURE__*/
|
|
526
|
+
})), itemsCleared && /*#__PURE__*/React.createElement("span", {
|
|
527
527
|
"aria-live": "assertive",
|
|
528
528
|
"aria-label": clearAnnouncement
|
|
529
|
-
})), !inline && !invalid && !warn && helperText && /*#__PURE__*/
|
|
529
|
+
})), !inline && !invalid && !warn && helperText && /*#__PURE__*/React.createElement("div", {
|
|
530
530
|
id: helperId,
|
|
531
531
|
className: helperClasses
|
|
532
532
|
}, helperText));
|