@carbon/react 1.103.0-rc.0 → 1.104.0-rc.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 +950 -950
- package/es/_virtual/_rolldown/runtime.js +25 -0
- package/es/components/AILabel/index.d.ts +29 -2
- package/es/components/AILabel/index.js +114 -169
- package/es/components/AISkeleton/AISkeletonIcon.js +23 -27
- package/es/components/AISkeleton/AISkeletonPlaceholder.js +19 -27
- package/es/components/AISkeleton/AISkeletonText.js +26 -39
- package/es/components/Accordion/Accordion.Skeleton.js +55 -79
- package/es/components/Accordion/Accordion.js +43 -61
- package/es/components/Accordion/AccordionItem.js +102 -156
- package/es/components/Accordion/AccordionProvider.js +18 -15
- package/es/components/AspectRatio/AspectRatio.js +41 -47
- package/es/components/BadgeIndicator/index.js +28 -33
- package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +39 -50
- package/es/components/Breadcrumb/Breadcrumb.js +39 -51
- package/es/components/Breadcrumb/BreadcrumbItem.js +80 -83
- package/es/components/Button/Button.Skeleton.js +49 -58
- package/es/components/Button/Button.d.ts +1 -1
- package/es/components/Button/Button.js +146 -240
- package/es/components/Button/ButtonBase.js +82 -104
- package/es/components/Button/index.js +13 -6
- package/es/components/ButtonSet/ButtonSet.js +74 -98
- package/es/components/ButtonSet/index.js +12 -4
- package/es/components/ChatButton/ChatButton.Skeleton.js +27 -27
- package/es/components/ChatButton/ChatButton.js +64 -79
- package/es/components/Checkbox/Checkbox.Skeleton.js +26 -25
- package/es/components/Checkbox/Checkbox.js +116 -195
- package/es/components/Checkbox/index.js +13 -5
- package/es/components/CheckboxGroup/CheckboxGroup.js +100 -148
- package/es/components/ClassPrefix/index.js +21 -17
- package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +45 -42
- package/es/components/CodeSnippet/CodeSnippet.js +210 -299
- package/es/components/ComboBox/ComboBox.js +621 -970
- package/es/components/ComboBox/index.js +12 -4
- package/es/components/ComboButton/index.js +172 -208
- package/es/components/ComposedModal/ComposedModal.js +311 -450
- package/es/components/ComposedModal/ComposedModalPresence.js +47 -42
- package/es/components/ComposedModal/ModalFooter.js +127 -207
- package/es/components/ComposedModal/ModalHeader.js +71 -101
- package/es/components/ComposedModal/useComposedModalState.js +21 -15
- package/es/components/ContainedList/ContainedList.js +67 -102
- package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +49 -67
- package/es/components/ContainedList/ContainedListItem/index.js +12 -4
- package/es/components/ContainedList/index.js +15 -12
- package/es/components/ContentSwitcher/ContentSwitcher.js +108 -140
- package/es/components/ContextMenu/useContextMenu.js +41 -36
- package/es/components/Copy/Copy.js +97 -117
- package/es/components/Copy/index.js +12 -4
- package/es/components/CopyButton/CopyButton.js +81 -94
- package/es/components/CopyButton/index.js +12 -4
- package/es/components/DangerButton/DangerButton.js +11 -9
- package/es/components/DataTable/DataTable.d.ts +11 -11
- package/es/components/DataTable/DataTable.js +448 -630
- package/es/components/DataTable/Table.js +111 -156
- package/es/components/DataTable/TableActionList.js +14 -6
- package/es/components/DataTable/TableBatchAction.js +25 -34
- package/es/components/DataTable/TableBatchActions.js +78 -113
- package/es/components/DataTable/TableBody.js +26 -19
- package/es/components/DataTable/TableCell.js +31 -46
- package/es/components/DataTable/TableContainer.js +75 -82
- package/es/components/DataTable/TableContext.js +14 -6
- package/es/components/DataTable/TableDecoratorRow.js +30 -36
- package/es/components/DataTable/TableExpandHeader.js +53 -90
- package/es/components/DataTable/TableExpandRow.js +82 -119
- package/es/components/DataTable/TableExpandedRow.js +45 -51
- package/es/components/DataTable/TableHead.js +7 -5
- package/es/components/DataTable/TableHeader.js +138 -181
- package/es/components/DataTable/TableRow.d.ts +1 -1
- package/es/components/DataTable/TableRow.js +42 -76
- package/es/components/DataTable/TableSelectAll.js +42 -70
- package/es/components/DataTable/TableSelectRow.js +63 -98
- package/es/components/DataTable/TableSlugRow.js +35 -43
- package/es/components/DataTable/TableToolbar.js +33 -45
- package/es/components/DataTable/TableToolbarAction.js +25 -20
- package/es/components/DataTable/TableToolbarContent.js +14 -6
- package/es/components/DataTable/TableToolbarMenu.js +35 -46
- package/es/components/DataTable/TableToolbarSearch.js +97 -187
- package/es/components/DataTable/state/getDerivedStateFromProps.js +38 -43
- package/es/components/DataTable/state/sortStates.js +11 -9
- package/es/components/DataTable/state/sorting.js +53 -72
- package/es/components/DataTable/tools/cells.js +15 -7
- package/es/components/DataTable/tools/denormalize.js +27 -19
- package/es/components/DataTable/tools/filter.js +21 -22
- package/es/components/DataTable/tools/normalize.js +57 -72
- package/es/components/DataTable/tools/sorting.js +50 -71
- package/es/components/DataTableSkeleton/DataTableSkeleton.js +66 -94
- package/es/components/DatePicker/DatePicker.Skeleton.js +44 -51
- package/es/components/DatePicker/DatePicker.d.ts +4 -2
- package/es/components/DatePicker/DatePicker.js +485 -749
- package/es/components/DatePicker/DatePickerLocales.js +75 -126
- package/es/components/DatePicker/index.js +13 -5
- package/es/components/DatePicker/plugins/appendToPlugin.js +31 -45
- package/es/components/DatePicker/plugins/fixEventsPlugin.js +127 -171
- package/es/components/DatePicker/plugins/rangePlugin.d.ts +1 -1
- package/es/components/DatePicker/plugins/rangePlugin.js +40 -47
- package/es/components/DatePicker/utils.d.ts +7 -0
- package/es/components/DatePicker/utils.js +18 -0
- package/es/components/DatePickerInput/DatePickerInput.js +179 -289
- package/es/components/DatePickerInput/index.js +12 -4
- package/es/components/Dialog/Dialog.js +303 -574
- package/es/components/Dialog/index.js +18 -2
- package/es/components/Dropdown/Dropdown.Skeleton.js +26 -38
- package/es/components/Dropdown/Dropdown.js +344 -535
- package/es/components/Dropdown/index.js +13 -5
- package/es/components/ErrorBoundary/ErrorBoundary.js +36 -58
- package/es/components/ErrorBoundary/ErrorBoundaryContext.js +14 -9
- package/es/components/ExpandableSearch/ExpandableSearch.js +60 -69
- package/es/components/ExpandableSearch/index.js +12 -4
- package/es/components/FeatureFlags/index.d.ts +11 -2
- package/es/components/FeatureFlags/index.js +79 -77
- package/es/components/FileUploader/FileUploader.Skeleton.js +35 -30
- package/es/components/FileUploader/FileUploader.js +269 -343
- package/es/components/FileUploader/FileUploaderButton.js +110 -160
- package/es/components/FileUploader/FileUploaderDropContainer.js +144 -221
- package/es/components/FileUploader/FileUploaderItem.js +138 -157
- package/es/components/FileUploader/Filename.d.ts +1 -1
- package/es/components/FileUploader/Filename.js +53 -72
- package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +26 -28
- package/es/components/FluidComboBox/FluidComboBox.js +54 -105
- package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +56 -53
- package/es/components/FluidDatePicker/FluidDatePicker.js +46 -68
- package/es/components/FluidDatePickerInput/FluidDatePickerInput.js +23 -16
- package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +26 -28
- package/es/components/FluidDropdown/FluidDropdown.js +55 -111
- package/es/components/FluidForm/FluidForm.js +29 -31
- package/es/components/FluidForm/FormContext.js +12 -6
- package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +26 -28
- package/es/components/FluidMultiSelect/FluidMultiSelect.js +67 -197
- package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +27 -30
- package/es/components/FluidNumberInput/FluidNumberInput.js +63 -147
- package/es/components/FluidSearch/FluidSearch.Skeleton.js +27 -30
- package/es/components/FluidSearch/FluidSearch.js +41 -84
- package/es/components/FluidSelect/FluidSelect.Skeleton.js +26 -28
- package/es/components/FluidSelect/FluidSelect.js +40 -76
- package/es/components/FluidSelect/index.js +13 -5
- package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +27 -30
- package/es/components/FluidTextArea/FluidTextArea.js +48 -112
- package/es/components/FluidTextInput/FluidPasswordInput.js +44 -99
- package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +27 -30
- package/es/components/FluidTextInput/FluidTextInput.js +49 -104
- package/es/components/FluidTextInput/index.js +14 -6
- package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +30 -33
- package/es/components/FluidTimePicker/FluidTimePicker.js +68 -115
- package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +28 -47
- package/es/components/Form/Form.js +23 -25
- package/es/components/FormGroup/FormGroup.js +45 -67
- package/es/components/FormItem/FormItem.js +23 -25
- package/es/components/FormLabel/FormLabel.js +28 -34
- package/es/components/Grid/CSSGrid.d.ts +1 -1
- package/es/components/Grid/CSSGrid.js +85 -127
- package/es/components/Grid/Column.js +192 -324
- package/es/components/Grid/ColumnHang.js +28 -36
- package/es/components/Grid/FlexGrid.js +40 -60
- package/es/components/Grid/Grid.js +29 -42
- package/es/components/Grid/GridContext.js +36 -42
- package/es/components/Grid/Row.js +31 -49
- package/es/components/Heading/index.js +36 -51
- package/es/components/Icon/Icon.Skeleton.js +21 -21
- package/es/components/IconButton/index.js +117 -178
- package/es/components/IconIndicator/index.d.ts +1 -1
- package/es/components/IconIndicator/index.js +59 -60
- package/es/components/IdPrefix/index.js +21 -17
- package/es/components/InlineCheckbox/InlineCheckbox.js +69 -113
- package/es/components/InlineCheckbox/index.js +12 -4
- package/es/components/InlineLoading/InlineLoading.js +83 -100
- package/es/components/InlineLoading/index.js +12 -4
- package/es/components/Layer/LayerContext.js +12 -4
- package/es/components/Layer/LayerLevel.js +20 -4
- package/es/components/Layer/index.js +54 -66
- package/es/components/Layout/index.js +77 -109
- package/es/components/LayoutDirection/LayoutDirection.d.ts +1 -1
- package/es/components/LayoutDirection/LayoutDirection.js +33 -37
- package/es/components/LayoutDirection/LayoutDirectionContext.js +12 -6
- package/es/components/LayoutDirection/useLayoutDirection.js +15 -7
- package/es/components/Link/Link.js +63 -108
- package/es/components/Link/index.js +12 -4
- package/es/components/ListBox/ListBox.js +78 -126
- package/es/components/ListBox/ListBoxField.js +24 -43
- package/es/components/ListBox/ListBoxMenu.js +36 -42
- package/es/components/ListBox/ListBoxMenuIcon.js +39 -40
- package/es/components/ListBox/ListBoxMenuItem.js +67 -88
- package/es/components/ListBox/ListBoxPropTypes.js +17 -5
- package/es/components/ListBox/ListBoxSelection.js +71 -96
- package/es/components/ListBox/index.js +16 -14
- package/es/components/ListBox/next/ListBoxSelection.js +79 -117
- package/es/components/ListBox/next/ListBoxTrigger.js +44 -48
- package/es/components/ListItem/ListItem.js +25 -28
- package/es/components/Loading/Loading.js +64 -73
- package/es/components/Loading/index.js +12 -4
- package/es/components/Menu/Menu.js +220 -363
- package/es/components/Menu/MenuContext.d.ts +1 -1
- package/es/components/Menu/MenuContext.js +41 -38
- package/es/components/Menu/MenuItem.js +282 -413
- package/es/components/MenuButton/index.js +134 -195
- package/es/components/Modal/Modal.js +500 -660
- package/es/components/Modal/ModalPresence.js +39 -37
- package/es/components/Modal/index.js +13 -5
- package/es/components/ModalWrapper/ModalWrapper.d.ts +2 -2
- package/es/components/ModalWrapper/ModalWrapper.js +106 -130
- package/es/components/MultiSelect/FilterableMultiSelect.js +605 -918
- package/es/components/MultiSelect/MultiSelect.js +454 -716
- package/es/components/MultiSelect/MultiSelectPropTypes.js +13 -30
- package/es/components/MultiSelect/filter.js +14 -9
- package/es/components/MultiSelect/tools/sorting.js +21 -34
- package/es/components/Notification/Notification.js +508 -785
- package/es/components/NumberInput/NumberFormatPropTypes.js +69 -30
- package/es/components/NumberInput/NumberInput.Skeleton.js +29 -33
- package/es/components/NumberInput/NumberInput.js +567 -947
- package/es/components/OrderedList/OrderedList.js +31 -44
- package/es/components/OverflowMenu/OverflowMenu.js +335 -450
- package/es/components/OverflowMenu/index.js +25 -16
- package/es/components/OverflowMenu/next/index.js +154 -186
- package/es/components/OverflowMenuItem/OverflowMenuItem.js +100 -160
- package/es/components/OverflowMenuItem/index.js +12 -4
- package/es/components/OverflowMenuV2/index.js +15 -13
- package/es/components/PageHeader/PageHeader.js +297 -442
- package/es/components/PageHeader/index.js +24 -2
- package/es/components/Pagination/Pagination.Skeleton.js +34 -35
- package/es/components/Pagination/Pagination.d.ts +1 -1
- package/es/components/Pagination/Pagination.js +251 -356
- package/es/components/Pagination/experimental/PageSelector.js +38 -54
- package/es/components/Pagination/experimental/Pagination-story.d.ts +114 -0
- package/es/components/Pagination/experimental/Pagination.js +144 -196
- package/es/components/PaginationNav/PaginationNav.js +320 -426
- package/es/components/Popover/index.js +318 -437
- package/es/components/PrimaryButton/PrimaryButton.js +11 -9
- package/es/components/ProgressBar/ProgressBar.js +117 -143
- package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +42 -38
- package/es/components/ProgressIndicator/ProgressIndicator.js +146 -243
- package/es/components/RadioButton/RadioButton.Skeleton.js +23 -25
- package/es/components/RadioButton/RadioButton.js +101 -174
- package/es/components/RadioButton/index.js +12 -4
- package/es/components/RadioButtonGroup/RadioButtonGroup.js +135 -207
- package/es/components/RadioTile/RadioTile.js +104 -168
- package/es/components/RadioTile/index.js +12 -4
- package/es/components/Search/Search.Skeleton.js +28 -33
- package/es/components/Search/Search.js +182 -278
- package/es/components/Search/index.js +13 -5
- package/es/components/Search/utils.js +11 -3
- package/es/components/SecondaryButton/SecondaryButton.js +11 -9
- package/es/components/Select/Select.Skeleton.js +27 -30
- package/es/components/Select/Select.js +178 -257
- package/es/components/Select/index.js +13 -5
- package/es/components/SelectItem/SelectItem.js +33 -48
- package/es/components/SelectItem/index.js +12 -4
- package/es/components/SelectItemGroup/SelectItemGroup.js +27 -37
- package/es/components/ShapeIndicator/index.d.ts +1 -1
- package/es/components/ShapeIndicator/index.js +74 -80
- package/es/components/SkeletonIcon/SkeletonIcon.js +21 -24
- package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +15 -24
- package/es/components/SkeletonText/SkeletonText.js +67 -81
- package/es/components/SkeletonText/index.js +12 -4
- package/es/components/Slider/Slider.Skeleton.js +68 -91
- package/es/components/Slider/Slider.js +864 -1315
- package/es/components/Slider/SliderHandles.js +73 -66
- package/es/components/Stack/HStack.js +19 -11
- package/es/components/Stack/Stack.js +56 -80
- package/es/components/Stack/VStack.js +19 -11
- package/es/components/StructuredList/StructuredList.Skeleton.js +55 -48
- package/es/components/StructuredList/StructuredList.js +178 -317
- package/es/components/Switch/IconSwitch.js +99 -145
- package/es/components/Switch/Switch.js +66 -99
- package/es/components/TabContent/TabContent.js +28 -34
- package/es/components/Tabs/Tabs.Skeleton.js +41 -36
- package/es/components/Tabs/Tabs.js +732 -1147
- package/es/components/Tabs/usePressable.js +97 -112
- package/es/components/Tag/DismissibleTag.js +119 -156
- package/es/components/Tag/OperationalTag.js +91 -111
- package/es/components/Tag/SelectableTag.js +94 -129
- package/es/components/Tag/Tag.Skeleton.js +26 -30
- package/es/components/Tag/Tag.js +152 -200
- package/es/components/Tag/isEllipsisActive.js +13 -8
- package/es/components/Text/Text.js +66 -79
- package/es/components/Text/TextDirection.js +36 -37
- package/es/components/Text/TextDirectionContext.js +14 -8
- package/es/components/Text/createTextComponent.js +21 -20
- package/es/components/TextArea/TextArea.Skeleton.js +25 -29
- package/es/components/TextArea/TextArea.js +315 -422
- package/es/components/TextArea/index.js +13 -5
- package/es/components/TextInput/ControlledPasswordInput.js +133 -198
- package/es/components/TextInput/PasswordInput.js +196 -303
- package/es/components/TextInput/TextInput.Skeleton.js +24 -28
- package/es/components/TextInput/TextInput.js +219 -317
- package/es/components/TextInput/index.js +13 -5
- package/es/components/TextInput/util.js +21 -25
- package/es/components/Theme/index.js +79 -95
- package/es/components/Tile/Tile.d.ts +2 -2
- package/es/components/Tile/Tile.js +394 -588
- package/es/components/TileGroup/TileGroup.js +70 -111
- package/es/components/TimePicker/TimePicker.d.ts +1 -1
- package/es/components/TimePicker/TimePicker.js +148 -247
- package/es/components/TimePickerSelect/TimePickerSelect.js +43 -58
- package/es/components/Toggle/Toggle.Skeleton.js +24 -22
- package/es/components/Toggle/Toggle.js +102 -171
- package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +46 -51
- package/es/components/Toggletip/index.d.ts +2 -2
- package/es/components/Toggletip/index.js +170 -256
- package/es/components/Tooltip/DefinitionTooltip.js +98 -138
- package/es/components/Tooltip/Tooltip.js +188 -263
- package/es/components/TreeView/TreeContext.js +13 -5
- package/es/components/TreeView/TreeNode.js +361 -500
- package/es/components/TreeView/TreeView.js +164 -237
- package/es/components/UIShell/Content.js +23 -30
- package/es/components/UIShell/Header.js +25 -29
- package/es/components/UIShell/HeaderContainer.js +31 -40
- package/es/components/UIShell/HeaderGlobalAction.js +65 -90
- package/es/components/UIShell/HeaderGlobalBar.js +16 -9
- package/es/components/UIShell/HeaderMenu.js +141 -215
- package/es/components/UIShell/HeaderMenuButton.js +43 -66
- package/es/components/UIShell/HeaderMenuItem.js +49 -76
- package/es/components/UIShell/HeaderName.js +32 -44
- package/es/components/UIShell/HeaderNavigation.js +32 -37
- package/es/components/UIShell/HeaderPanel.js +74 -97
- package/es/components/UIShell/HeaderSideNavItems.js +27 -33
- package/es/components/UIShell/Link.js +29 -50
- package/es/components/UIShell/SideNav.js +132 -241
- package/es/components/UIShell/SideNavContext.js +21 -15
- package/es/components/UIShell/SideNavDetails.js +29 -34
- package/es/components/UIShell/SideNavDivider.js +21 -21
- package/es/components/UIShell/SideNavFooter.js +43 -52
- package/es/components/UIShell/SideNavHeader.js +26 -35
- package/es/components/UIShell/SideNavIcon.js +28 -33
- package/es/components/UIShell/SideNavItem.js +28 -33
- package/es/components/UIShell/SideNavItems.js +31 -40
- package/es/components/UIShell/SideNavLink.js +52 -79
- package/es/components/UIShell/SideNavLinkText.js +24 -25
- package/es/components/UIShell/SideNavMenu.js +102 -143
- package/es/components/UIShell/SideNavMenuItem.js +40 -52
- package/es/components/UIShell/SideNavSwitcher.js +59 -68
- package/es/components/UIShell/SkipToContent.js +28 -36
- package/es/components/UIShell/Switcher.js +69 -99
- package/es/components/UIShell/SwitcherDivider.js +16 -24
- package/es/components/UIShell/SwitcherItem.js +74 -114
- package/es/components/UnorderedList/UnorderedList.js +28 -37
- package/es/feature-flags.js +19 -10
- package/es/index.js +249 -242
- package/es/internal/FloatingMenu.js +246 -292
- package/es/internal/OptimizedResize.js +35 -46
- package/es/internal/Selection.js +99 -132
- package/es/internal/clamp.js +12 -4
- package/es/internal/defaultItemToString.js +15 -9
- package/es/internal/deprecateFieldOnObject.js +22 -14
- package/es/internal/environment.js +15 -7
- package/es/internal/getAnnouncement.js +16 -13
- package/es/internal/keyboard/keys.js +48 -48
- package/es/internal/keyboard/match.js +25 -42
- package/es/internal/keyboard/navigation.js +22 -27
- package/es/internal/noopFn.js +10 -2
- package/es/internal/useAttachedMenu.js +43 -51
- package/es/internal/useControllableState.js +43 -48
- package/es/internal/useDelayedState.js +30 -35
- package/es/internal/useEvent.js +39 -35
- package/es/internal/useId.js +51 -87
- package/es/internal/useIdPrefix.js +13 -5
- package/es/internal/useIsomorphicEffect.js +12 -4
- package/es/internal/useMatchMedia.js +29 -21
- package/es/internal/useMergedRefs.js +26 -22
- package/es/internal/useNoInteractiveChildren.js +70 -99
- package/es/internal/useNormalizedInputProps.js +47 -51
- package/es/internal/useOutsideClick.js +21 -24
- package/es/internal/useOverflowItems.js +89 -90
- package/es/internal/usePrefix.js +13 -5
- package/es/internal/usePresence.js +51 -54
- package/es/internal/usePresenceContext.js +35 -35
- package/es/internal/usePreviousValue.js +26 -18
- package/es/internal/useResizeObserver.js +57 -66
- package/es/internal/useSavedCallback.js +24 -17
- package/es/internal/utils.js +17 -9
- package/es/internal/warning.js +17 -22
- package/es/internal/wrapFocus.js +77 -98
- package/es/prop-types/AriaPropTypes.js +14 -6
- package/es/prop-types/deprecate.js +30 -27
- package/es/prop-types/deprecateComponent.js +17 -8
- package/es/prop-types/deprecateValuesWithin.js +18 -21
- package/es/prop-types/isRequiredOneOf.js +21 -24
- package/es/prop-types/requiredIfGivenPropIsTruthy.js +14 -14
- package/es/tools/events.js +17 -21
- package/es/tools/mapPopoverAlign.js +19 -18
- package/es/tools/mergeRefs.js +14 -17
- package/es/tools/setupGetInstanceId.js +16 -8
- package/es/tools/toggleClass.js +17 -9
- package/es/tools/wrapComponent.js +34 -39
- package/icons/index.d.ts +2 -1
- package/icons/index.esm.js +2 -2
- package/icons/index.js +7 -10
- package/lib/_virtual/_rolldown/runtime.js +50 -0
- package/lib/components/AILabel/index.d.ts +29 -2
- package/lib/components/AILabel/index.js +118 -171
- package/lib/components/AISkeleton/AISkeletonIcon.js +27 -31
- package/lib/components/AISkeleton/AISkeletonPlaceholder.js +29 -31
- package/lib/components/AISkeleton/AISkeletonText.js +30 -43
- package/lib/components/Accordion/Accordion.Skeleton.js +59 -84
- package/lib/components/Accordion/Accordion.js +47 -65
- package/lib/components/Accordion/AccordionItem.js +106 -160
- package/lib/components/Accordion/AccordionProvider.js +20 -17
- package/lib/components/AspectRatio/AspectRatio.js +45 -51
- package/lib/components/BadgeIndicator/index.js +33 -39
- package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +43 -55
- package/lib/components/Breadcrumb/Breadcrumb.js +43 -55
- package/lib/components/Breadcrumb/BreadcrumbItem.js +84 -87
- package/lib/components/Button/Button.Skeleton.js +53 -63
- package/lib/components/Button/Button.d.ts +1 -1
- package/lib/components/Button/Button.js +149 -244
- package/lib/components/Button/ButtonBase.js +85 -108
- package/lib/components/Button/index.js +13 -15
- package/lib/components/ButtonSet/ButtonSet.js +78 -102
- package/lib/components/ButtonSet/index.js +12 -9
- package/lib/components/ChatButton/ChatButton.Skeleton.js +31 -31
- package/lib/components/ChatButton/ChatButton.js +68 -83
- package/lib/components/Checkbox/Checkbox.Skeleton.js +30 -30
- package/lib/components/Checkbox/Checkbox.js +119 -198
- package/lib/components/Checkbox/index.js +13 -11
- package/lib/components/CheckboxGroup/CheckboxGroup.js +104 -152
- package/lib/components/ClassPrefix/index.js +24 -19
- package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +49 -47
- package/lib/components/CodeSnippet/CodeSnippet.js +215 -303
- package/lib/components/ComboBox/ComboBox.js +626 -974
- package/lib/components/ComboBox/index.js +12 -9
- package/lib/components/ComboButton/index.js +176 -210
- package/lib/components/ComposedModal/ComposedModal.js +315 -454
- package/lib/components/ComposedModal/ComposedModalPresence.js +49 -44
- package/lib/components/ComposedModal/ModalFooter.js +131 -209
- package/lib/components/ComposedModal/ModalHeader.js +75 -103
- package/lib/components/ComposedModal/useComposedModalState.js +22 -17
- package/lib/components/ContainedList/ContainedList.js +77 -106
- package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +59 -71
- package/lib/components/ContainedList/ContainedListItem/index.js +12 -9
- package/lib/components/ContainedList/index.js +18 -15
- package/lib/components/ContentSwitcher/ContentSwitcher.js +112 -142
- package/lib/components/ContextMenu/useContextMenu.js +42 -40
- package/lib/components/Copy/Copy.js +101 -121
- package/lib/components/Copy/index.js +12 -9
- package/lib/components/CopyButton/CopyButton.js +85 -98
- package/lib/components/CopyButton/index.js +12 -9
- package/lib/components/DangerButton/DangerButton.js +19 -13
- package/lib/components/DataTable/DataTable.d.ts +11 -11
- package/lib/components/DataTable/DataTable.js +474 -655
- package/lib/components/DataTable/Table.js +115 -161
- package/lib/components/DataTable/TableActionList.js +15 -11
- package/lib/components/DataTable/TableBatchAction.js +28 -38
- package/lib/components/DataTable/TableBatchActions.js +82 -117
- package/lib/components/DataTable/TableBody.js +29 -23
- package/lib/components/DataTable/TableCell.js +35 -50
- package/lib/components/DataTable/TableContainer.js +79 -86
- package/lib/components/DataTable/TableContext.js +15 -8
- package/lib/components/DataTable/TableDecoratorRow.js +34 -40
- package/lib/components/DataTable/TableExpandHeader.js +57 -94
- package/lib/components/DataTable/TableExpandRow.js +86 -123
- package/lib/components/DataTable/TableExpandedRow.js +49 -55
- package/lib/components/DataTable/TableHead.js +8 -10
- package/lib/components/DataTable/TableHeader.js +142 -185
- package/lib/components/DataTable/TableRow.d.ts +1 -1
- package/lib/components/DataTable/TableRow.js +46 -80
- package/lib/components/DataTable/TableSelectAll.js +46 -74
- package/lib/components/DataTable/TableSelectRow.js +67 -102
- package/lib/components/DataTable/TableSlugRow.js +39 -47
- package/lib/components/DataTable/TableToolbar.js +37 -49
- package/lib/components/DataTable/TableToolbarAction.js +28 -24
- package/lib/components/DataTable/TableToolbarContent.js +15 -11
- package/lib/components/DataTable/TableToolbarMenu.js +39 -50
- package/lib/components/DataTable/TableToolbarSearch.js +101 -191
- package/lib/components/DataTable/state/getDerivedStateFromProps.js +38 -47
- package/lib/components/DataTable/state/sortStates.js +11 -10
- package/lib/components/DataTable/state/sorting.js +54 -76
- package/lib/components/DataTable/tools/cells.js +15 -8
- package/lib/components/DataTable/tools/denormalize.js +27 -22
- package/lib/components/DataTable/tools/filter.js +21 -23
- package/lib/components/DataTable/tools/normalize.js +57 -76
- package/lib/components/DataTable/tools/sorting.js +50 -75
- package/lib/components/DataTableSkeleton/DataTableSkeleton.js +70 -98
- package/lib/components/DatePicker/DatePicker.Skeleton.js +48 -56
- package/lib/components/DatePicker/DatePicker.d.ts +4 -2
- package/lib/components/DatePicker/DatePicker.js +491 -753
- package/lib/components/DatePicker/DatePickerLocales.js +75 -127
- package/lib/components/DatePicker/index.js +13 -11
- package/lib/components/DatePicker/plugins/appendToPlugin.js +31 -46
- package/lib/components/DatePicker/plugins/fixEventsPlugin.js +127 -175
- package/lib/components/DatePicker/plugins/rangePlugin.d.ts +1 -1
- package/lib/components/DatePicker/plugins/rangePlugin.js +42 -49
- package/lib/components/DatePicker/utils.d.ts +7 -0
- package/lib/components/DatePicker/utils.js +19 -0
- package/lib/components/DatePickerInput/DatePickerInput.js +183 -293
- package/lib/components/DatePickerInput/index.js +12 -9
- package/lib/components/Dialog/Dialog.js +307 -576
- package/lib/components/Dialog/index.js +21 -13
- package/lib/components/Dropdown/Dropdown.Skeleton.js +30 -43
- package/lib/components/Dropdown/Dropdown.js +348 -539
- package/lib/components/Dropdown/index.js +13 -11
- package/lib/components/ErrorBoundary/ErrorBoundary.js +39 -62
- package/lib/components/ErrorBoundary/ErrorBoundaryContext.js +15 -11
- package/lib/components/ExpandableSearch/ExpandableSearch.js +63 -73
- package/lib/components/ExpandableSearch/index.js +12 -9
- package/lib/components/FeatureFlags/index.d.ts +11 -2
- package/lib/components/FeatureFlags/index.js +82 -79
- package/lib/components/FileUploader/FileUploader.Skeleton.js +39 -35
- package/lib/components/FileUploader/FileUploader.js +273 -347
- package/lib/components/FileUploader/FileUploaderButton.js +114 -164
- package/lib/components/FileUploader/FileUploaderDropContainer.js +148 -225
- package/lib/components/FileUploader/FileUploaderItem.js +142 -161
- package/lib/components/FileUploader/Filename.d.ts +1 -1
- package/lib/components/FileUploader/Filename.js +56 -76
- package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +30 -32
- package/lib/components/FluidComboBox/FluidComboBox.js +58 -109
- package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +60 -57
- package/lib/components/FluidDatePicker/FluidDatePicker.js +50 -72
- package/lib/components/FluidDatePickerInput/FluidDatePickerInput.js +25 -20
- package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +30 -32
- package/lib/components/FluidDropdown/FluidDropdown.js +59 -115
- package/lib/components/FluidForm/FluidForm.js +33 -35
- package/lib/components/FluidForm/FormContext.js +13 -8
- package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +30 -32
- package/lib/components/FluidMultiSelect/FluidMultiSelect.js +71 -201
- package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +31 -34
- package/lib/components/FluidNumberInput/FluidNumberInput.js +67 -151
- package/lib/components/FluidSearch/FluidSearch.Skeleton.js +31 -34
- package/lib/components/FluidSearch/FluidSearch.js +45 -88
- package/lib/components/FluidSelect/FluidSelect.Skeleton.js +30 -32
- package/lib/components/FluidSelect/FluidSelect.js +44 -80
- package/lib/components/FluidSelect/index.js +13 -11
- package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +31 -34
- package/lib/components/FluidTextArea/FluidTextArea.js +52 -116
- package/lib/components/FluidTextInput/FluidPasswordInput.js +48 -103
- package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +31 -34
- package/lib/components/FluidTextInput/FluidTextInput.js +53 -108
- package/lib/components/FluidTextInput/index.js +14 -13
- package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +34 -37
- package/lib/components/FluidTimePicker/FluidTimePicker.js +72 -119
- package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +31 -51
- package/lib/components/Form/Form.js +27 -29
- package/lib/components/FormGroup/FormGroup.js +49 -71
- package/lib/components/FormItem/FormItem.js +27 -29
- package/lib/components/FormLabel/FormLabel.js +32 -38
- package/lib/components/Grid/CSSGrid.d.ts +1 -1
- package/lib/components/Grid/CSSGrid.js +89 -129
- package/lib/components/Grid/Column.js +196 -328
- package/lib/components/Grid/ColumnHang.js +32 -38
- package/lib/components/Grid/FlexGrid.js +44 -62
- package/lib/components/Grid/Grid.js +32 -44
- package/lib/components/Grid/GridContext.js +39 -44
- package/lib/components/Grid/Row.js +35 -53
- package/lib/components/Heading/index.js +39 -53
- package/lib/components/Icon/Icon.Skeleton.js +25 -23
- package/lib/components/IconButton/index.js +121 -180
- package/lib/components/IconIndicator/index.d.ts +1 -1
- package/lib/components/IconIndicator/index.js +63 -63
- package/lib/components/IdPrefix/index.js +24 -19
- package/lib/components/InlineCheckbox/InlineCheckbox.js +72 -117
- package/lib/components/InlineCheckbox/index.js +12 -9
- package/lib/components/InlineLoading/InlineLoading.js +87 -104
- package/lib/components/InlineLoading/index.js +12 -9
- package/lib/components/Layer/LayerContext.js +14 -6
- package/lib/components/Layer/LayerLevel.js +20 -6
- package/lib/components/Layer/index.js +58 -68
- package/lib/components/Layout/index.js +81 -111
- package/lib/components/LayoutDirection/LayoutDirection.d.ts +1 -1
- package/lib/components/LayoutDirection/LayoutDirection.js +36 -40
- package/lib/components/LayoutDirection/LayoutDirectionContext.js +14 -8
- package/lib/components/LayoutDirection/useLayoutDirection.js +16 -9
- package/lib/components/Link/Link.js +67 -112
- package/lib/components/Link/index.js +12 -9
- package/lib/components/ListBox/ListBox.js +82 -130
- package/lib/components/ListBox/ListBoxField.js +33 -47
- package/lib/components/ListBox/ListBoxMenu.js +39 -46
- package/lib/components/ListBox/ListBoxMenuIcon.js +43 -44
- package/lib/components/ListBox/ListBoxMenuItem.js +71 -92
- package/lib/components/ListBox/ListBoxPropTypes.js +21 -9
- package/lib/components/ListBox/ListBoxSelection.js +75 -100
- package/lib/components/ListBox/index.js +17 -21
- package/lib/components/ListBox/next/ListBoxSelection.js +83 -121
- package/lib/components/ListBox/next/ListBoxTrigger.js +48 -52
- package/lib/components/ListItem/ListItem.js +29 -32
- package/lib/components/Loading/Loading.js +68 -77
- package/lib/components/Loading/index.js +12 -9
- package/lib/components/Menu/Menu.js +224 -365
- package/lib/components/Menu/MenuContext.d.ts +1 -1
- package/lib/components/Menu/MenuContext.js +42 -40
- package/lib/components/Menu/MenuItem.js +286 -415
- package/lib/components/MenuButton/index.js +138 -197
- package/lib/components/Modal/Modal.js +504 -665
- package/lib/components/Modal/ModalPresence.js +41 -39
- package/lib/components/Modal/index.js +13 -10
- package/lib/components/ModalWrapper/ModalWrapper.d.ts +2 -2
- package/lib/components/ModalWrapper/ModalWrapper.js +112 -134
- package/lib/components/MultiSelect/FilterableMultiSelect.js +611 -920
- package/lib/components/MultiSelect/MultiSelect.js +459 -718
- package/lib/components/MultiSelect/MultiSelectPropTypes.js +15 -32
- package/lib/components/MultiSelect/filter.js +14 -10
- package/lib/components/MultiSelect/tools/sorting.js +21 -35
- package/lib/components/Notification/Notification.js +514 -787
- package/lib/components/NumberInput/NumberFormatPropTypes.js +72 -33
- package/lib/components/NumberInput/NumberInput.Skeleton.js +33 -37
- package/lib/components/NumberInput/NumberInput.js +571 -950
- package/lib/components/OrderedList/OrderedList.js +35 -48
- package/lib/components/OverflowMenu/OverflowMenu.js +341 -454
- package/lib/components/OverflowMenu/index.js +27 -21
- package/lib/components/OverflowMenu/next/index.js +158 -188
- package/lib/components/OverflowMenuItem/OverflowMenuItem.js +104 -164
- package/lib/components/OverflowMenuItem/index.js +12 -9
- package/lib/components/OverflowMenuV2/index.js +25 -15
- package/lib/components/PageHeader/PageHeader.js +301 -444
- package/lib/components/PageHeader/index.js +27 -19
- package/lib/components/Pagination/Pagination.Skeleton.js +38 -37
- package/lib/components/Pagination/Pagination.d.ts +1 -1
- package/lib/components/Pagination/Pagination.js +256 -360
- package/lib/components/Pagination/experimental/PageSelector.js +48 -58
- package/lib/components/Pagination/experimental/Pagination-story.d.ts +114 -0
- package/lib/components/Pagination/experimental/Pagination.js +148 -200
- package/lib/components/PaginationNav/PaginationNav.js +324 -430
- package/lib/components/Popover/index.js +323 -440
- package/lib/components/PrimaryButton/PrimaryButton.js +19 -13
- package/lib/components/ProgressBar/ProgressBar.js +121 -147
- package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +46 -43
- package/lib/components/ProgressIndicator/ProgressIndicator.js +150 -245
- package/lib/components/RadioButton/RadioButton.Skeleton.js +27 -27
- package/lib/components/RadioButton/RadioButton.js +105 -178
- package/lib/components/RadioButton/index.js +12 -9
- package/lib/components/RadioButtonGroup/RadioButtonGroup.js +139 -211
- package/lib/components/RadioTile/RadioTile.js +108 -172
- package/lib/components/RadioTile/index.js +12 -9
- package/lib/components/Search/Search.Skeleton.js +32 -38
- package/lib/components/Search/Search.js +185 -281
- package/lib/components/Search/index.js +13 -11
- package/lib/components/Search/utils.js +11 -4
- package/lib/components/SecondaryButton/SecondaryButton.js +19 -13
- package/lib/components/Select/Select.Skeleton.js +31 -35
- package/lib/components/Select/Select.js +182 -261
- package/lib/components/Select/index.js +13 -11
- package/lib/components/SelectItem/SelectItem.js +37 -52
- package/lib/components/SelectItem/index.js +12 -9
- package/lib/components/SelectItemGroup/SelectItemGroup.js +31 -41
- package/lib/components/ShapeIndicator/index.d.ts +1 -1
- package/lib/components/ShapeIndicator/index.js +78 -83
- package/lib/components/SkeletonIcon/SkeletonIcon.js +25 -28
- package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +25 -28
- package/lib/components/SkeletonText/SkeletonText.js +71 -85
- package/lib/components/SkeletonText/index.js +12 -9
- package/lib/components/Slider/Slider.Skeleton.js +72 -95
- package/lib/components/Slider/Slider.js +868 -1319
- package/lib/components/Slider/SliderHandles.js +75 -68
- package/lib/components/Stack/HStack.js +22 -14
- package/lib/components/Stack/Stack.js +60 -82
- package/lib/components/Stack/VStack.js +22 -14
- package/lib/components/StructuredList/StructuredList.Skeleton.js +59 -52
- package/lib/components/StructuredList/StructuredList.js +182 -319
- package/lib/components/Switch/IconSwitch.js +103 -149
- package/lib/components/Switch/Switch.js +70 -103
- package/lib/components/TabContent/TabContent.js +32 -38
- package/lib/components/Tabs/Tabs.Skeleton.js +45 -41
- package/lib/components/Tabs/Tabs.js +738 -1151
- package/lib/components/Tabs/usePressable.js +98 -114
- package/lib/components/Tag/DismissibleTag.js +123 -160
- package/lib/components/Tag/OperationalTag.js +95 -115
- package/lib/components/Tag/SelectableTag.js +98 -133
- package/lib/components/Tag/Tag.Skeleton.js +30 -32
- package/lib/components/Tag/Tag.js +156 -204
- package/lib/components/Tag/isEllipsisActive.js +13 -9
- package/lib/components/Text/Text.js +69 -81
- package/lib/components/Text/TextDirection.js +39 -39
- package/lib/components/Text/TextDirectionContext.js +15 -10
- package/lib/components/Text/createTextComponent.js +29 -22
- package/lib/components/TextArea/TextArea.Skeleton.js +29 -34
- package/lib/components/TextArea/TextArea.js +319 -426
- package/lib/components/TextArea/index.js +13 -11
- package/lib/components/TextInput/ControlledPasswordInput.js +137 -202
- package/lib/components/TextInput/PasswordInput.js +200 -307
- package/lib/components/TextInput/TextInput.Skeleton.js +28 -33
- package/lib/components/TextInput/TextInput.js +223 -321
- package/lib/components/TextInput/index.js +13 -11
- package/lib/components/TextInput/util.js +21 -26
- package/lib/components/Theme/index.js +83 -97
- package/lib/components/Tile/Tile.d.ts +2 -2
- package/lib/components/Tile/Tile.js +398 -590
- package/lib/components/TileGroup/TileGroup.js +73 -113
- package/lib/components/TimePicker/TimePicker.d.ts +1 -1
- package/lib/components/TimePicker/TimePicker.js +152 -251
- package/lib/components/TimePickerSelect/TimePickerSelect.js +47 -62
- package/lib/components/Toggle/Toggle.Skeleton.js +28 -24
- package/lib/components/Toggle/Toggle.js +106 -176
- package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +50 -53
- package/lib/components/Toggletip/index.d.ts +2 -2
- package/lib/components/Toggletip/index.js +174 -258
- package/lib/components/Tooltip/DefinitionTooltip.js +102 -140
- package/lib/components/Tooltip/Tooltip.js +192 -265
- package/lib/components/TreeView/TreeContext.js +14 -7
- package/lib/components/TreeView/TreeNode.js +365 -504
- package/lib/components/TreeView/TreeView.js +169 -242
- package/lib/components/UIShell/Content.js +27 -34
- package/lib/components/UIShell/Header.js +29 -33
- package/lib/components/UIShell/HeaderContainer.js +34 -44
- package/lib/components/UIShell/HeaderGlobalAction.js +69 -94
- package/lib/components/UIShell/HeaderGlobalBar.js +17 -14
- package/lib/components/UIShell/HeaderMenu.js +146 -221
- package/lib/components/UIShell/HeaderMenuButton.js +47 -70
- package/lib/components/UIShell/HeaderMenuItem.js +53 -80
- package/lib/components/UIShell/HeaderName.js +36 -48
- package/lib/components/UIShell/HeaderNavigation.js +36 -41
- package/lib/components/UIShell/HeaderPanel.js +78 -101
- package/lib/components/UIShell/HeaderSideNavItems.js +31 -37
- package/lib/components/UIShell/Link.js +32 -54
- package/lib/components/UIShell/SideNav.js +136 -245
- package/lib/components/UIShell/SideNavContext.js +23 -17
- package/lib/components/UIShell/SideNavDetails.js +33 -38
- package/lib/components/UIShell/SideNavDivider.js +25 -25
- package/lib/components/UIShell/SideNavFooter.js +47 -56
- package/lib/components/UIShell/SideNavHeader.js +30 -39
- package/lib/components/UIShell/SideNavIcon.js +32 -37
- package/lib/components/UIShell/SideNavItem.js +32 -37
- package/lib/components/UIShell/SideNavItems.js +35 -44
- package/lib/components/UIShell/SideNavLink.js +56 -83
- package/lib/components/UIShell/SideNavLinkText.js +28 -29
- package/lib/components/UIShell/SideNavMenu.js +106 -148
- package/lib/components/UIShell/SideNavMenuItem.js +44 -56
- package/lib/components/UIShell/SideNavSwitcher.js +63 -72
- package/lib/components/UIShell/SkipToContent.js +32 -40
- package/lib/components/UIShell/Switcher.js +73 -103
- package/lib/components/UIShell/SwitcherDivider.js +26 -28
- package/lib/components/UIShell/SwitcherItem.js +78 -118
- package/lib/components/UnorderedList/UnorderedList.js +32 -41
- package/lib/feature-flags.js +21 -13
- package/lib/index.js +622 -602
- package/lib/internal/FloatingMenu.js +249 -296
- package/lib/internal/OptimizedResize.js +35 -47
- package/lib/internal/Selection.js +102 -134
- package/lib/internal/clamp.js +12 -5
- package/lib/internal/defaultItemToString.js +15 -10
- package/lib/internal/deprecateFieldOnObject.js +23 -16
- package/lib/internal/environment.js +15 -8
- package/lib/internal/getAnnouncement.js +16 -14
- package/lib/internal/keyboard/keys.js +48 -49
- package/lib/internal/keyboard/match.js +25 -43
- package/lib/internal/keyboard/navigation.js +22 -29
- package/lib/internal/noopFn.js +10 -3
- package/lib/internal/useAttachedMenu.js +44 -53
- package/lib/internal/useControllableState.js +44 -50
- package/lib/internal/useDelayedState.js +31 -37
- package/lib/internal/useEvent.js +40 -37
- package/lib/internal/useId.js +54 -91
- package/lib/internal/useIdPrefix.js +15 -7
- package/lib/internal/useIsomorphicEffect.js +13 -8
- package/lib/internal/useMatchMedia.js +30 -23
- package/lib/internal/useMergedRefs.js +27 -24
- package/lib/internal/useNoInteractiveChildren.js +73 -101
- package/lib/internal/useNormalizedInputProps.js +55 -53
- package/lib/internal/useOutsideClick.js +22 -26
- package/lib/internal/useOverflowItems.js +90 -94
- package/lib/internal/usePrefix.js +15 -7
- package/lib/internal/usePresence.js +52 -56
- package/lib/internal/usePresenceContext.js +36 -37
- package/lib/internal/usePreviousValue.js +27 -20
- package/lib/internal/useResizeObserver.js +58 -68
- package/lib/internal/useSavedCallback.js +25 -19
- package/lib/internal/utils.js +18 -11
- package/lib/internal/warning.js +24 -23
- package/lib/internal/wrapFocus.js +78 -100
- package/lib/prop-types/AriaPropTypes.js +17 -9
- package/lib/prop-types/deprecate.js +30 -29
- package/lib/prop-types/deprecateComponent.js +17 -10
- package/lib/prop-types/deprecateValuesWithin.js +18 -23
- package/lib/prop-types/isRequiredOneOf.js +21 -25
- package/lib/prop-types/requiredIfGivenPropIsTruthy.js +14 -15
- package/lib/tools/events.js +17 -22
- package/lib/tools/mapPopoverAlign.js +19 -19
- package/lib/tools/mergeRefs.js +14 -18
- package/lib/tools/setupGetInstanceId.js +16 -9
- package/lib/tools/toggleClass.js +17 -10
- package/lib/tools/wrapComponent.js +38 -43
- package/package.json +10 -16
- package/es/_virtual/_rollupPluginBabelHelpers.js +0 -40
- package/es/components/DataTable/stories/examples/TableToolbarFilter.d.ts +0 -54
- package/es/node_modules/es-toolkit/dist/compat/function/debounce.js +0 -55
- package/es/node_modules/es-toolkit/dist/compat/function/throttle.js +0 -23
- package/es/node_modules/es-toolkit/dist/function/debounce.js +0 -70
- package/lib/_virtual/_rollupPluginBabelHelpers.js +0 -45
- package/lib/components/DataTable/stories/examples/TableToolbarFilter.d.ts +0 -54
- package/lib/node_modules/es-toolkit/dist/compat/function/debounce.js +0 -57
- package/lib/node_modules/es-toolkit/dist/compat/function/throttle.js +0 -25
- package/lib/node_modules/es-toolkit/dist/function/debounce.js +0 -72
package/lib/internal/useEvent.js
CHANGED
|
@@ -1,50 +1,53 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
var React = require('react');
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
11
10
|
|
|
11
|
+
//#region src/internal/useEvent.ts
|
|
12
|
+
/**
|
|
13
|
+
* Copyright IBM Corp. 2016, 2025
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*/
|
|
12
18
|
const useEvent = (elementOrRef, eventName, callback) => {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
};
|
|
29
|
-
}, [elementOrRef, eventName]);
|
|
19
|
+
const savedCallback = (0, react.useRef)(null);
|
|
20
|
+
(0, react.useEffect)(() => {
|
|
21
|
+
savedCallback.current = callback;
|
|
22
|
+
}, [callback]);
|
|
23
|
+
(0, react.useEffect)(() => {
|
|
24
|
+
const element = "current" in elementOrRef ? elementOrRef.current : elementOrRef;
|
|
25
|
+
if (!element) return;
|
|
26
|
+
const handler = (event) => {
|
|
27
|
+
if (savedCallback.current) savedCallback.current(event);
|
|
28
|
+
};
|
|
29
|
+
element.addEventListener(eventName, handler);
|
|
30
|
+
return () => {
|
|
31
|
+
element.removeEventListener(eventName, handler);
|
|
32
|
+
};
|
|
33
|
+
}, [elementOrRef, eventName]);
|
|
30
34
|
};
|
|
31
35
|
const useWindowEvent = (eventName, callback) => {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
};
|
|
46
|
-
}, [eventName]);
|
|
36
|
+
const savedCallback = (0, react.useRef)(null);
|
|
37
|
+
(0, react.useEffect)(() => {
|
|
38
|
+
savedCallback.current = callback;
|
|
39
|
+
}, [callback]);
|
|
40
|
+
(0, react.useEffect)(() => {
|
|
41
|
+
const handler = (event) => {
|
|
42
|
+
if (savedCallback.current) savedCallback.current(event);
|
|
43
|
+
};
|
|
44
|
+
window.addEventListener(eventName, handler);
|
|
45
|
+
return () => {
|
|
46
|
+
window.removeEventListener(eventName, handler);
|
|
47
|
+
};
|
|
48
|
+
}, [eventName]);
|
|
47
49
|
};
|
|
48
50
|
|
|
51
|
+
//#endregion
|
|
49
52
|
exports.useEvent = useEvent;
|
|
50
|
-
exports.useWindowEvent = useWindowEvent;
|
|
53
|
+
exports.useWindowEvent = useWindowEvent;
|
package/lib/internal/useId.js
CHANGED
|
@@ -1,112 +1,75 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
const require_setupGetInstanceId = require('../tools/setupGetInstanceId.js');
|
|
10
|
+
const require_useIsomorphicEffect = require('./useIsomorphicEffect.js');
|
|
11
|
+
const require_useIdPrefix = require('./useIdPrefix.js');
|
|
12
|
+
let react = require("react");
|
|
13
|
+
react = require_runtime.__toESM(react);
|
|
9
14
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
//
|
|
20
|
-
// 2. Floating UI and their work on react >=18 compatibility
|
|
21
|
-
// https://github.com/floating-ui/floating-ui/blob/%40floating-ui/utils%400.2.5/packages/react/src/hooks/useId.ts
|
|
22
|
-
//
|
|
23
|
-
// The problem that this solves is an id mismatch when auto-generating
|
|
24
|
-
// ids on both the server and the client. When using server-side rendering,
|
|
25
|
-
// there can be the chance of a mismatch between what the server renders and
|
|
26
|
-
// what the client renders when the id value is auto-generated.
|
|
27
|
-
//
|
|
28
|
-
// To get around this, we set the initial value of the `id` to `null` and then
|
|
29
|
-
// conditionally use `useLayoutEffect` on the client and `useEffect` on the
|
|
30
|
-
// server. On the client, `useLayoutEffect` will patch up the id to the correct
|
|
31
|
-
// value. On the server, `useEffect` will not run.
|
|
32
|
-
//
|
|
33
|
-
// This ensures that we won't encounter a mismatch in ids between server and
|
|
34
|
-
// client, at the cost of runtime patching of the id value in
|
|
35
|
-
// `useLayoutEffect`
|
|
36
|
-
//
|
|
37
|
-
// React 18 introduced a new hook called `useId` that takes care of hydration
|
|
38
|
-
// mismatches. If the user is running React 18 or higher, the native hook is
|
|
39
|
-
// used via the `useReactId` function. If the user is running React 17 or
|
|
40
|
-
// lower, `useCompatibleId` is used.
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
// This tricks bundlers so they can't statically analyze this and produce
|
|
44
|
-
// compilation warnings/errors.
|
|
45
|
-
// https://github.com/webpack/webpack/issues/14814
|
|
46
|
-
// https://github.com/mui/material-ui/issues/41190
|
|
47
|
-
const _React = {
|
|
48
|
-
...React
|
|
49
|
-
};
|
|
50
|
-
const instanceId = setupGetInstanceId.setupGetInstanceId();
|
|
15
|
+
//#region src/internal/useId.js
|
|
16
|
+
/**
|
|
17
|
+
* Copyright IBM Corp. 2016, 2026
|
|
18
|
+
*
|
|
19
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
20
|
+
* LICENSE file in the root directory of this source tree.
|
|
21
|
+
*/
|
|
22
|
+
const _React = { ...react.default };
|
|
23
|
+
const instanceId = require_setupGetInstanceId.setupGetInstanceId();
|
|
51
24
|
let serverHandoffCompleted = false;
|
|
52
|
-
const defaultId =
|
|
53
|
-
|
|
25
|
+
const defaultId = "id";
|
|
54
26
|
/**
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
27
|
+
* Generate a unique ID for React <=17 with an optional prefix prepended to it.
|
|
28
|
+
* This is an internal utility, not intended for public usage.
|
|
29
|
+
* @param {string} [prefix]
|
|
30
|
+
* @returns {string}
|
|
31
|
+
*/
|
|
60
32
|
function useCompatibleId(prefix = defaultId) {
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
React.useEffect(() => {
|
|
74
|
-
if (serverHandoffCompleted === false) {
|
|
75
|
-
serverHandoffCompleted = true;
|
|
76
|
-
}
|
|
77
|
-
}, []);
|
|
78
|
-
return id;
|
|
33
|
+
const contextPrefix = require_useIdPrefix.useIdPrefix();
|
|
34
|
+
const [id, setId] = (0, react.useState)(() => {
|
|
35
|
+
if (serverHandoffCompleted) return `${contextPrefix ? `${contextPrefix}-` : ``}${prefix}-${instanceId()}`;
|
|
36
|
+
return null;
|
|
37
|
+
});
|
|
38
|
+
require_useIsomorphicEffect.default(() => {
|
|
39
|
+
if (id === null) setId(`${contextPrefix ? `${contextPrefix}-` : ``}${prefix}-${instanceId()}`);
|
|
40
|
+
}, [instanceId]);
|
|
41
|
+
(0, react.useEffect)(() => {
|
|
42
|
+
if (serverHandoffCompleted === false) serverHandoffCompleted = true;
|
|
43
|
+
}, []);
|
|
44
|
+
return id;
|
|
79
45
|
}
|
|
80
|
-
|
|
81
46
|
/**
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
47
|
+
* Generate a unique ID for React >=18 with an optional prefix prepended to it.
|
|
48
|
+
* This is an internal utility, not intended for public usage.
|
|
49
|
+
* @param {string} [prefix]
|
|
50
|
+
* @returns {string}
|
|
51
|
+
*/
|
|
87
52
|
function useReactId(prefix = defaultId) {
|
|
88
|
-
|
|
89
|
-
|
|
53
|
+
const contextPrefix = require_useIdPrefix.useIdPrefix();
|
|
54
|
+
return `${contextPrefix ? `${contextPrefix}-` : ``}${prefix}-${_React.useId()}`;
|
|
90
55
|
}
|
|
91
|
-
|
|
92
56
|
/**
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
57
|
+
* Uses React 18's built-in `useId()` when available, or falls back to a
|
|
58
|
+
* slightly less performant (requiring a double render) implementation for
|
|
59
|
+
* earlier React versions.
|
|
60
|
+
*/
|
|
97
61
|
const useId = _React.useId ? useReactId : useCompatibleId;
|
|
98
|
-
|
|
99
62
|
/**
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
63
|
+
* Generate a unique id if a given `id` is not provided
|
|
64
|
+
* This is an internal utility, not intended for public usage.
|
|
65
|
+
* @param {string|undefined} id
|
|
66
|
+
* @returns {string}
|
|
67
|
+
*/
|
|
105
68
|
function useFallbackId(id) {
|
|
106
|
-
|
|
107
|
-
|
|
69
|
+
const fallback = useId();
|
|
70
|
+
return id ?? fallback;
|
|
108
71
|
}
|
|
109
72
|
|
|
110
|
-
|
|
73
|
+
//#endregion
|
|
111
74
|
exports.useFallbackId = useFallbackId;
|
|
112
|
-
exports.useId = useId;
|
|
75
|
+
exports.useId = useId;
|
|
@@ -1,18 +1,26 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
10
|
+
react = require_runtime.__toESM(react);
|
|
9
11
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
12
|
+
//#region src/internal/useIdPrefix.ts
|
|
13
|
+
/**
|
|
14
|
+
* Copyright IBM Corp. 2016, 2023
|
|
15
|
+
*
|
|
16
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
17
|
+
* LICENSE file in the root directory of this source tree.
|
|
18
|
+
*/
|
|
19
|
+
const IdPrefixContext = react.default.createContext(null);
|
|
13
20
|
function useIdPrefix() {
|
|
14
|
-
|
|
21
|
+
return react.default.useContext(IdPrefixContext);
|
|
15
22
|
}
|
|
16
23
|
|
|
24
|
+
//#endregion
|
|
17
25
|
exports.IdPrefixContext = IdPrefixContext;
|
|
18
|
-
exports.useIdPrefix = useIdPrefix;
|
|
26
|
+
exports.useIdPrefix = useIdPrefix;
|
|
@@ -1,17 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
Object.defineProperty(exports, '__esModule', { value: true });
|
|
11
|
-
|
|
12
|
-
var React = require('react');
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
13
10
|
|
|
11
|
+
//#region src/internal/useIsomorphicEffect.ts
|
|
12
|
+
/**
|
|
13
|
+
* Copyright IBM Corp. 2021, 2025
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*/
|
|
14
18
|
/** `useLayoutEffect` on the client, `useEffect` on the server */
|
|
15
|
-
const useIsomorphicEffect = typeof window !==
|
|
19
|
+
const useIsomorphicEffect = typeof window !== "undefined" ? react.useLayoutEffect : react.useEffect;
|
|
16
20
|
|
|
17
|
-
|
|
21
|
+
//#endregion
|
|
22
|
+
exports.default = useIsomorphicEffect;
|
|
@@ -1,34 +1,41 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
var React = require('react');
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
11
10
|
|
|
11
|
+
//#region src/internal/useMatchMedia.ts
|
|
12
12
|
/**
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
13
|
+
* Copyright IBM Corp. 2016, 2025
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*/
|
|
18
|
+
/**
|
|
19
|
+
* Listens to changes in a media query and returns whether it matches.
|
|
20
|
+
* @param mediaQuery - The media query to listen to. For example, `(min-width: 600px)`.
|
|
21
|
+
* @param defaultState - The initial state to return before the media query is evaluated. Defaults to `false`.
|
|
22
|
+
* @returns Whether the media query matches.
|
|
23
|
+
*/
|
|
18
24
|
const useMatchMedia = (mediaQuery, defaultState = false) => {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
25
|
+
const [matches, setMatches] = (0, react.useState)(defaultState);
|
|
26
|
+
(0, react.useEffect)(() => {
|
|
27
|
+
const listener = (event) => {
|
|
28
|
+
setMatches(event.matches);
|
|
29
|
+
};
|
|
30
|
+
const mediaQueryList = window.matchMedia(mediaQuery);
|
|
31
|
+
mediaQueryList.addEventListener("change", listener);
|
|
32
|
+
setMatches(mediaQueryList.matches);
|
|
33
|
+
return () => {
|
|
34
|
+
mediaQueryList.removeEventListener("change", listener);
|
|
35
|
+
};
|
|
36
|
+
}, [mediaQuery]);
|
|
37
|
+
return matches;
|
|
32
38
|
};
|
|
33
39
|
|
|
34
|
-
|
|
40
|
+
//#endregion
|
|
41
|
+
exports.useMatchMedia = useMatchMedia;
|
|
@@ -1,34 +1,37 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
var React = require('react');
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
11
10
|
|
|
11
|
+
//#region src/internal/useMergedRefs.ts
|
|
12
12
|
/**
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
13
|
+
* Copyright IBM Corp. 2016, 2025
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*/
|
|
18
|
+
/**
|
|
19
|
+
* Merges multiple refs into a single callback ref.
|
|
20
|
+
*
|
|
21
|
+
* This hook is useful when you need to attach multiple refs (for example, a ref
|
|
22
|
+
* passed from `forwardRef` and a local ref from `useRef`) to the same node. It
|
|
23
|
+
* accepts an array of refs and returns a callback ref that, when attached to a
|
|
24
|
+
* node, assigns that node to every ref in the array.
|
|
25
|
+
*/
|
|
26
|
+
const useMergedRefs = (refs) => {
|
|
27
|
+
const memoizedRefs = (0, react.useMemo)(() => refs, refs);
|
|
28
|
+
return (0, react.useCallback)((node) => {
|
|
29
|
+
memoizedRefs.forEach((ref) => {
|
|
30
|
+
if (typeof ref === "function") ref(node);
|
|
31
|
+
else if (ref) ref.current = node;
|
|
32
|
+
});
|
|
33
|
+
}, [memoizedRefs]);
|
|
32
34
|
};
|
|
33
35
|
|
|
34
|
-
|
|
36
|
+
//#endregion
|
|
37
|
+
exports.useMergedRefs = useMergedRefs;
|
|
@@ -1,121 +1,93 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* Copyright IBM Corp. 2016,
|
|
2
|
+
* Copyright IBM Corp. 2016, 2026
|
|
3
3
|
*
|
|
4
4
|
* This source code is licensed under the Apache-2.0 license found in the
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
|
|
8
|
+
const require_runtime = require('../_virtual/_rolldown/runtime.js');
|
|
9
|
+
let react = require("react");
|
|
9
10
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
11
|
+
//#region src/internal/useNoInteractiveChildren.ts
|
|
12
|
+
/**
|
|
13
|
+
* Copyright IBM Corp. 2016, 2026
|
|
14
|
+
*
|
|
15
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
|
16
|
+
* LICENSE file in the root directory of this source tree.
|
|
17
|
+
*/
|
|
18
|
+
const useNoInteractiveChildren = (ref, message = "component should have no interactive child nodes") => {
|
|
19
|
+
(0, react.useEffect)(() => {
|
|
20
|
+
if (process.env.NODE_ENV === "production") return;
|
|
21
|
+
const { current } = ref;
|
|
22
|
+
const node = current ? getInteractiveContent(current) : null;
|
|
23
|
+
if (node) {
|
|
24
|
+
const errorMessage = `Error: ${message}.\n\nInstead found: ${node.outerHTML}`;
|
|
25
|
+
console.error(errorMessage);
|
|
26
|
+
throw new Error(errorMessage);
|
|
27
|
+
}
|
|
28
|
+
}, [message, ref]);
|
|
26
29
|
};
|
|
27
30
|
const useInteractiveChildrenNeedDescription = (ref, message = `interactive child node(s) should have an \`aria-describedby\` property`) => {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
if (node && !node.hasAttribute('aria-describedby')) {
|
|
35
|
-
throw new Error(`Error: ${message}.\n\nInstead found: ${node.outerHTML}`);
|
|
36
|
-
}
|
|
37
|
-
}, [message, ref]);
|
|
31
|
+
(0, react.useEffect)(() => {
|
|
32
|
+
if (process.env.NODE_ENV === "production") return;
|
|
33
|
+
const { current } = ref;
|
|
34
|
+
const node = current ? getInteractiveContent(current) : null;
|
|
35
|
+
if (node && !node.hasAttribute("aria-describedby")) throw new Error(`Error: ${message}.\n\nInstead found: ${node.outerHTML}`);
|
|
36
|
+
}, [message, ref]);
|
|
38
37
|
};
|
|
39
|
-
|
|
40
38
|
/**
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
const getInteractiveContent = node => {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
for (const childNode of node.childNodes) {
|
|
56
|
-
if (childNode instanceof HTMLElement) {
|
|
57
|
-
const interactiveNode = getInteractiveContent(childNode);
|
|
58
|
-
if (interactiveNode) {
|
|
59
|
-
return interactiveNode;
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
return null;
|
|
39
|
+
* Determines if a given DOM node has interactive content, or is itself
|
|
40
|
+
* interactive. It returns the interactive node if one is found.
|
|
41
|
+
*
|
|
42
|
+
* @param node - The node to check.
|
|
43
|
+
* @returns The interactive node, or `null` if none is found.
|
|
44
|
+
*/
|
|
45
|
+
const getInteractiveContent = (node) => {
|
|
46
|
+
if (!node || !node.childNodes) return null;
|
|
47
|
+
if (isFocusable(node)) return node;
|
|
48
|
+
for (const childNode of node.childNodes) if (childNode instanceof HTMLElement) {
|
|
49
|
+
const interactiveNode = getInteractiveContent(childNode);
|
|
50
|
+
if (interactiveNode) return interactiveNode;
|
|
51
|
+
}
|
|
52
|
+
return null;
|
|
64
53
|
};
|
|
65
|
-
|
|
66
54
|
/**
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
const getRoleContent = node => {
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
for (const childNode of node.childNodes) {
|
|
82
|
-
if (childNode instanceof HTMLElement) {
|
|
83
|
-
const roleNode = getRoleContent(childNode);
|
|
84
|
-
if (roleNode) {
|
|
85
|
-
return roleNode;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
return null;
|
|
55
|
+
* Determines if a given DOM node has a `role`, or has itself a `role`.
|
|
56
|
+
* It returns the node with a `role` if one is found.
|
|
57
|
+
*
|
|
58
|
+
* @param node - The node to check.
|
|
59
|
+
* @returns The node with a `role`, or `null` if none is found.
|
|
60
|
+
*/
|
|
61
|
+
const getRoleContent = (node) => {
|
|
62
|
+
if (!node || !node.childNodes) return null;
|
|
63
|
+
if (node.getAttribute("role") && node.getAttribute("role") !== "") return node;
|
|
64
|
+
for (const childNode of node.childNodes) if (childNode instanceof HTMLElement) {
|
|
65
|
+
const roleNode = getRoleContent(childNode);
|
|
66
|
+
if (roleNode) return roleNode;
|
|
67
|
+
}
|
|
68
|
+
return null;
|
|
90
69
|
};
|
|
91
|
-
|
|
92
70
|
/**
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
const isFocusable = element => {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
case 'A':
|
|
110
|
-
return element instanceof HTMLAnchorElement && !!element.href && element.rel !== 'ignore';
|
|
111
|
-
case 'INPUT':
|
|
112
|
-
return element instanceof HTMLInputElement && element.type !== 'hidden';
|
|
113
|
-
default:
|
|
114
|
-
return true;
|
|
115
|
-
}
|
|
71
|
+
* Determines if the given element is focusable.
|
|
72
|
+
*
|
|
73
|
+
* @param element - The element to check.
|
|
74
|
+
* @returns Whether the element is focusable.
|
|
75
|
+
* @see https://github.com/w3c/aria-practices/blob/0553bb51588ffa517506e2a1b2ca1422ed438c5f/examples/js/utils.js#L68
|
|
76
|
+
*/
|
|
77
|
+
const isFocusable = (element) => {
|
|
78
|
+
if (element.tabIndex === void 0 || element.tabIndex < 0) return false;
|
|
79
|
+
if (element instanceof HTMLButtonElement || element instanceof HTMLInputElement || element instanceof HTMLSelectElement || element instanceof HTMLTextAreaElement) {
|
|
80
|
+
if (element.disabled) return false;
|
|
81
|
+
}
|
|
82
|
+
switch (element.nodeName) {
|
|
83
|
+
case "A": return element instanceof HTMLAnchorElement && !!element.href && element.rel !== "ignore";
|
|
84
|
+
case "INPUT": return element instanceof HTMLInputElement && element.type !== "hidden";
|
|
85
|
+
default: return true;
|
|
86
|
+
}
|
|
116
87
|
};
|
|
117
88
|
|
|
89
|
+
//#endregion
|
|
118
90
|
exports.getInteractiveContent = getInteractiveContent;
|
|
119
91
|
exports.getRoleContent = getRoleContent;
|
|
120
92
|
exports.useInteractiveChildrenNeedDescription = useInteractiveChildrenNeedDescription;
|
|
121
|
-
exports.useNoInteractiveChildren = useNoInteractiveChildren;
|
|
93
|
+
exports.useNoInteractiveChildren = useNoInteractiveChildren;
|