@carbon/react 1.110.0 → 1.111.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 +927 -927
- package/es/components/AILabel/index.js +48 -1
- package/es/components/AISkeleton/AISkeletonIcon.js +7 -1
- package/es/components/AISkeleton/AISkeletonPlaceholder.js +7 -2
- package/es/components/AISkeleton/AISkeletonText.js +16 -1
- package/es/components/Accordion/Accordion.Skeleton.js +16 -1
- package/es/components/Accordion/Accordion.js +23 -1
- package/es/components/Accordion/AccordionItem.js +34 -1
- package/es/components/AspectRatio/AspectRatio.js +20 -1
- package/es/components/BadgeIndicator/index.js +10 -1
- package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +13 -1
- package/es/components/Breadcrumb/Breadcrumb.js +17 -1
- package/es/components/Breadcrumb/BreadcrumbItem.js +13 -1
- package/es/components/Button/Button.Skeleton.js +18 -1
- package/es/components/Button/Button.js +96 -0
- package/es/components/Button/ButtonBase.js +1 -1
- package/es/components/ButtonSet/ButtonSet.js +15 -1
- package/es/components/ChatButton/ChatButton.Skeleton.js +7 -1
- package/es/components/ChatButton/ChatButton.js +25 -1
- package/es/components/Checkbox/Checkbox.Skeleton.js +6 -2
- package/es/components/Checkbox/Checkbox.js +59 -2
- package/es/components/CheckboxGroup/CheckboxGroup.js +41 -1
- package/es/components/ClassPrefix/index.js +3 -0
- package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +7 -1
- package/es/components/CodeSnippet/CodeSnippet.js +77 -1
- package/es/components/ComboBox/ComboBox.js +141 -1
- package/es/components/ComboButton/index.js +28 -1
- package/es/components/ComposedModal/ComposedModal.js +70 -2
- package/es/components/ComposedModal/ModalFooter.js +65 -2
- package/es/components/ComposedModal/ModalHeader.js +36 -1
- package/es/components/ContainedList/ContainedList.js +22 -1
- package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +19 -1
- package/es/components/ContentSwitcher/ContentSwitcher.js +26 -1
- package/es/components/Copy/Copy.js +31 -2
- package/es/components/CopyButton/CopyButton.js +28 -2
- package/es/components/DataTable/DataTable.js +59 -0
- package/es/components/DataTable/Table.js +28 -1
- package/es/components/DataTable/TableBatchAction.js +10 -0
- package/es/components/DataTable/TableBatchActions.js +25 -1
- package/es/components/DataTable/TableBody.js +3 -0
- package/es/components/DataTable/TableCell.js +16 -1
- package/es/components/DataTable/TableContainer.js +19 -1
- package/es/components/DataTable/TableDecoratorRow.js +7 -1
- package/es/components/DataTable/TableExpandHeader.js +32 -1
- package/es/components/DataTable/TableExpandRow.js +30 -1
- package/es/components/DataTable/TableExpandedRow.js +10 -1
- package/es/components/DataTable/TableHeader.js +36 -1
- package/es/components/DataTable/TableRow.js +22 -1
- package/es/components/DataTable/TableSelectAll.js +29 -1
- package/es/components/DataTable/TableSelectRow.js +32 -1
- package/es/components/DataTable/TableSlugRow.js +7 -1
- package/es/components/DataTable/TableToolbar.js +16 -1
- package/es/components/DataTable/TableToolbarMenu.js +16 -1
- package/es/components/DataTable/TableToolbarSearch.js +60 -2
- package/es/components/DataTableSkeleton/DataTableSkeleton.js +25 -1
- package/es/components/DatePicker/DatePicker.Skeleton.js +13 -1
- package/es/components/DatePicker/DatePicker.js +89 -1
- package/es/components/DatePickerInput/DatePickerInput.js +81 -2
- package/es/components/Dialog/Dialog.js +132 -5
- package/es/components/Dropdown/Dropdown.Skeleton.js +10 -1
- package/es/components/Dropdown/Dropdown.js +110 -1
- package/es/components/ExpandableSearch/ExpandableSearch.js +1 -1
- package/es/components/FeatureFlags/index.js +3 -0
- package/es/components/FileUploader/FileUploader.Skeleton.js +6 -2
- package/es/components/FileUploader/FileUploader.js +58 -1
- package/es/components/FileUploader/FileUploaderButton.js +49 -2
- package/es/components/FileUploader/FileUploaderDropContainer.js +44 -2
- package/es/components/FileUploader/FileUploaderItem.js +31 -2
- package/es/components/FileUploader/Filename.js +18 -0
- package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +6 -2
- package/es/components/FluidComboBox/FluidComboBox.js +62 -1
- package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +7 -1
- package/es/components/FluidDatePicker/FluidDatePicker.js +22 -1
- package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +6 -2
- package/es/components/FluidDropdown/FluidDropdown.js +66 -1
- package/es/components/FluidForm/FluidForm.js +7 -1
- package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +6 -2
- package/es/components/FluidMultiSelect/FluidMultiSelect.js +129 -1
- package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +6 -2
- package/es/components/FluidNumberInput/FluidNumberInput.js +96 -1
- package/es/components/FluidSearch/FluidSearch.Skeleton.js +6 -2
- package/es/components/FluidSearch/FluidSearch.js +46 -1
- package/es/components/FluidSelect/FluidSelect.Skeleton.js +6 -2
- package/es/components/FluidSelect/FluidSelect.js +39 -1
- package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +6 -2
- package/es/components/FluidTextArea/FluidTextArea.js +68 -1
- package/es/components/FluidTextInput/FluidPasswordInput.js +59 -1
- package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +6 -2
- package/es/components/FluidTextInput/FluidTextInput.js +55 -1
- package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +7 -1
- package/es/components/FluidTimePicker/FluidTimePicker.js +29 -1
- package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +26 -0
- package/es/components/Form/Form.js +7 -1
- package/es/components/FormGroup/FormGroup.js +26 -1
- package/es/components/FormItem/FormItem.js +7 -1
- package/es/components/FormLabel/FormLabel.js +10 -1
- package/es/components/Grid/CSSGrid.js +44 -1
- package/es/components/Grid/Column.js +87 -1
- package/es/components/Grid/ColumnHang.js +10 -1
- package/es/components/Grid/FlexGrid.js +25 -1
- package/es/components/Grid/Grid.js +27 -0
- package/es/components/Grid/GridContext.js +10 -0
- package/es/components/Grid/Row.js +18 -1
- package/es/components/Heading/index.js +19 -0
- package/es/components/Icon/Icon.Skeleton.js +6 -2
- package/es/components/IconButton/index.js +69 -1
- package/es/components/IconIndicator/index.js +13 -1
- package/es/components/IdPrefix/index.js +3 -0
- package/es/components/InlineCheckbox/InlineCheckbox.js +34 -0
- package/es/components/InlineLoading/InlineLoading.js +20 -1
- package/es/components/Layer/index.js +18 -1
- package/es/components/Layout/index.js +35 -1
- package/es/components/LayoutDirection/LayoutDirection.js +10 -0
- package/es/components/Link/Link.d.ts +1 -1
- package/es/components/Link/Link.js +29 -1
- package/es/components/ListBox/ListBox.js +42 -1
- package/es/components/ListBox/ListBoxField.js +17 -0
- package/es/components/ListBox/ListBoxMenu.js +6 -0
- package/es/components/ListBox/ListBoxMenuIcon.js +8 -1
- package/es/components/ListBox/ListBoxMenuItem.js +17 -1
- package/es/components/ListBox/ListBoxSelection.d.ts +1 -1
- package/es/components/ListBox/ListBoxSelection.js +33 -10
- package/es/components/ListBox/next/ListBoxSelection.d.ts +1 -1
- package/es/components/ListBox/next/ListBoxSelection.js +42 -7
- package/es/components/ListBox/next/ListBoxTrigger.js +8 -1
- package/es/components/ListItem/ListItem.js +7 -1
- package/es/components/Loading/Loading.js +19 -1
- package/es/components/Menu/Menu.js +53 -1
- package/es/components/Menu/MenuItem.js +78 -2
- package/es/components/MenuButton/index.js +34 -1
- package/es/components/Modal/Modal.js +118 -4
- package/es/components/ModalWrapper/ModalWrapper.js +2 -2
- package/es/components/MultiSelect/FilterableMultiSelect.js +129 -1
- package/es/components/MultiSelect/MultiSelect.js +151 -3
- package/es/components/MultiSelect/MultiSelectPropTypes.js +25 -0
- package/es/components/Notification/Notification.js +210 -3
- package/es/components/NumberInput/NumberInput.Skeleton.js +10 -1
- package/es/components/NumberInput/NumberInput.js +139 -1
- package/es/components/OrderedList/OrderedList.js +16 -1
- package/es/components/OverflowMenu/OverflowMenu.js +78 -2
- package/es/components/OverflowMenu/next/index.js +31 -1
- package/es/components/OverflowMenuItem/OverflowMenuItem.js +38 -2
- package/es/components/PageHeader/PageHeader.js +49 -1
- package/es/components/Pagination/Pagination.Skeleton.js +6 -2
- package/es/components/Pagination/Pagination.d.ts +8 -0
- package/es/components/Pagination/Pagination.js +86 -4
- package/es/components/Pagination/experimental/PageSelector.js +9 -1
- package/es/components/Pagination/experimental/Pagination.js +55 -1
- package/es/components/PaginationNav/PaginationNav.js +81 -1
- package/es/components/Popover/index.js +59 -1
- package/es/components/ProgressBar/ProgressBar.js +28 -1
- package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +7 -1
- package/es/components/ProgressIndicator/ProgressIndicator.js +59 -1
- package/es/components/RadioButton/RadioButton.Skeleton.js +6 -2
- package/es/components/RadioButton/RadioButton.js +64 -1
- package/es/components/RadioButtonGroup/RadioButtonGroup.js +60 -1
- package/es/components/RadioTile/RadioTile.js +47 -2
- package/es/components/Search/Search.Skeleton.js +10 -1
- package/es/components/Search/Search.js +68 -3
- package/es/components/Select/Select.Skeleton.js +7 -1
- package/es/components/Select/Select.js +83 -20
- package/es/components/SelectItem/SelectItem.js +16 -1
- package/es/components/SelectItemGroup/SelectItemGroup.js +13 -1
- package/es/components/ShapeIndicator/index.js +13 -1
- package/es/components/SkeletonIcon/SkeletonIcon.js +6 -2
- package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +6 -2
- package/es/components/SkeletonText/SkeletonText.js +16 -1
- package/es/components/Slider/Slider.Skeleton.js +16 -1
- package/es/components/Slider/Slider.js +105 -1
- package/es/components/Stack/Stack.js +21 -1
- package/es/components/StructuredList/StructuredList.Skeleton.js +7 -1
- package/es/components/StructuredList/StructuredList.js +98 -1
- package/es/components/Switch/IconSwitch.js +49 -2
- package/es/components/Switch/Switch.js +32 -2
- package/es/components/TabContent/TabContent.js +10 -1
- package/es/components/Tabs/Tabs.Skeleton.js +7 -1
- package/es/components/Tabs/Tabs.js +175 -2
- package/es/components/Tag/DismissibleTag.js +44 -1
- package/es/components/Tag/OperationalTag.js +23 -1
- package/es/components/Tag/SelectableTag.js +32 -1
- package/es/components/Tag/Tag.Skeleton.js +8 -1
- package/es/components/Tag/Tag.js +42 -1
- package/es/components/Text/Text.js +10 -0
- package/es/components/Text/TextDirection.js +11 -0
- package/es/components/TextArea/TextArea.Skeleton.js +7 -1
- package/es/components/TextArea/TextArea.js +82 -2
- package/es/components/TextInput/ControlledPasswordInput.js +66 -2
- package/es/components/TextInput/PasswordInput.js +84 -1
- package/es/components/TextInput/TextInput.Skeleton.js +10 -1
- package/es/components/TextInput/TextInput.js +77 -1
- package/es/components/Theme/index.js +22 -1
- package/es/components/Tile/Tile.js +158 -3
- package/es/components/TileGroup/TileGroup.js +29 -1
- package/es/components/TimePicker/TimePicker.js +68 -1
- package/es/components/TimePickerSelect/TimePickerSelect.js +16 -1
- package/es/components/Toggle/Toggle.Skeleton.js +1 -1
- package/es/components/Toggle/Toggle.js +47 -1
- package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +12 -1
- package/es/components/Toggletip/index.js +39 -1
- package/es/components/Tooltip/DefinitionTooltip.js +37 -1
- package/es/components/Tooltip/Tooltip.js +47 -1
- package/es/components/TreeView/TreeNode.js +65 -1
- package/es/components/TreeView/TreeView.js +33 -1
- package/es/components/UIShell/Content.js +10 -1
- package/es/components/UIShell/Header.js +10 -1
- package/es/components/UIShell/HeaderContainer.js +9 -0
- package/es/components/UIShell/HeaderGlobalAction.js +29 -1
- package/es/components/UIShell/HeaderMenu.js +38 -1
- package/es/components/UIShell/HeaderMenuButton.js +18 -1
- package/es/components/UIShell/HeaderMenuItem.js +26 -1
- package/es/components/UIShell/HeaderName.js +19 -1
- package/es/components/UIShell/HeaderNavigation.js +11 -1
- package/es/components/UIShell/HeaderPanel.js +21 -2
- package/es/components/UIShell/HeaderSideNavItems.js +12 -1
- package/es/components/UIShell/Link.js +14 -0
- package/es/components/UIShell/SideNav.js +54 -1
- package/es/components/UIShell/SideNavDetails.js +11 -1
- package/es/components/UIShell/SideNavDivider.js +6 -2
- package/es/components/UIShell/SideNavFooter.js +12 -1
- package/es/components/UIShell/SideNavHeader.js +14 -1
- package/es/components/UIShell/SideNavIcon.js +11 -1
- package/es/components/UIShell/SideNavItem.js +11 -1
- package/es/components/UIShell/SideNavItems.js +12 -1
- package/es/components/UIShell/SideNavLink.js +23 -1
- package/es/components/UIShell/SideNavLinkText.js +7 -1
- package/es/components/UIShell/SideNavMenu.js +32 -1
- package/es/components/UIShell/SideNavMenuItem.js +18 -1
- package/es/components/UIShell/SideNavSwitcher.js +17 -1
- package/es/components/UIShell/SkipToContent.js +12 -1
- package/es/components/UIShell/Switcher.js +13 -1
- package/es/components/UIShell/SwitcherDivider.js +6 -2
- package/es/components/UIShell/SwitcherItem.js +31 -1
- package/es/components/UnorderedList/UnorderedList.js +13 -1
- package/es/internal/FloatingMenu.js +1 -1
- package/es/internal/OptimizedResize.js +6 -2
- package/es/internal/usePresence.js +6 -0
- package/es/tools/wrapComponent.js +1 -1
- package/lib/components/AILabel/index.js +49 -2
- package/lib/components/AISkeleton/AISkeletonIcon.js +8 -2
- package/lib/components/AISkeleton/AISkeletonPlaceholder.js +8 -3
- package/lib/components/AISkeleton/AISkeletonText.js +17 -2
- package/lib/components/Accordion/Accordion.Skeleton.js +17 -2
- package/lib/components/Accordion/Accordion.js +24 -2
- package/lib/components/Accordion/AccordionItem.js +35 -2
- package/lib/components/AspectRatio/AspectRatio.js +21 -2
- package/lib/components/BadgeIndicator/index.js +11 -2
- package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +14 -2
- package/lib/components/Breadcrumb/Breadcrumb.js +18 -2
- package/lib/components/Breadcrumb/BreadcrumbItem.js +14 -2
- package/lib/components/Button/Button.Skeleton.js +19 -2
- package/lib/components/Button/Button.js +96 -0
- package/lib/components/Button/ButtonBase.js +2 -2
- package/lib/components/ButtonSet/ButtonSet.js +16 -2
- package/lib/components/ChatButton/ChatButton.Skeleton.js +8 -2
- package/lib/components/ChatButton/ChatButton.js +26 -2
- package/lib/components/Checkbox/Checkbox.Skeleton.js +7 -3
- package/lib/components/Checkbox/Checkbox.js +60 -3
- package/lib/components/CheckboxGroup/CheckboxGroup.js +42 -2
- package/lib/components/ClassPrefix/index.js +3 -0
- package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +8 -2
- package/lib/components/CodeSnippet/CodeSnippet.js +78 -2
- package/lib/components/ComboBox/ComboBox.js +142 -2
- package/lib/components/ComboButton/index.js +29 -2
- package/lib/components/ComposedModal/ComposedModal.js +71 -3
- package/lib/components/ComposedModal/ComposedModalContext.js +0 -1
- package/lib/components/ComposedModal/ModalFooter.js +66 -3
- package/lib/components/ComposedModal/ModalHeader.js +37 -2
- package/lib/components/ComposedModal/useComposedModalState.js +0 -1
- package/lib/components/ContainedList/ContainedList.js +23 -2
- package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +20 -2
- package/lib/components/ContainedList/index.js +2 -2
- package/lib/components/ContentSwitcher/ContentSwitcher.js +27 -2
- package/lib/components/ContextMenu/useContextMenu.js +0 -1
- package/lib/components/Copy/Copy.js +32 -3
- package/lib/components/CopyButton/CopyButton.js +29 -3
- package/lib/components/DataTable/DataTable.js +59 -0
- package/lib/components/DataTable/Table.js +29 -2
- package/lib/components/DataTable/TableBatchAction.js +10 -0
- package/lib/components/DataTable/TableBatchActions.js +26 -2
- package/lib/components/DataTable/TableBody.js +3 -0
- package/lib/components/DataTable/TableCell.js +17 -2
- package/lib/components/DataTable/TableContainer.js +20 -2
- package/lib/components/DataTable/TableContext.js +0 -1
- package/lib/components/DataTable/TableDecoratorRow.js +8 -2
- package/lib/components/DataTable/TableExpandHeader.js +33 -2
- package/lib/components/DataTable/TableExpandRow.js +31 -2
- package/lib/components/DataTable/TableExpandedRow.js +11 -2
- package/lib/components/DataTable/TableHeader.js +37 -2
- package/lib/components/DataTable/TableRow.js +23 -2
- package/lib/components/DataTable/TableSelectAll.js +30 -2
- package/lib/components/DataTable/TableSelectRow.js +33 -2
- package/lib/components/DataTable/TableSlugRow.js +8 -2
- package/lib/components/DataTable/TableToolbar.js +17 -2
- package/lib/components/DataTable/TableToolbarMenu.js +17 -2
- package/lib/components/DataTable/TableToolbarSearch.js +61 -3
- package/lib/components/DataTableSkeleton/DataTableSkeleton.js +26 -2
- package/lib/components/DatePicker/DatePicker.Skeleton.js +14 -2
- package/lib/components/DatePicker/DatePicker.js +90 -2
- package/lib/components/DatePickerInput/DatePickerInput.js +82 -3
- package/lib/components/Dialog/Dialog.js +133 -6
- package/lib/components/Dropdown/Dropdown.Skeleton.js +11 -2
- package/lib/components/Dropdown/Dropdown.js +111 -2
- package/lib/components/ErrorBoundary/ErrorBoundaryContext.js +0 -1
- package/lib/components/ExpandableSearch/ExpandableSearch.js +2 -2
- package/lib/components/FeatureFlags/index.js +3 -0
- package/lib/components/FileUploader/FileUploader.Skeleton.js +7 -3
- package/lib/components/FileUploader/FileUploader.js +59 -2
- package/lib/components/FileUploader/FileUploaderButton.js +50 -3
- package/lib/components/FileUploader/FileUploaderDropContainer.js +45 -3
- package/lib/components/FileUploader/FileUploaderItem.js +32 -3
- package/lib/components/FileUploader/Filename.js +18 -0
- package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +7 -3
- package/lib/components/FluidComboBox/FluidComboBox.js +63 -2
- package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +8 -2
- package/lib/components/FluidDatePicker/FluidDatePicker.js +23 -2
- package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +7 -3
- package/lib/components/FluidDropdown/FluidDropdown.js +67 -2
- package/lib/components/FluidForm/FluidForm.js +8 -2
- package/lib/components/FluidForm/FormContext.js +0 -1
- package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +7 -3
- package/lib/components/FluidMultiSelect/FluidMultiSelect.js +130 -2
- package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +7 -3
- package/lib/components/FluidNumberInput/FluidNumberInput.js +97 -2
- package/lib/components/FluidSearch/FluidSearch.Skeleton.js +7 -3
- package/lib/components/FluidSearch/FluidSearch.js +47 -2
- package/lib/components/FluidSelect/FluidSelect.Skeleton.js +7 -3
- package/lib/components/FluidSelect/FluidSelect.js +40 -2
- package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +7 -3
- package/lib/components/FluidTextArea/FluidTextArea.js +69 -2
- package/lib/components/FluidTextInput/FluidPasswordInput.js +60 -2
- package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +7 -3
- package/lib/components/FluidTextInput/FluidTextInput.js +56 -2
- package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +8 -2
- package/lib/components/FluidTimePicker/FluidTimePicker.js +30 -2
- package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +26 -0
- package/lib/components/Form/Form.js +8 -2
- package/lib/components/FormGroup/FormGroup.js +27 -2
- package/lib/components/FormItem/FormItem.js +8 -2
- package/lib/components/FormLabel/FormLabel.js +11 -2
- package/lib/components/Grid/CSSGrid.js +45 -2
- package/lib/components/Grid/Column.js +88 -2
- package/lib/components/Grid/ColumnHang.js +11 -2
- package/lib/components/Grid/FlexGrid.js +26 -2
- package/lib/components/Grid/Grid.js +27 -0
- package/lib/components/Grid/GridContext.js +10 -0
- package/lib/components/Grid/Row.js +19 -2
- package/lib/components/Heading/index.js +19 -0
- package/lib/components/Icon/Icon.Skeleton.js +7 -3
- package/lib/components/IconButton/index.js +70 -2
- package/lib/components/IconIndicator/index.js +14 -2
- package/lib/components/IdPrefix/index.js +3 -0
- package/lib/components/InlineCheckbox/InlineCheckbox.js +34 -0
- package/lib/components/InlineLoading/InlineLoading.js +21 -2
- package/lib/components/Layer/index.js +19 -2
- package/lib/components/Layout/index.js +36 -2
- package/lib/components/LayoutDirection/LayoutDirection.js +10 -0
- package/lib/components/LayoutDirection/useLayoutDirection.js +0 -1
- package/lib/components/Link/Link.d.ts +1 -1
- package/lib/components/Link/Link.js +30 -2
- package/lib/components/ListBox/ListBox.js +43 -2
- package/lib/components/ListBox/ListBoxField.js +17 -0
- package/lib/components/ListBox/ListBoxMenu.js +6 -0
- package/lib/components/ListBox/ListBoxMenuIcon.js +9 -2
- package/lib/components/ListBox/ListBoxMenuItem.js +18 -2
- package/lib/components/ListBox/ListBoxSelection.d.ts +1 -1
- package/lib/components/ListBox/ListBoxSelection.js +34 -11
- package/lib/components/ListBox/next/ListBoxSelection.d.ts +1 -1
- package/lib/components/ListBox/next/ListBoxSelection.js +43 -8
- package/lib/components/ListBox/next/ListBoxTrigger.js +9 -2
- package/lib/components/ListItem/ListItem.js +8 -2
- package/lib/components/Loading/Loading.js +20 -2
- package/lib/components/Menu/Menu.js +54 -2
- package/lib/components/Menu/MenuContext.js +0 -1
- package/lib/components/Menu/MenuItem.js +79 -3
- package/lib/components/MenuButton/index.js +35 -2
- package/lib/components/Modal/Modal.js +119 -5
- package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
- package/lib/components/MultiSelect/FilterableMultiSelect.js +130 -2
- package/lib/components/MultiSelect/MultiSelect.js +151 -3
- package/lib/components/MultiSelect/MultiSelectPropTypes.js +25 -0
- package/lib/components/Notification/Notification.js +211 -4
- package/lib/components/NumberInput/NumberInput.Skeleton.js +11 -2
- package/lib/components/NumberInput/NumberInput.js +140 -2
- package/lib/components/OrderedList/OrderedList.js +17 -2
- package/lib/components/OverflowMenu/OverflowMenu.js +79 -3
- package/lib/components/OverflowMenu/next/index.js +32 -2
- package/lib/components/OverflowMenuItem/OverflowMenuItem.js +39 -3
- package/lib/components/PageHeader/PageHeader.js +50 -2
- package/lib/components/Pagination/Pagination.Skeleton.js +7 -3
- package/lib/components/Pagination/Pagination.d.ts +8 -0
- package/lib/components/Pagination/Pagination.js +87 -5
- package/lib/components/Pagination/experimental/PageSelector.js +10 -2
- package/lib/components/Pagination/experimental/Pagination.js +56 -2
- package/lib/components/PaginationNav/PaginationNav.js +82 -2
- package/lib/components/Popover/index.js +60 -2
- package/lib/components/ProgressBar/ProgressBar.js +29 -2
- package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +8 -2
- package/lib/components/ProgressIndicator/ProgressIndicator.js +60 -2
- package/lib/components/RadioButton/RadioButton.Skeleton.js +7 -3
- package/lib/components/RadioButton/RadioButton.js +65 -2
- package/lib/components/RadioButtonGroup/RadioButtonGroup.js +61 -2
- package/lib/components/RadioTile/RadioTile.js +48 -3
- package/lib/components/Search/Search.Skeleton.js +11 -2
- package/lib/components/Search/Search.js +69 -4
- package/lib/components/Select/Select.Skeleton.js +8 -2
- package/lib/components/Select/Select.js +84 -21
- package/lib/components/SelectItem/SelectItem.js +17 -2
- package/lib/components/SelectItemGroup/SelectItemGroup.js +14 -2
- package/lib/components/ShapeIndicator/index.js +14 -2
- package/lib/components/SkeletonIcon/SkeletonIcon.js +7 -3
- package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +7 -3
- package/lib/components/SkeletonText/SkeletonText.js +17 -2
- package/lib/components/Slider/Slider.Skeleton.js +17 -2
- package/lib/components/Slider/Slider.js +106 -2
- package/lib/components/Stack/Stack.js +22 -2
- package/lib/components/StructuredList/StructuredList.Skeleton.js +8 -2
- package/lib/components/StructuredList/StructuredList.js +99 -2
- package/lib/components/Switch/IconSwitch.js +50 -3
- package/lib/components/Switch/Switch.js +33 -3
- package/lib/components/TabContent/TabContent.js +11 -2
- package/lib/components/Tabs/Tabs.Skeleton.js +8 -2
- package/lib/components/Tabs/Tabs.js +176 -3
- package/lib/components/Tabs/usePressable.js +0 -1
- package/lib/components/Tag/DismissibleTag.js +45 -2
- package/lib/components/Tag/OperationalTag.js +24 -2
- package/lib/components/Tag/SelectableTag.js +33 -2
- package/lib/components/Tag/Tag.Skeleton.js +9 -2
- package/lib/components/Tag/Tag.js +43 -2
- package/lib/components/Text/Text.js +10 -0
- package/lib/components/Text/TextDirection.js +11 -0
- package/lib/components/Text/TextDirectionContext.js +0 -1
- package/lib/components/TextArea/TextArea.Skeleton.js +8 -2
- package/lib/components/TextArea/TextArea.js +83 -3
- package/lib/components/TextInput/ControlledPasswordInput.js +67 -3
- package/lib/components/TextInput/PasswordInput.js +85 -2
- package/lib/components/TextInput/TextInput.Skeleton.js +11 -2
- package/lib/components/TextInput/TextInput.js +78 -2
- package/lib/components/Theme/index.js +23 -2
- package/lib/components/Tile/Tile.js +159 -4
- package/lib/components/TileGroup/TileGroup.js +29 -1
- package/lib/components/TimePicker/TimePicker.js +69 -2
- package/lib/components/TimePickerSelect/TimePickerSelect.js +17 -2
- package/lib/components/Toggle/Toggle.Skeleton.js +2 -2
- package/lib/components/Toggle/Toggle.js +48 -2
- package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +13 -2
- package/lib/components/Toggletip/index.js +40 -2
- package/lib/components/Tooltip/DefinitionTooltip.js +38 -2
- package/lib/components/Tooltip/Tooltip.js +48 -2
- package/lib/components/TreeView/TreeContext.js +0 -1
- package/lib/components/TreeView/TreeNode.js +66 -2
- package/lib/components/TreeView/TreeView.js +34 -2
- package/lib/components/UIShell/Content.js +11 -2
- package/lib/components/UIShell/Header.js +11 -2
- package/lib/components/UIShell/HeaderContainer.js +9 -0
- package/lib/components/UIShell/HeaderGlobalAction.js +30 -2
- package/lib/components/UIShell/HeaderMenu.js +39 -2
- package/lib/components/UIShell/HeaderMenuButton.js +19 -2
- package/lib/components/UIShell/HeaderMenuItem.js +27 -2
- package/lib/components/UIShell/HeaderName.js +20 -2
- package/lib/components/UIShell/HeaderNavigation.js +12 -2
- package/lib/components/UIShell/HeaderPanel.js +22 -3
- package/lib/components/UIShell/HeaderSideNavItems.js +13 -2
- package/lib/components/UIShell/Link.js +14 -0
- package/lib/components/UIShell/SideNav.js +55 -2
- package/lib/components/UIShell/SideNavDetails.js +12 -2
- package/lib/components/UIShell/SideNavDivider.js +7 -3
- package/lib/components/UIShell/SideNavFooter.js +13 -2
- package/lib/components/UIShell/SideNavHeader.js +15 -2
- package/lib/components/UIShell/SideNavIcon.js +12 -2
- package/lib/components/UIShell/SideNavItem.js +12 -2
- package/lib/components/UIShell/SideNavItems.js +13 -2
- package/lib/components/UIShell/SideNavLink.js +24 -2
- package/lib/components/UIShell/SideNavLinkText.js +8 -2
- package/lib/components/UIShell/SideNavMenu.js +33 -2
- package/lib/components/UIShell/SideNavMenuItem.js +19 -2
- package/lib/components/UIShell/SideNavSwitcher.js +18 -2
- package/lib/components/UIShell/SkipToContent.js +13 -2
- package/lib/components/UIShell/Switcher.js +14 -2
- package/lib/components/UIShell/SwitcherDivider.js +7 -3
- package/lib/components/UIShell/SwitcherItem.js +32 -2
- package/lib/components/UnorderedList/UnorderedList.js +14 -2
- package/lib/feature-flags.js +0 -1
- package/lib/index.js +241 -242
- package/lib/internal/FloatingMenu.js +1 -1
- package/lib/internal/OptimizedResize.js +6 -2
- package/lib/internal/useAttachedMenu.js +0 -1
- package/lib/internal/useControllableState.js +0 -1
- package/lib/internal/useDelayedState.js +0 -1
- package/lib/internal/useEvent.js +0 -1
- package/lib/internal/useIsomorphicEffect.js +0 -1
- package/lib/internal/useMatchMedia.js +0 -1
- package/lib/internal/useMergedRefs.js +0 -1
- package/lib/internal/useNoInteractiveChildren.js +0 -1
- package/lib/internal/useOutsideClick.js +0 -1
- package/lib/internal/useOverflowItems.js +0 -1
- package/lib/internal/usePresence.js +6 -1
- package/lib/internal/usePresenceContext.js +0 -1
- package/lib/internal/usePreviousValue.js +0 -1
- package/lib/internal/useResizeObserver.js +0 -1
- package/lib/internal/useSavedCallback.js +0 -1
- package/lib/internal/utils.js +0 -1
- package/lib/internal/wrapFocus.js +0 -1
- package/lib/tools/wrapComponent.js +2 -2
- package/package.json +9 -9
- package/telemetry.yml +12 -0
|
@@ -12,8 +12,8 @@ import { hasHelperText } from "../../internal/hasHelperText.js";
|
|
|
12
12
|
import { useNormalizedInputProps } from "../../internal/useNormalizedInputProps.js";
|
|
13
13
|
import { FormContext } from "../FluidForm/FormContext.js";
|
|
14
14
|
import { getTextInputProps } from "./util.js";
|
|
15
|
-
import { forwardRef, useContext, useEffect, useState } from "react";
|
|
16
15
|
import classNames from "classnames";
|
|
16
|
+
import { forwardRef, useContext, useEffect, useState } from "react";
|
|
17
17
|
import PropTypes from "prop-types";
|
|
18
18
|
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
19
19
|
import { View, ViewOff } from "@carbon/icons-react";
|
|
@@ -173,44 +173,127 @@ const PasswordInput = forwardRef(({ className, disabled = false, helperText, hid
|
|
|
173
173
|
});
|
|
174
174
|
PasswordInput.displayName = "PasswordInput";
|
|
175
175
|
PasswordInput.propTypes = {
|
|
176
|
+
/**
|
|
177
|
+
* Provide a custom className that is applied directly to the underlying
|
|
178
|
+
* `<input>` node
|
|
179
|
+
*/
|
|
176
180
|
className: PropTypes.string,
|
|
181
|
+
/**
|
|
182
|
+
* Optionally provide the default value of the `<input>`
|
|
183
|
+
*/
|
|
177
184
|
defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
185
|
+
/**
|
|
186
|
+
* Specify whether the control is disabled
|
|
187
|
+
*/
|
|
178
188
|
disabled: PropTypes.bool,
|
|
189
|
+
/**
|
|
190
|
+
* Provide text that is used alongside the control label for additional help
|
|
191
|
+
*/
|
|
179
192
|
helperText: PropTypes.node,
|
|
193
|
+
/**
|
|
194
|
+
* Specify whether or not the underlying label is visually hidden
|
|
195
|
+
*/
|
|
180
196
|
hideLabel: PropTypes.bool,
|
|
197
|
+
/**
|
|
198
|
+
* "Hide password" tooltip text on password visibility toggle
|
|
199
|
+
*/
|
|
181
200
|
hidePasswordLabel: PropTypes.string,
|
|
201
|
+
/**
|
|
202
|
+
* Provide a unique identifier for the input field
|
|
203
|
+
*/
|
|
182
204
|
id: PropTypes.string.isRequired,
|
|
205
|
+
/**
|
|
206
|
+
* `true` to use the inline version.
|
|
207
|
+
*/
|
|
183
208
|
inline: PropTypes.bool,
|
|
209
|
+
/**
|
|
210
|
+
* Specify whether the control is currently invalid
|
|
211
|
+
*/
|
|
184
212
|
invalid: PropTypes.bool,
|
|
213
|
+
/**
|
|
214
|
+
* Whether the PasswordInput should be read-only
|
|
215
|
+
*/
|
|
185
216
|
readOnly: PropTypes.bool,
|
|
217
|
+
/**
|
|
218
|
+
* Provide the text that is displayed when the control is in an invalid state
|
|
219
|
+
*/
|
|
186
220
|
invalidText: PropTypes.node,
|
|
221
|
+
/**
|
|
222
|
+
* Provide the text that will be read by a screen reader when visiting this
|
|
223
|
+
* control
|
|
224
|
+
*/
|
|
187
225
|
labelText: PropTypes.node.isRequired,
|
|
226
|
+
/**
|
|
227
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
228
|
+
* Don't use this to make tile background color same as container background color.
|
|
229
|
+
*/
|
|
188
230
|
light: deprecate(PropTypes.bool, "The `light` prop for `PasswordInput` has been deprecated in favor of the new `Layer` component. It will be removed in the next major release."),
|
|
231
|
+
/**
|
|
232
|
+
* Optionally provide an `onChange` handler that is called whenever `<input>`
|
|
233
|
+
* is updated
|
|
234
|
+
*/
|
|
189
235
|
onChange: PropTypes.func,
|
|
236
|
+
/**
|
|
237
|
+
* Optionally provide an `onClick` handler that is called whenever the
|
|
238
|
+
* `<input>` is clicked
|
|
239
|
+
*/
|
|
190
240
|
onClick: PropTypes.func,
|
|
241
|
+
/**
|
|
242
|
+
* Callback function that is called whenever the toggle password visibility
|
|
243
|
+
* button is clicked
|
|
244
|
+
*/
|
|
191
245
|
onTogglePasswordVisibility: PropTypes.func,
|
|
246
|
+
/**
|
|
247
|
+
* Specify the placeholder attribute for the `<input>`
|
|
248
|
+
*/
|
|
192
249
|
placeholder: PropTypes.string,
|
|
250
|
+
/**
|
|
251
|
+
* "Show password" tooltip text on password visibility toggle
|
|
252
|
+
*/
|
|
193
253
|
showPasswordLabel: PropTypes.string,
|
|
254
|
+
/**
|
|
255
|
+
* Specify the size of the Text Input. Supports `xs`, `sm`, `md`, or `lg`.
|
|
256
|
+
*/
|
|
194
257
|
size: PropTypes.oneOf([
|
|
195
258
|
"xs",
|
|
196
259
|
"sm",
|
|
197
260
|
"md",
|
|
198
261
|
"lg"
|
|
199
262
|
]),
|
|
263
|
+
/**
|
|
264
|
+
* Specify the alignment of the tooltip to the icon-only button.
|
|
265
|
+
* Can be one of: start, center, or end.
|
|
266
|
+
*/
|
|
200
267
|
tooltipAlignment: PropTypes.oneOf([
|
|
201
268
|
"start",
|
|
202
269
|
"center",
|
|
203
270
|
"end"
|
|
204
271
|
]),
|
|
272
|
+
/**
|
|
273
|
+
* Specify the direction of the tooltip for icon-only buttons.
|
|
274
|
+
* Can be either top, right, bottom, or left.
|
|
275
|
+
*/
|
|
205
276
|
tooltipPosition: PropTypes.oneOf([
|
|
206
277
|
"top",
|
|
207
278
|
"right",
|
|
208
279
|
"bottom",
|
|
209
280
|
"left"
|
|
210
281
|
]),
|
|
282
|
+
/**
|
|
283
|
+
* The input type, either password or text
|
|
284
|
+
*/
|
|
211
285
|
type: PropTypes.oneOf(["password", "text"]),
|
|
286
|
+
/**
|
|
287
|
+
* Provide the current value of the `<input>`
|
|
288
|
+
*/
|
|
212
289
|
value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
290
|
+
/**
|
|
291
|
+
* Specify whether the control is currently in warning state
|
|
292
|
+
*/
|
|
213
293
|
warn: PropTypes.bool,
|
|
294
|
+
/**
|
|
295
|
+
* Provide the text that is displayed when the control is in warning state
|
|
296
|
+
*/
|
|
214
297
|
warnText: PropTypes.node
|
|
215
298
|
};
|
|
216
299
|
//#endregion
|
|
@@ -6,8 +6,8 @@
|
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
8
|
import { usePrefix } from "../../internal/usePrefix.js";
|
|
9
|
-
import "react";
|
|
10
9
|
import classNames from "classnames";
|
|
10
|
+
import "react";
|
|
11
11
|
import PropTypes from "prop-types";
|
|
12
12
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
13
13
|
//#region src/components/TextInput/TextInput.Skeleton.tsx
|
|
@@ -26,8 +26,17 @@ const TextInputSkeleton = ({ hideLabel, className, size, ...rest }) => {
|
|
|
26
26
|
});
|
|
27
27
|
};
|
|
28
28
|
TextInputSkeleton.propTypes = {
|
|
29
|
+
/**
|
|
30
|
+
* Specify an optional className to add to the form item wrapper.
|
|
31
|
+
*/
|
|
29
32
|
className: PropTypes.string,
|
|
33
|
+
/**
|
|
34
|
+
* Specify whether the label should be hidden, or not
|
|
35
|
+
*/
|
|
30
36
|
hideLabel: PropTypes.bool,
|
|
37
|
+
/**
|
|
38
|
+
* Specify the size of the TextInputSkeleton
|
|
39
|
+
*/
|
|
31
40
|
size: PropTypes.oneOf([
|
|
32
41
|
"xs",
|
|
33
42
|
"sm",
|
|
@@ -16,8 +16,8 @@ import { AILabel } from "../AILabel/index.js";
|
|
|
16
16
|
import { FormContext } from "../FluidForm/FormContext.js";
|
|
17
17
|
import { getTextInputProps } from "./util.js";
|
|
18
18
|
import { getAnnouncement } from "../../internal/getAnnouncement.js";
|
|
19
|
-
import { cloneElement, forwardRef, useContext, useEffect, useRef, useState } from "react";
|
|
20
19
|
import classNames from "classnames";
|
|
20
|
+
import { cloneElement, forwardRef, useContext, useEffect, useRef, useState } from "react";
|
|
21
21
|
import PropTypes from "prop-types";
|
|
22
22
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
23
23
|
//#region src/components/TextInput/TextInput.tsx
|
|
@@ -203,34 +203,110 @@ const TextInput = forwardRef(({ className, decorator, disabled = false, helperTe
|
|
|
203
203
|
});
|
|
204
204
|
TextInput.displayName = "TextInput";
|
|
205
205
|
TextInput.propTypes = {
|
|
206
|
+
/**
|
|
207
|
+
* Specify an optional className to be applied to the `<input>` node
|
|
208
|
+
*/
|
|
206
209
|
className: PropTypes.string,
|
|
210
|
+
/**
|
|
211
|
+
* **Experimental**: Provide a `decorator` component to be rendered inside the `TextInput` component
|
|
212
|
+
*/
|
|
207
213
|
decorator: PropTypes.node,
|
|
214
|
+
/**
|
|
215
|
+
* Optionally provide the default value of the `<input>`
|
|
216
|
+
*/
|
|
208
217
|
defaultValue: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
218
|
+
/**
|
|
219
|
+
* Specify whether the `<input>` should be disabled
|
|
220
|
+
*/
|
|
209
221
|
disabled: PropTypes.bool,
|
|
222
|
+
/**
|
|
223
|
+
* Specify whether to display the character counter
|
|
224
|
+
*/
|
|
210
225
|
enableCounter: PropTypes.bool,
|
|
226
|
+
/**
|
|
227
|
+
* Provide text that is used alongside the control label for additional help
|
|
228
|
+
*/
|
|
211
229
|
helperText: PropTypes.node,
|
|
230
|
+
/**
|
|
231
|
+
* Specify whether you want the underlying label to be visually hidden
|
|
232
|
+
*/
|
|
212
233
|
hideLabel: PropTypes.bool,
|
|
234
|
+
/**
|
|
235
|
+
* Specify a custom `id` for the `<input>`
|
|
236
|
+
*/
|
|
213
237
|
id: PropTypes.string.isRequired,
|
|
238
|
+
/**
|
|
239
|
+
* `true` to use the inline version.
|
|
240
|
+
*/
|
|
214
241
|
inline: PropTypes.bool,
|
|
242
|
+
/**
|
|
243
|
+
* Specify whether the control is currently invalid
|
|
244
|
+
*/
|
|
215
245
|
invalid: PropTypes.bool,
|
|
246
|
+
/**
|
|
247
|
+
* Provide the text that is displayed when the control is in an invalid state
|
|
248
|
+
*/
|
|
216
249
|
invalidText: PropTypes.node,
|
|
250
|
+
/**
|
|
251
|
+
* Provide the text that will be read by a screen reader when visiting this
|
|
252
|
+
* control
|
|
253
|
+
*/
|
|
217
254
|
labelText: PropTypes.node.isRequired,
|
|
255
|
+
/**
|
|
256
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
257
|
+
* Don't use this to make tile background color same as container background color.
|
|
258
|
+
*/
|
|
218
259
|
light: deprecate(PropTypes.bool, "The `light` prop for `TextInput` has been deprecated in favor of the new `Layer` component. It will be removed in the next major release."),
|
|
260
|
+
/**
|
|
261
|
+
* Max character count allowed for the input. This is needed in order for enableCounter to display
|
|
262
|
+
*/
|
|
219
263
|
maxCount: PropTypes.number,
|
|
264
|
+
/**
|
|
265
|
+
* Optionally provide an `onChange` handler that is called whenever `<input>`
|
|
266
|
+
* is updated
|
|
267
|
+
*/
|
|
220
268
|
onChange: PropTypes.func,
|
|
269
|
+
/**
|
|
270
|
+
* Optionally provide an `onClick` handler that is called whenever the
|
|
271
|
+
* `<input>` is clicked
|
|
272
|
+
*/
|
|
221
273
|
onClick: PropTypes.func,
|
|
274
|
+
/**
|
|
275
|
+
* Specify the placeholder attribute for the `<input>`
|
|
276
|
+
*/
|
|
222
277
|
placeholder: PropTypes.string,
|
|
278
|
+
/**
|
|
279
|
+
* Whether the input should be read-only
|
|
280
|
+
*/
|
|
223
281
|
readOnly: PropTypes.bool,
|
|
282
|
+
/**
|
|
283
|
+
* Specify the size of the Text Input. Currently supports the following:
|
|
284
|
+
*/
|
|
224
285
|
size: PropTypes.oneOf([
|
|
225
286
|
"xs",
|
|
226
287
|
"sm",
|
|
227
288
|
"md",
|
|
228
289
|
"lg"
|
|
229
290
|
]),
|
|
291
|
+
/**
|
|
292
|
+
* **Experimental**: Provide a `Slug` component to be rendered inside the `TextInput` component
|
|
293
|
+
*/
|
|
230
294
|
slug: deprecate(PropTypes.node, "The `slug` prop for `TextInput` has been deprecated in favor of the new `decorator` prop. It will be removed in the next major release."),
|
|
295
|
+
/**
|
|
296
|
+
* Specify the type of the `<input>`
|
|
297
|
+
*/
|
|
231
298
|
type: PropTypes.string,
|
|
299
|
+
/**
|
|
300
|
+
* Specify the value of the `<input>`
|
|
301
|
+
*/
|
|
232
302
|
value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
303
|
+
/**
|
|
304
|
+
* Specify whether the control is currently in warning state
|
|
305
|
+
*/
|
|
233
306
|
warn: PropTypes.bool,
|
|
307
|
+
/**
|
|
308
|
+
* Provide the text that is displayed when the control is in warning state
|
|
309
|
+
*/
|
|
234
310
|
warnText: PropTypes.node
|
|
235
311
|
};
|
|
236
312
|
//#endregion
|
|
@@ -8,8 +8,8 @@
|
|
|
8
8
|
import { usePrefix } from "../../internal/usePrefix.js";
|
|
9
9
|
import { LayerContext } from "../Layer/LayerContext.js";
|
|
10
10
|
import { useMatchMedia } from "../../internal/useMatchMedia.js";
|
|
11
|
-
import React, { cloneElement, isValidElement, useMemo } from "react";
|
|
12
11
|
import classNames from "classnames";
|
|
12
|
+
import React, { cloneElement, isValidElement, useMemo } from "react";
|
|
13
13
|
import PropTypes from "prop-types";
|
|
14
14
|
import { jsx } from "react/jsx-runtime";
|
|
15
15
|
//#region src/components/Theme/index.tsx
|
|
@@ -31,7 +31,14 @@ const GlobalTheme = React.forwardRef(({ children, theme }, ref) => {
|
|
|
31
31
|
});
|
|
32
32
|
});
|
|
33
33
|
GlobalTheme.propTypes = {
|
|
34
|
+
/**
|
|
35
|
+
* Provide child elements to be rendered inside of `GlobalTheme`, this is
|
|
36
|
+
* typically the root of your app
|
|
37
|
+
*/
|
|
34
38
|
children: PropTypes.node,
|
|
39
|
+
/**
|
|
40
|
+
* Specify the global theme for your app
|
|
41
|
+
*/
|
|
35
42
|
theme: PropTypes.oneOf([
|
|
36
43
|
"white",
|
|
37
44
|
"g10",
|
|
@@ -70,13 +77,27 @@ function Theme({ as: BaseComponent = "div", className: customClassName, theme, .
|
|
|
70
77
|
});
|
|
71
78
|
}
|
|
72
79
|
Theme.propTypes = {
|
|
80
|
+
/**
|
|
81
|
+
* Specify a custom component or element to be rendered as the top-level
|
|
82
|
+
* element in the component
|
|
83
|
+
*/
|
|
73
84
|
as: PropTypes.oneOfType([
|
|
74
85
|
PropTypes.func,
|
|
75
86
|
PropTypes.string,
|
|
76
87
|
PropTypes.elementType
|
|
77
88
|
]),
|
|
89
|
+
/**
|
|
90
|
+
* Provide child elements to be rendered inside of `Theme`
|
|
91
|
+
*/
|
|
78
92
|
children: PropTypes.node,
|
|
93
|
+
/**
|
|
94
|
+
* Provide a custom class name to be used on the outermost element rendered by
|
|
95
|
+
* the component
|
|
96
|
+
*/
|
|
79
97
|
className: PropTypes.string,
|
|
98
|
+
/**
|
|
99
|
+
* Specify the theme
|
|
100
|
+
*/
|
|
80
101
|
theme: PropTypes.oneOf([
|
|
81
102
|
"white",
|
|
82
103
|
"g10",
|
|
@@ -19,8 +19,8 @@ import { useFeatureFlag } from "../FeatureFlags/index.js";
|
|
|
19
19
|
import { getInteractiveContent, getRoleContent } from "../../internal/useNoInteractiveChildren.js";
|
|
20
20
|
import { AILabel } from "../AILabel/index.js";
|
|
21
21
|
import { composeEventHandlers } from "../../tools/events.js";
|
|
22
|
-
import React, { Children, cloneElement, forwardRef, useCallback, useEffect, useRef, useState } from "react";
|
|
23
22
|
import classNames from "classnames";
|
|
23
|
+
import React, { Children, cloneElement, forwardRef, useCallback, useEffect, useRef, useState } from "react";
|
|
24
24
|
import PropTypes from "prop-types";
|
|
25
25
|
import { jsx, jsxs } from "react/jsx-runtime";
|
|
26
26
|
import { AiLabel, ArrowRight, Checkbox, CheckboxCheckedFilled, ChevronDown, Error } from "@carbon/icons-react";
|
|
@@ -55,11 +55,33 @@ const Tile = React.forwardRef(({ children, className, decorator, light = false,
|
|
|
55
55
|
});
|
|
56
56
|
Tile.displayName = "Tile";
|
|
57
57
|
Tile.propTypes = {
|
|
58
|
+
/**
|
|
59
|
+
* The child nodes.
|
|
60
|
+
*/
|
|
58
61
|
children: PropTypes.node,
|
|
62
|
+
/**
|
|
63
|
+
* The CSS class names.
|
|
64
|
+
*/
|
|
59
65
|
className: PropTypes.string,
|
|
66
|
+
/**
|
|
67
|
+
* **Experimental**: Provide a `decorator` component to be rendered inside the `Tile` component
|
|
68
|
+
*/
|
|
60
69
|
decorator: PropTypes.node,
|
|
70
|
+
/**
|
|
71
|
+
* **Experimental**: Specify if the `Tile` component should be rendered with rounded corners. Only valid
|
|
72
|
+
* when an AILabel is present
|
|
73
|
+
*/
|
|
61
74
|
hasRoundedCorners: PropTypes.bool,
|
|
75
|
+
/**
|
|
76
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
77
|
+
* Don't use this to make tile background color same as container background color.
|
|
78
|
+
*
|
|
79
|
+
* @deprecated
|
|
80
|
+
*/
|
|
62
81
|
light: deprecate(PropTypes.bool, "The `light` prop for `Tile` is no longer needed and has been deprecated. It will be removed in the next major release. Use the Layer component instead."),
|
|
82
|
+
/**
|
|
83
|
+
* **Experimental**: Provide a `Slug` component to be rendered inside the `Tile` component
|
|
84
|
+
*/
|
|
63
85
|
slug: deprecate(PropTypes.node, "The `slug` prop for `Tile` has been deprecated in favor of the new `decorator` prop. It will be removed in the next major release.")
|
|
64
86
|
};
|
|
65
87
|
const ClickableTile = React.forwardRef(({ children, className, clicked = false, decorator, disabled, href, light, onClick = () => {}, onKeyDown = () => {}, renderIcon: Icon, hasRoundedCorners, slug, ...rest }, ref) => {
|
|
@@ -124,17 +146,55 @@ const ClickableTile = React.forwardRef(({ children, className, clicked = false,
|
|
|
124
146
|
});
|
|
125
147
|
ClickableTile.displayName = "ClickableTile";
|
|
126
148
|
ClickableTile.propTypes = {
|
|
149
|
+
/**
|
|
150
|
+
* The child nodes.
|
|
151
|
+
*/
|
|
127
152
|
children: PropTypes.node,
|
|
153
|
+
/**
|
|
154
|
+
* The CSS class names.
|
|
155
|
+
*/
|
|
128
156
|
className: PropTypes.string,
|
|
157
|
+
/**
|
|
158
|
+
* Boolean for whether a tile has been clicked.
|
|
159
|
+
*/
|
|
129
160
|
clicked: PropTypes.bool,
|
|
161
|
+
/**
|
|
162
|
+
* **Experimental**: Provide a `decorator` component or set the boolean to True for an AILabel icon to be rendered inside the `ClickableTile` component
|
|
163
|
+
*/
|
|
130
164
|
decorator: PropTypes.oneOfType([PropTypes.bool, PropTypes.node]),
|
|
165
|
+
/**
|
|
166
|
+
* Specify whether the ClickableTile should be disabled
|
|
167
|
+
*/
|
|
131
168
|
disabled: PropTypes.bool,
|
|
169
|
+
/**
|
|
170
|
+
* **Experimental**: Specify if the `ClickableTile` component should be rendered with rounded corners.
|
|
171
|
+
* Only valid when `slug` prop is present
|
|
172
|
+
*/
|
|
132
173
|
hasRoundedCorners: PropTypes.bool,
|
|
174
|
+
/**
|
|
175
|
+
* The href for the link.
|
|
176
|
+
*/
|
|
133
177
|
href: PropTypes.string,
|
|
178
|
+
/**
|
|
179
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
180
|
+
* Don't use this to make tile background color same as container background color.
|
|
181
|
+
*/
|
|
134
182
|
light: deprecate(PropTypes.bool, "The `light` prop for `ClickableTile` is no longer needed and has been deprecated. It will be removed in the next major release. Use the Layer component instead."),
|
|
183
|
+
/**
|
|
184
|
+
* Specify the function to run when the ClickableTile is clicked
|
|
185
|
+
*/
|
|
135
186
|
onClick: PropTypes.func,
|
|
187
|
+
/**
|
|
188
|
+
* Specify the function to run when the ClickableTile is interacted with via a keyboard
|
|
189
|
+
*/
|
|
136
190
|
onKeyDown: PropTypes.func,
|
|
191
|
+
/**
|
|
192
|
+
* The rel property for the link.
|
|
193
|
+
*/
|
|
137
194
|
rel: PropTypes.string,
|
|
195
|
+
/**
|
|
196
|
+
* A component used to render an icon.
|
|
197
|
+
*/
|
|
138
198
|
renderIcon: PropTypes.oneOfType([PropTypes.func, PropTypes.object])
|
|
139
199
|
};
|
|
140
200
|
const SelectableTile = React.forwardRef(({ children, className, decorator, disabled, id, light, onClick = () => {}, onChange = () => {}, onKeyDown = () => {}, selected = false, tabIndex = 0, title = "title", slug, hasRoundedCorners, ...rest }, ref) => {
|
|
@@ -211,19 +271,65 @@ const SelectableTile = React.forwardRef(({ children, className, decorator, disab
|
|
|
211
271
|
SelectableTile.propTypes = {
|
|
212
272
|
children: PropTypes.node,
|
|
213
273
|
className: PropTypes.string,
|
|
274
|
+
/**
|
|
275
|
+
* **Experimental**: Provide a `decorator` component to be rendered inside the `SelectableTile` component
|
|
276
|
+
*/
|
|
214
277
|
decorator: PropTypes.node,
|
|
278
|
+
/**
|
|
279
|
+
* Specify whether the SelectableTile should be disabled
|
|
280
|
+
*/
|
|
215
281
|
disabled: PropTypes.bool,
|
|
282
|
+
/**
|
|
283
|
+
* **Experimental**: Specify if the `SelectableTile` component should be rendered with rounded corners.
|
|
284
|
+
* Only valid when `slug` prop is present
|
|
285
|
+
*/
|
|
216
286
|
hasRoundedCorners: PropTypes.bool,
|
|
287
|
+
/**
|
|
288
|
+
* The ID of the `<input>`.
|
|
289
|
+
*/
|
|
217
290
|
id: PropTypes.string,
|
|
291
|
+
/**
|
|
292
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
293
|
+
* Don't use this to make tile background color same as container background color.
|
|
294
|
+
*/
|
|
218
295
|
light: deprecate(PropTypes.bool, "The `light` prop for `SelectableTile` is no longer needed and has been deprecated. It will be removed in the next major release. Use the Layer component instead."),
|
|
296
|
+
/**
|
|
297
|
+
* The `name` of the `<input>`.
|
|
298
|
+
* @deprecated
|
|
299
|
+
*/
|
|
219
300
|
name: deprecate(PropTypes.string, "The `name` property is no longer used. It will be removed in the next major release."),
|
|
301
|
+
/**
|
|
302
|
+
* The empty handler of the `<input>`.
|
|
303
|
+
*/
|
|
220
304
|
onChange: PropTypes.func,
|
|
305
|
+
/**
|
|
306
|
+
* Specify the function to run when the SelectableTile is clicked
|
|
307
|
+
*/
|
|
221
308
|
onClick: PropTypes.func,
|
|
309
|
+
/**
|
|
310
|
+
* Specify the function to run when the SelectableTile is interacted with via a keyboard
|
|
311
|
+
*/
|
|
222
312
|
onKeyDown: PropTypes.func,
|
|
313
|
+
/**
|
|
314
|
+
* `true` to select this tile.
|
|
315
|
+
*/
|
|
223
316
|
selected: PropTypes.bool,
|
|
317
|
+
/**
|
|
318
|
+
* **Experimental**: Provide a `Slug` component to be rendered inside the `SelectableTile` component
|
|
319
|
+
*/
|
|
224
320
|
slug: deprecate(PropTypes.node, "The `slug` prop for `SelectableTile` has been deprecated in favor of the new `decorator` prop. It will be removed in the next major release."),
|
|
321
|
+
/**
|
|
322
|
+
* Specify the tab index of the wrapper element
|
|
323
|
+
*/
|
|
225
324
|
tabIndex: PropTypes.number,
|
|
325
|
+
/**
|
|
326
|
+
* The `title` of the `<input>`.
|
|
327
|
+
*/
|
|
226
328
|
title: PropTypes.string,
|
|
329
|
+
/**
|
|
330
|
+
* The value of the `<input>`.
|
|
331
|
+
* @deprecated
|
|
332
|
+
*/
|
|
227
333
|
value: deprecate(PropTypes.oneOfType([PropTypes.string, PropTypes.number]), "The `value` property is no longer used. It will be removed in the next major release.`")
|
|
228
334
|
};
|
|
229
335
|
const ExpandableTile = forwardRef(({ tabIndex = 0, className, children, decorator, expanded = false, tileMaxHeight = 0, tilePadding = 0, onClick, onKeyUp, tileCollapsedIconText = "Interact to expand Tile", tileExpandedIconText = "Interact to collapse Tile", tileCollapsedLabel, tileExpandedLabel, light, slug, hasRoundedCorners, ...rest }, forwardRef) => {
|
|
@@ -374,18 +480,59 @@ const ExpandableTile = forwardRef(({ tabIndex = 0, className, children, decorato
|
|
|
374
480
|
ExpandableTile.propTypes = {
|
|
375
481
|
children: PropTypes.node,
|
|
376
482
|
className: PropTypes.string,
|
|
483
|
+
/**
|
|
484
|
+
* **Experimental**: Provide a `decorator` component to be rendered inside the `ExpandableTile` component
|
|
485
|
+
*/
|
|
377
486
|
decorator: PropTypes.node,
|
|
487
|
+
/**
|
|
488
|
+
* `true` if the tile is expanded.
|
|
489
|
+
*/
|
|
378
490
|
expanded: PropTypes.bool,
|
|
491
|
+
/**
|
|
492
|
+
* Specify if the `ExpandableTile` component should be rendered with rounded corners.
|
|
493
|
+
* Only valid when `slug` prop is present
|
|
494
|
+
*/
|
|
379
495
|
hasRoundedCorners: PropTypes.bool,
|
|
496
|
+
/**
|
|
497
|
+
* An ID that can be provided to aria-labelledby
|
|
498
|
+
*/
|
|
380
499
|
id: PropTypes.string,
|
|
500
|
+
/**
|
|
501
|
+
* `true` to use the light version. For use on $ui-01 backgrounds only.
|
|
502
|
+
* Don't use this to make tile background color same as container background color.
|
|
503
|
+
*/
|
|
381
504
|
light: deprecate(PropTypes.bool, "The `light` prop for `ExpandableTile` is no longer needed and has been deprecated. It will be removed in the next major release. Use the Layer component instead."),
|
|
505
|
+
/**
|
|
506
|
+
* Specify the function to run when the ExpandableTile is clicked
|
|
507
|
+
*/
|
|
382
508
|
onClick: PropTypes.func,
|
|
509
|
+
/**
|
|
510
|
+
* optional handler to trigger a function when a key is pressed
|
|
511
|
+
*/
|
|
383
512
|
onKeyUp: PropTypes.func,
|
|
513
|
+
/**
|
|
514
|
+
* **Experimental**: Provide a `Slug` component to be rendered inside the `ExpandableTile` component
|
|
515
|
+
*/
|
|
384
516
|
slug: deprecate(PropTypes.node, "The `slug` prop for `ExpandableTile` has been deprecated in favor of the new `decorator` prop. It will be removed in the next major release."),
|
|
517
|
+
/**
|
|
518
|
+
* The `tabindex` attribute.
|
|
519
|
+
*/
|
|
385
520
|
tabIndex: PropTypes.number,
|
|
521
|
+
/**
|
|
522
|
+
* The description of the "collapsed" icon that can be read by screen readers.
|
|
523
|
+
*/
|
|
386
524
|
tileCollapsedIconText: PropTypes.string,
|
|
525
|
+
/**
|
|
526
|
+
* When "collapsed", a label to appear next to the chevron (e.g., "View more").
|
|
527
|
+
*/
|
|
387
528
|
tileCollapsedLabel: PropTypes.string,
|
|
529
|
+
/**
|
|
530
|
+
* The description of the "expanded" icon that can be read by screen readers.
|
|
531
|
+
*/
|
|
388
532
|
tileExpandedIconText: PropTypes.string,
|
|
533
|
+
/**
|
|
534
|
+
* When "expanded", a label to appear next to the chevron (e.g., "View less").
|
|
535
|
+
*/
|
|
389
536
|
tileExpandedLabel: PropTypes.string
|
|
390
537
|
};
|
|
391
538
|
ExpandableTile.displayName = "ExpandableTile";
|
|
@@ -396,7 +543,11 @@ const TileAboveTheFoldContent = React.forwardRef(({ children }, ref) => {
|
|
|
396
543
|
children
|
|
397
544
|
});
|
|
398
545
|
});
|
|
399
|
-
TileAboveTheFoldContent.propTypes = {
|
|
546
|
+
TileAboveTheFoldContent.propTypes = {
|
|
547
|
+
/**
|
|
548
|
+
* The child nodes.
|
|
549
|
+
*/
|
|
550
|
+
children: PropTypes.node };
|
|
400
551
|
TileAboveTheFoldContent.displayName = "TileAboveTheFoldContent";
|
|
401
552
|
const TileBelowTheFoldContent = React.forwardRef(({ children }, ref) => {
|
|
402
553
|
return /* @__PURE__ */ jsx("div", {
|
|
@@ -405,7 +556,11 @@ const TileBelowTheFoldContent = React.forwardRef(({ children }, ref) => {
|
|
|
405
556
|
children
|
|
406
557
|
});
|
|
407
558
|
});
|
|
408
|
-
TileBelowTheFoldContent.propTypes = {
|
|
559
|
+
TileBelowTheFoldContent.propTypes = {
|
|
560
|
+
/**
|
|
561
|
+
* The child nodes.
|
|
562
|
+
*/
|
|
563
|
+
children: PropTypes.node };
|
|
409
564
|
TileBelowTheFoldContent.displayName = "TileBelowTheFoldContent";
|
|
410
565
|
//#endregion
|
|
411
566
|
export { ClickableTile, ExpandableTile, SelectableTile, Tile, TileAboveTheFoldContent, TileBelowTheFoldContent };
|
|
@@ -5,8 +5,8 @@
|
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
|
-
import { noopFn } from "../../internal/noopFn.js";
|
|
9
8
|
import { usePrefix } from "../../internal/usePrefix.js";
|
|
9
|
+
import { noopFn } from "../../internal/noopFn.js";
|
|
10
10
|
import { isComponentElement } from "../../internal/utils.js";
|
|
11
11
|
import RadioTile_default from "../RadioTile/index.js";
|
|
12
12
|
import { Children, cloneElement, createElement, isValidElement, useEffect, useState } from "react";
|
|
@@ -65,14 +65,42 @@ const TileGroup = ({ children, className, defaultSelected, disabled, legend, nam
|
|
|
65
65
|
};
|
|
66
66
|
TileGroup.displayName = "TileGroup";
|
|
67
67
|
TileGroup.propTypes = {
|
|
68
|
+
/**
|
|
69
|
+
* Provide a collection of <RadioTile> components to render in the group
|
|
70
|
+
*/
|
|
68
71
|
children: PropTypes.node,
|
|
72
|
+
/**
|
|
73
|
+
* Provide an optional className to be applied to the container node
|
|
74
|
+
*/
|
|
69
75
|
className: PropTypes.string,
|
|
76
|
+
/**
|
|
77
|
+
* Specify the the value of <RadioTile> to be selected by default
|
|
78
|
+
*/
|
|
70
79
|
defaultSelected: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
80
|
+
/**
|
|
81
|
+
* Specify whether the group is disabled
|
|
82
|
+
*/
|
|
71
83
|
disabled: PropTypes.bool,
|
|
84
|
+
/**
|
|
85
|
+
* Provide an optional legend for this group
|
|
86
|
+
*/
|
|
72
87
|
legend: PropTypes.string,
|
|
88
|
+
/**
|
|
89
|
+
* Specify the name of the underlying `<input>` nodes
|
|
90
|
+
*/
|
|
73
91
|
name: PropTypes.string.isRequired,
|
|
92
|
+
/**
|
|
93
|
+
* Provide an optional `onChange` hook that is called whenever the value of
|
|
94
|
+
* the group changes
|
|
95
|
+
*/
|
|
74
96
|
onChange: PropTypes.func,
|
|
97
|
+
/**
|
|
98
|
+
* `true` to specify if input selection in group is required.
|
|
99
|
+
*/
|
|
75
100
|
required: PropTypes.bool,
|
|
101
|
+
/**
|
|
102
|
+
* Specify the value that is currently selected in the group
|
|
103
|
+
*/
|
|
76
104
|
valueSelected: PropTypes.oneOfType([PropTypes.string, PropTypes.number])
|
|
77
105
|
};
|
|
78
106
|
//#endregion
|