@carbon/react 1.83.0-rc.0 → 1.84.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.
Files changed (635) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +895 -790
  2. package/README.md +1 -1
  3. package/es/components/AILabel/index.js +37 -40
  4. package/es/components/AISkeleton/AISkeletonIcon.js +6 -7
  5. package/es/components/AISkeleton/AISkeletonPlaceholder.js +6 -7
  6. package/es/components/AISkeleton/AISkeletonText.js +6 -7
  7. package/es/components/Accordion/Accordion.Skeleton.js +24 -25
  8. package/es/components/Accordion/Accordion.js +13 -14
  9. package/es/components/Accordion/AccordionItem.js +22 -23
  10. package/es/components/Accordion/AccordionProvider.js +6 -7
  11. package/es/components/AspectRatio/AspectRatio.js +9 -10
  12. package/es/components/BadgeIndicator/index.js +7 -8
  13. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +9 -10
  14. package/es/components/Breadcrumb/Breadcrumb.js +3 -3
  15. package/es/components/Breadcrumb/BreadcrumbItem.js +9 -9
  16. package/es/components/Button/Button.Skeleton.js +10 -11
  17. package/es/components/Button/Button.js +5 -5
  18. package/es/components/Button/ButtonBase.js +27 -28
  19. package/es/components/ButtonSet/ButtonSet.js +2 -2
  20. package/es/components/ChatButton/ChatButton.Skeleton.js +7 -8
  21. package/es/components/ChatButton/ChatButton.js +13 -14
  22. package/es/components/Checkbox/Checkbox.Skeleton.js +8 -9
  23. package/es/components/Checkbox/Checkbox.js +33 -34
  24. package/es/components/CheckboxGroup/CheckboxGroup.js +28 -29
  25. package/es/components/ClassPrefix/index.js +6 -7
  26. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +12 -13
  27. package/es/components/CodeSnippet/CodeSnippet.js +41 -42
  28. package/es/components/ComboBox/ComboBox.js +42 -48
  29. package/es/components/ComboBox/tools/filter.js +9 -12
  30. package/es/components/ComboButton/index.js +22 -24
  31. package/es/components/ComposedModal/ComposedModal.js +49 -52
  32. package/es/components/ComposedModal/ModalFooter.js +42 -47
  33. package/es/components/ComposedModal/ModalHeader.js +21 -22
  34. package/es/components/ContainedList/ContainedList.js +17 -18
  35. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +16 -17
  36. package/es/components/ContentSwitcher/ContentSwitcher.d.ts +17 -29
  37. package/es/components/ContentSwitcher/ContentSwitcher.js +100 -126
  38. package/es/components/ContentSwitcher/index.d.ts +3 -4
  39. package/es/components/ContextMenu/useContextMenu.js +1 -2
  40. package/es/components/Copy/Copy.js +13 -14
  41. package/es/components/CopyButton/CopyButton.js +14 -15
  42. package/es/components/DangerButton/DangerButton.js +2 -2
  43. package/es/components/DataTable/DataTable.d.ts +81 -283
  44. package/es/components/DataTable/DataTable.js +124 -172
  45. package/es/components/DataTable/Table.d.ts +2 -2
  46. package/es/components/DataTable/Table.js +19 -22
  47. package/es/components/DataTable/TableActionList.d.ts +1 -1
  48. package/es/components/DataTable/TableBatchAction.js +9 -12
  49. package/es/components/DataTable/TableBatchActions.js +27 -29
  50. package/es/components/DataTable/TableBody.d.ts +3 -3
  51. package/es/components/DataTable/TableBody.js +9 -12
  52. package/es/components/DataTable/TableCell.d.ts +3 -4
  53. package/es/components/DataTable/TableCell.js +2 -2
  54. package/es/components/DataTable/TableContainer.d.ts +2 -3
  55. package/es/components/DataTable/TableContainer.js +15 -16
  56. package/es/components/DataTable/TableDecoratorRow.js +8 -9
  57. package/es/components/DataTable/TableExpandHeader.d.ts +2 -3
  58. package/es/components/DataTable/TableExpandHeader.js +18 -19
  59. package/es/components/DataTable/TableExpandRow.js +20 -21
  60. package/es/components/DataTable/TableExpandedRow.d.ts +3 -3
  61. package/es/components/DataTable/TableExpandedRow.js +10 -11
  62. package/es/components/DataTable/TableHead.d.ts +1 -1
  63. package/es/components/DataTable/TableHeader.d.ts +4 -4
  64. package/es/components/DataTable/TableHeader.js +29 -30
  65. package/es/components/DataTable/TableRow.d.ts +3 -4
  66. package/es/components/DataTable/TableRow.js +4 -4
  67. package/es/components/DataTable/TableSelectAll.js +14 -15
  68. package/es/components/DataTable/TableSelectRow.js +16 -17
  69. package/es/components/DataTable/TableSlugRow.js +7 -8
  70. package/es/components/DataTable/TableToolbar.js +9 -10
  71. package/es/components/DataTable/TableToolbarAction.js +2 -2
  72. package/es/components/DataTable/TableToolbarContent.d.ts +1 -1
  73. package/es/components/DataTable/TableToolbarMenu.js +10 -11
  74. package/es/components/DataTable/TableToolbarSearch.js +24 -26
  75. package/es/components/DataTable/index.d.ts +1 -1
  76. package/es/components/DataTable/state/sorting.js +3 -4
  77. package/es/components/DataTable/tools/filter.js +10 -12
  78. package/es/components/DataTable/tools/normalize.js +6 -8
  79. package/es/components/DataTable/tools/sorting.js +24 -30
  80. package/es/components/DataTableSkeleton/DataTableSkeleton.js +26 -27
  81. package/es/components/DatePicker/DatePicker.Skeleton.js +15 -16
  82. package/es/components/DatePicker/DatePicker.js +104 -81
  83. package/es/components/DatePickerInput/DatePickerInput.d.ts +3 -4
  84. package/es/components/DatePickerInput/DatePickerInput.js +24 -25
  85. package/es/components/Dialog/index.d.ts +194 -10
  86. package/es/components/Dialog/index.js +458 -39
  87. package/es/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
  88. package/es/components/Dropdown/Dropdown.Skeleton.js +10 -11
  89. package/es/components/Dropdown/Dropdown.d.ts +3 -3
  90. package/es/components/Dropdown/Dropdown.js +57 -60
  91. package/es/components/ErrorBoundary/ErrorBoundary.js +4 -4
  92. package/es/components/ExpandableSearch/ExpandableSearch.js +11 -12
  93. package/es/components/FeatureFlags/index.js +13 -14
  94. package/es/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
  95. package/es/components/FileUploader/FileUploader.Skeleton.js +9 -10
  96. package/es/components/FileUploader/FileUploader.d.ts +2 -3
  97. package/es/components/FileUploader/FileUploader.js +33 -35
  98. package/es/components/FileUploader/FileUploaderButton.d.ts +2 -3
  99. package/es/components/FileUploader/FileUploaderButton.js +20 -21
  100. package/es/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
  101. package/es/components/FileUploader/FileUploaderDropContainer.js +20 -21
  102. package/es/components/FileUploader/FileUploaderItem.d.ts +2 -3
  103. package/es/components/FileUploader/FileUploaderItem.js +26 -27
  104. package/es/components/FileUploader/Filename.d.ts +3 -4
  105. package/es/components/FileUploader/Filename.js +16 -17
  106. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +9 -10
  107. package/es/components/FluidComboBox/FluidComboBox.js +8 -9
  108. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +16 -17
  109. package/es/components/FluidDatePicker/FluidDatePicker.js +13 -14
  110. package/es/components/FluidDatePickerInput/FluidDatePickerInput.js +3 -3
  111. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +9 -10
  112. package/es/components/FluidDropdown/FluidDropdown.js +8 -9
  113. package/es/components/FluidForm/FluidForm.d.ts +3 -4
  114. package/es/components/FluidForm/FluidForm.js +8 -9
  115. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +9 -10
  116. package/es/components/FluidMultiSelect/FluidMultiSelect.js +10 -11
  117. package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +9 -10
  118. package/es/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  119. package/es/components/FluidNumberInput/FluidNumberInput.js +41 -8
  120. package/es/components/FluidSearch/FluidSearch.Skeleton.js +9 -10
  121. package/es/components/FluidSearch/FluidSearch.js +7 -8
  122. package/es/components/FluidSelect/FluidSelect.Skeleton.js +9 -10
  123. package/es/components/FluidSelect/FluidSelect.js +8 -9
  124. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +9 -10
  125. package/es/components/FluidTextArea/FluidTextArea.js +7 -8
  126. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +9 -10
  127. package/es/components/FluidTextInput/FluidTextInput.js +9 -10
  128. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +8 -9
  129. package/es/components/FluidTimePicker/FluidTimePicker.js +23 -24
  130. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +7 -8
  131. package/es/components/Form/Form.js +7 -8
  132. package/es/components/FormGroup/FormGroup.d.ts +3 -4
  133. package/es/components/FormGroup/FormGroup.js +15 -16
  134. package/es/components/FormItem/FormItem.js +7 -8
  135. package/es/components/FormLabel/FormLabel.js +8 -9
  136. package/es/components/Grid/CSSGrid.js +23 -25
  137. package/es/components/Grid/Column.js +32 -31
  138. package/es/components/Grid/ColumnHang.js +8 -9
  139. package/es/components/Grid/FlexGrid.js +12 -13
  140. package/es/components/Grid/Grid.js +3 -3
  141. package/es/components/Grid/GridContext.d.ts +2 -2
  142. package/es/components/Grid/GridContext.js +6 -7
  143. package/es/components/Grid/Row.js +10 -11
  144. package/es/components/Heading/index.js +13 -14
  145. package/es/components/Icon/Icon.Skeleton.js +6 -7
  146. package/es/components/IconButton/index.js +30 -26
  147. package/es/components/IconIndicator/index.js +10 -11
  148. package/es/components/IdPrefix/index.js +6 -7
  149. package/es/components/InlineCheckbox/InlineCheckbox.js +6 -6
  150. package/es/components/InlineLoading/InlineLoading.js +19 -20
  151. package/es/components/Layer/LayerContext.js +2 -2
  152. package/es/components/Layer/index.d.ts +4 -0
  153. package/es/components/Layer/index.js +21 -15
  154. package/es/components/Layout/index.js +24 -29
  155. package/es/components/LayoutDirection/LayoutDirection.js +10 -11
  156. package/es/components/LayoutDirection/LayoutDirectionContext.js +2 -2
  157. package/es/components/Link/Link.d.ts +1 -1
  158. package/es/components/Link/Link.js +19 -20
  159. package/es/components/ListBox/ListBox.d.ts +2 -3
  160. package/es/components/ListBox/ListBox.js +5 -5
  161. package/es/components/ListBox/ListBoxField.d.ts +3 -4
  162. package/es/components/ListBox/ListBoxField.js +8 -9
  163. package/es/components/ListBox/ListBoxMenu.d.ts +2 -3
  164. package/es/components/ListBox/ListBoxMenu.js +7 -8
  165. package/es/components/ListBox/ListBoxMenuIcon.js +8 -9
  166. package/es/components/ListBox/ListBoxMenuItem.d.ts +2 -3
  167. package/es/components/ListBox/ListBoxMenuItem.js +11 -13
  168. package/es/components/ListBox/ListBoxSelection.js +14 -15
  169. package/es/components/ListBox/next/ListBoxSelection.js +16 -17
  170. package/es/components/ListBox/next/ListBoxTrigger.js +8 -9
  171. package/es/components/ListItem/ListItem.js +7 -8
  172. package/es/components/Loading/Loading.d.ts +3 -3
  173. package/es/components/Loading/Loading.js +14 -15
  174. package/es/components/Menu/Menu.js +26 -27
  175. package/es/components/Menu/MenuItem.js +55 -60
  176. package/es/components/MenuButton/index.js +20 -22
  177. package/es/components/Modal/Modal.d.ts +2 -3
  178. package/es/components/Modal/Modal.js +85 -93
  179. package/es/components/ModalWrapper/ModalWrapper.js +9 -9
  180. package/es/components/MultiSelect/FilterableMultiSelect.js +68 -74
  181. package/es/components/MultiSelect/MultiSelect.js +65 -67
  182. package/es/components/MultiSelect/tools/sorting.js +11 -15
  183. package/es/components/Notification/Notification.js +137 -146
  184. package/es/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  185. package/es/components/NumberInput/NumberFormatPropTypes.js +40 -0
  186. package/es/components/NumberInput/NumberInput.Skeleton.js +10 -11
  187. package/es/components/NumberInput/NumberInput.d.ts +39 -3
  188. package/es/components/NumberInput/NumberInput.js +195 -65
  189. package/es/components/OrderedList/OrderedList.js +9 -10
  190. package/es/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  191. package/es/components/OverflowMenu/OverflowMenu.js +42 -48
  192. package/es/components/OverflowMenu/index.js +3 -3
  193. package/es/components/OverflowMenu/next/index.js +17 -18
  194. package/es/components/OverflowMenuItem/OverflowMenuItem.js +4 -4
  195. package/es/components/OverflowMenuV2/index.js +3 -3
  196. package/es/components/PageHeader/PageHeader.d.ts +29 -5
  197. package/es/components/PageHeader/PageHeader.js +136 -90
  198. package/es/components/Pagination/Pagination.Skeleton.js +12 -13
  199. package/es/components/Pagination/Pagination.js +40 -41
  200. package/es/components/Pagination/experimental/PageSelector.js +11 -12
  201. package/es/components/Pagination/experimental/Pagination.js +34 -35
  202. package/es/components/PaginationNav/PaginationNav.js +63 -68
  203. package/es/components/Popover/index.js +40 -42
  204. package/es/components/PrimaryButton/PrimaryButton.js +2 -2
  205. package/es/components/ProgressBar/ProgressBar.js +24 -25
  206. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +12 -13
  207. package/es/components/ProgressIndicator/ProgressIndicator.js +49 -52
  208. package/es/components/RadioButton/RadioButton.Skeleton.js +4 -4
  209. package/es/components/RadioButton/RadioButton.js +10 -10
  210. package/es/components/RadioButtonGroup/RadioButtonGroup.js +16 -16
  211. package/es/components/RadioTile/RadioTile.js +28 -29
  212. package/es/components/Search/Search.Skeleton.js +9 -10
  213. package/es/components/Search/Search.js +36 -38
  214. package/es/components/SecondaryButton/SecondaryButton.js +2 -2
  215. package/es/components/Select/Select.Skeleton.js +10 -11
  216. package/es/components/Select/Select.js +42 -43
  217. package/es/components/SelectItem/SelectItem.js +10 -11
  218. package/es/components/SelectItemGroup/SelectItemGroup.js +9 -10
  219. package/es/components/ShapeIndicator/index.js +13 -14
  220. package/es/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
  221. package/es/components/SkeletonIcon/SkeletonIcon.js +7 -12
  222. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +6 -7
  223. package/es/components/SkeletonText/SkeletonText.js +12 -13
  224. package/es/components/Slider/Slider.Skeleton.js +25 -26
  225. package/es/components/Slider/Slider.js +99 -113
  226. package/es/components/Slider/SliderHandles.js +20 -20
  227. package/es/components/Stack/HStack.js +2 -2
  228. package/es/components/Stack/Stack.js +2 -2
  229. package/es/components/Stack/VStack.js +2 -2
  230. package/es/components/StructuredList/StructuredList.Skeleton.js +17 -18
  231. package/es/components/StructuredList/StructuredList.js +24 -24
  232. package/es/components/Switch/IconSwitch.js +3 -3
  233. package/es/components/Switch/Switch.js +4 -4
  234. package/es/components/TabContent/TabContent.js +2 -2
  235. package/es/components/Tabs/Tabs.Skeleton.js +12 -13
  236. package/es/components/Tabs/Tabs.js +141 -156
  237. package/es/components/Tabs/usePressable.js +7 -8
  238. package/es/components/Tag/DismissibleTag.js +26 -27
  239. package/es/components/Tag/OperationalTag.js +16 -17
  240. package/es/components/Tag/SelectableTag.js +19 -20
  241. package/es/components/Tag/Tag.Skeleton.js +7 -8
  242. package/es/components/Tag/Tag.js +33 -34
  243. package/es/components/Text/Text.js +9 -10
  244. package/es/components/Text/TextDirection.js +7 -8
  245. package/es/components/Text/createTextComponent.js +2 -2
  246. package/es/components/TextArea/TextArea.Skeleton.js +4 -4
  247. package/es/components/TextArea/TextArea.js +22 -22
  248. package/es/components/TextInput/ControlledPasswordInput.d.ts +2 -3
  249. package/es/components/TextInput/ControlledPasswordInput.js +36 -37
  250. package/es/components/TextInput/PasswordInput.js +40 -41
  251. package/es/components/TextInput/TextInput.Skeleton.js +9 -10
  252. package/es/components/TextInput/TextInput.js +43 -44
  253. package/es/components/TextInput/util.js +14 -17
  254. package/es/components/Theme/index.js +19 -21
  255. package/es/components/Tile/Tile.js +98 -104
  256. package/es/components/TileGroup/TileGroup.d.ts +3 -4
  257. package/es/components/TileGroup/TileGroup.js +8 -8
  258. package/es/components/TimePicker/TimePicker.d.ts +2 -3
  259. package/es/components/TimePicker/TimePicker.js +14 -14
  260. package/es/components/TimePickerSelect/TimePickerSelect.js +4 -4
  261. package/es/components/Toggle/Toggle.Skeleton.js +8 -9
  262. package/es/components/Toggle/Toggle.js +27 -28
  263. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +14 -15
  264. package/es/components/Toggletip/index.js +43 -49
  265. package/es/components/Tooltip/DefinitionTooltip.js +17 -18
  266. package/es/components/Tooltip/Tooltip.d.ts +3 -0
  267. package/es/components/Tooltip/Tooltip.js +39 -28
  268. package/es/components/TreeView/TreeNode.js +64 -56
  269. package/es/components/TreeView/TreeView.js +44 -37
  270. package/es/components/UIShell/Content.js +8 -9
  271. package/es/components/UIShell/Header.js +7 -8
  272. package/es/components/UIShell/HeaderContainer.js +7 -8
  273. package/es/components/UIShell/HeaderGlobalAction.js +14 -15
  274. package/es/components/UIShell/HeaderGlobalBar.d.ts +1 -1
  275. package/es/components/UIShell/HeaderMenu.d.ts +10 -112
  276. package/es/components/UIShell/HeaderMenu.js +154 -201
  277. package/es/components/UIShell/HeaderMenuButton.js +14 -15
  278. package/es/components/UIShell/HeaderMenuItem.js +21 -20
  279. package/es/components/UIShell/HeaderName.js +9 -10
  280. package/es/components/UIShell/HeaderNavigation.js +10 -11
  281. package/es/components/UIShell/HeaderPanel.js +11 -12
  282. package/es/components/UIShell/HeaderSideNavItems.js +7 -8
  283. package/es/components/UIShell/Link.js +11 -12
  284. package/es/components/UIShell/SideNav.js +30 -32
  285. package/es/components/UIShell/SideNavDetails.js +9 -10
  286. package/es/components/UIShell/SideNavDivider.js +6 -7
  287. package/es/components/UIShell/SideNavFooter.js +13 -14
  288. package/es/components/UIShell/SideNavHeader.js +8 -9
  289. package/es/components/UIShell/SideNavIcon.js +7 -8
  290. package/es/components/UIShell/SideNavItem.js +7 -8
  291. package/es/components/UIShell/SideNavItems.js +10 -11
  292. package/es/components/UIShell/SideNavLink.js +15 -16
  293. package/es/components/UIShell/SideNavLinkText.js +7 -8
  294. package/es/components/UIShell/SideNavMenu.js +20 -21
  295. package/es/components/UIShell/SideNavMenuItem.js +5 -5
  296. package/es/components/UIShell/SideNavSwitcher.js +8 -8
  297. package/es/components/UIShell/SkipToContent.js +9 -10
  298. package/es/components/UIShell/Switcher.js +12 -13
  299. package/es/components/UIShell/SwitcherDivider.js +6 -7
  300. package/es/components/UIShell/SwitcherItem.js +3 -3
  301. package/es/components/UnorderedList/UnorderedList.js +8 -9
  302. package/es/index.js +25 -26
  303. package/es/internal/FloatingMenu.js +30 -32
  304. package/es/internal/Selection.js +15 -17
  305. package/{lib/feature-flags.d.ts → es/internal/__mocks__/mockHTMLElement.d.ts} +4 -2
  306. package/es/internal/createClassWrapper.js +2 -2
  307. package/es/internal/getAnnouncement.d.ts +8 -0
  308. package/es/internal/getAnnouncement.js +22 -0
  309. package/es/internal/keyboard/match.js +6 -7
  310. package/es/internal/useControllableState.d.ts +1 -1
  311. package/es/internal/useControllableState.js +8 -9
  312. package/es/internal/useDelayedState.js +1 -2
  313. package/es/internal/useDocumentLang.d.ts +12 -0
  314. package/es/internal/useId.js +4 -6
  315. package/es/internal/useIdPrefix.js +3 -3
  316. package/es/internal/useMatchMedia.js +1 -2
  317. package/es/internal/useMergedRefs.d.ts +1 -1
  318. package/es/internal/useNoInteractiveChildren.js +2 -4
  319. package/es/internal/useNormalizedInputProps.js +12 -13
  320. package/es/internal/usePrefix.js +3 -3
  321. package/es/internal/useResizeObserver.d.ts +14 -0
  322. package/es/internal/useResizeObserver.js +73 -0
  323. package/es/internal/useSavedCallback.js +1 -3
  324. package/es/internal/wrapFocus.js +23 -35
  325. package/es/prop-types/deprecate.js +1 -4
  326. package/es/prop-types/deprecateValuesWithin.js +1 -4
  327. package/es/prop-types/isRequiredOneOf.js +1 -4
  328. package/es/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  329. package/es/tools/events.js +1 -4
  330. package/es/tools/mergeRefs.js +9 -14
  331. package/es/tools/uniqueId.js +1 -2
  332. package/es/tools/wrapComponent.d.ts +3 -4
  333. package/es/tools/wrapComponent.js +11 -13
  334. package/es/types/common.d.ts +0 -2
  335. package/lib/components/AILabel/index.js +27 -30
  336. package/lib/components/AISkeleton/AISkeletonIcon.js +4 -5
  337. package/lib/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  338. package/lib/components/AISkeleton/AISkeletonText.js +4 -5
  339. package/lib/components/Accordion/Accordion.Skeleton.js +9 -10
  340. package/lib/components/Accordion/Accordion.js +10 -11
  341. package/lib/components/Accordion/AccordionItem.js +13 -14
  342. package/lib/components/Accordion/AccordionProvider.js +4 -5
  343. package/lib/components/AspectRatio/AspectRatio.js +7 -8
  344. package/lib/components/BadgeIndicator/index.js +5 -6
  345. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  346. package/lib/components/Button/Button.Skeleton.js +7 -8
  347. package/lib/components/Button/ButtonBase.js +23 -24
  348. package/lib/components/ChatButton/ChatButton.Skeleton.js +5 -6
  349. package/lib/components/ChatButton/ChatButton.js +11 -12
  350. package/lib/components/Checkbox/Checkbox.Skeleton.js +4 -5
  351. package/lib/components/Checkbox/Checkbox.js +19 -20
  352. package/lib/components/CheckboxGroup/CheckboxGroup.js +16 -17
  353. package/lib/components/ClassPrefix/index.js +4 -5
  354. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  355. package/lib/components/CodeSnippet/CodeSnippet.js +27 -29
  356. package/lib/components/ComboBox/ComboBox.js +24 -30
  357. package/lib/components/ComboBox/tools/filter.js +9 -12
  358. package/lib/components/ComboButton/index.js +16 -18
  359. package/lib/components/ComposedModal/ComposedModal.js +31 -34
  360. package/lib/components/ComposedModal/ModalFooter.js +37 -42
  361. package/lib/components/ComposedModal/ModalHeader.js +14 -15
  362. package/lib/components/ContainedList/ContainedList.js +10 -11
  363. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  364. package/lib/components/ContentSwitcher/ContentSwitcher.d.ts +17 -29
  365. package/lib/components/ContentSwitcher/ContentSwitcher.js +98 -124
  366. package/lib/components/ContentSwitcher/index.d.ts +3 -4
  367. package/lib/components/ContextMenu/useContextMenu.js +1 -2
  368. package/lib/components/Copy/Copy.js +11 -12
  369. package/lib/components/CopyButton/CopyButton.js +10 -11
  370. package/lib/components/DataTable/DataTable.d.ts +81 -283
  371. package/lib/components/DataTable/DataTable.js +123 -172
  372. package/lib/components/DataTable/Table.d.ts +2 -2
  373. package/lib/components/DataTable/Table.js +15 -18
  374. package/lib/components/DataTable/TableActionList.d.ts +1 -1
  375. package/lib/components/DataTable/TableBatchAction.js +8 -11
  376. package/lib/components/DataTable/TableBatchActions.js +18 -20
  377. package/lib/components/DataTable/TableBody.d.ts +3 -3
  378. package/lib/components/DataTable/TableBody.js +8 -11
  379. package/lib/components/DataTable/TableCell.d.ts +3 -4
  380. package/lib/components/DataTable/TableContainer.d.ts +2 -3
  381. package/lib/components/DataTable/TableContainer.js +9 -10
  382. package/lib/components/DataTable/TableDecoratorRow.js +4 -5
  383. package/lib/components/DataTable/TableExpandHeader.d.ts +2 -3
  384. package/lib/components/DataTable/TableExpandHeader.js +14 -15
  385. package/lib/components/DataTable/TableExpandRow.js +13 -14
  386. package/lib/components/DataTable/TableExpandedRow.d.ts +3 -3
  387. package/lib/components/DataTable/TableExpandedRow.js +6 -7
  388. package/lib/components/DataTable/TableHead.d.ts +1 -1
  389. package/lib/components/DataTable/TableHeader.d.ts +4 -4
  390. package/lib/components/DataTable/TableHeader.js +15 -16
  391. package/lib/components/DataTable/TableRow.d.ts +3 -4
  392. package/lib/components/DataTable/TableSelectAll.js +11 -12
  393. package/lib/components/DataTable/TableSelectRow.js +12 -13
  394. package/lib/components/DataTable/TableSlugRow.js +4 -5
  395. package/lib/components/DataTable/TableToolbar.js +7 -8
  396. package/lib/components/DataTable/TableToolbarContent.d.ts +1 -1
  397. package/lib/components/DataTable/TableToolbarMenu.js +8 -9
  398. package/lib/components/DataTable/TableToolbarSearch.js +22 -24
  399. package/lib/components/DataTable/index.d.ts +1 -1
  400. package/lib/components/DataTable/state/sorting.js +3 -4
  401. package/lib/components/DataTable/tools/filter.js +10 -12
  402. package/lib/components/DataTable/tools/normalize.js +6 -8
  403. package/lib/components/DataTable/tools/sorting.js +24 -30
  404. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  405. package/lib/components/DatePicker/DatePicker.Skeleton.js +7 -8
  406. package/lib/components/DatePicker/DatePicker.js +87 -64
  407. package/lib/components/DatePickerInput/DatePickerInput.d.ts +3 -4
  408. package/lib/components/DatePickerInput/DatePickerInput.js +5 -6
  409. package/lib/components/Dialog/index.d.ts +194 -10
  410. package/lib/components/Dialog/index.js +457 -33
  411. package/lib/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
  412. package/lib/components/Dropdown/Dropdown.Skeleton.js +6 -7
  413. package/lib/components/Dropdown/Dropdown.d.ts +3 -3
  414. package/lib/components/Dropdown/Dropdown.js +40 -43
  415. package/lib/components/ErrorBoundary/ErrorBoundary.js +2 -2
  416. package/lib/components/ExpandableSearch/ExpandableSearch.js +9 -10
  417. package/lib/components/FeatureFlags/index.js +11 -12
  418. package/lib/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
  419. package/lib/components/FileUploader/FileUploader.Skeleton.js +4 -5
  420. package/lib/components/FileUploader/FileUploader.d.ts +2 -3
  421. package/lib/components/FileUploader/FileUploader.js +22 -24
  422. package/lib/components/FileUploader/FileUploaderButton.d.ts +2 -3
  423. package/lib/components/FileUploader/FileUploaderButton.js +16 -17
  424. package/lib/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
  425. package/lib/components/FileUploader/FileUploaderDropContainer.js +15 -16
  426. package/lib/components/FileUploader/FileUploaderItem.d.ts +2 -3
  427. package/lib/components/FileUploader/FileUploaderItem.js +13 -14
  428. package/lib/components/FileUploader/Filename.d.ts +3 -4
  429. package/lib/components/FileUploader/Filename.js +9 -10
  430. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  431. package/lib/components/FluidComboBox/FluidComboBox.js +5 -6
  432. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  433. package/lib/components/FluidDatePicker/FluidDatePicker.js +10 -11
  434. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  435. package/lib/components/FluidDropdown/FluidDropdown.js +5 -6
  436. package/lib/components/FluidForm/FluidForm.d.ts +3 -4
  437. package/lib/components/FluidForm/FluidForm.js +5 -6
  438. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  439. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  440. package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  441. package/lib/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  442. package/lib/components/FluidNumberInput/FluidNumberInput.js +38 -5
  443. package/lib/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  444. package/lib/components/FluidSearch/FluidSearch.js +4 -5
  445. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  446. package/lib/components/FluidSelect/FluidSelect.js +5 -6
  447. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  448. package/lib/components/FluidTextArea/FluidTextArea.js +4 -5
  449. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  450. package/lib/components/FluidTextInput/FluidTextInput.js +5 -6
  451. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  452. package/lib/components/FluidTimePicker/FluidTimePicker.js +11 -12
  453. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  454. package/lib/components/Form/Form.js +5 -6
  455. package/lib/components/FormGroup/FormGroup.d.ts +3 -4
  456. package/lib/components/FormGroup/FormGroup.js +11 -12
  457. package/lib/components/FormItem/FormItem.js +5 -6
  458. package/lib/components/FormLabel/FormLabel.js +6 -7
  459. package/lib/components/Grid/CSSGrid.js +17 -19
  460. package/lib/components/Grid/Column.js +28 -27
  461. package/lib/components/Grid/ColumnHang.js +6 -7
  462. package/lib/components/Grid/FlexGrid.js +9 -10
  463. package/lib/components/Grid/GridContext.d.ts +2 -2
  464. package/lib/components/Grid/GridContext.js +10 -29
  465. package/lib/components/Grid/Row.js +8 -9
  466. package/lib/components/Heading/index.js +5 -6
  467. package/lib/components/Icon/Icon.Skeleton.js +4 -5
  468. package/lib/components/IconButton/index.js +26 -22
  469. package/lib/components/IconIndicator/index.js +7 -8
  470. package/lib/components/IdPrefix/index.js +4 -5
  471. package/lib/components/InlineLoading/InlineLoading.js +9 -10
  472. package/lib/components/Layer/index.d.ts +4 -0
  473. package/lib/components/Layer/index.js +16 -10
  474. package/lib/components/Layout/index.js +21 -26
  475. package/lib/components/LayoutDirection/LayoutDirection.js +6 -7
  476. package/lib/components/Link/Link.d.ts +1 -1
  477. package/lib/components/Link/Link.js +15 -16
  478. package/lib/components/ListBox/ListBox.d.ts +2 -3
  479. package/lib/components/ListBox/ListBoxField.d.ts +3 -4
  480. package/lib/components/ListBox/ListBoxField.js +6 -7
  481. package/lib/components/ListBox/ListBoxMenu.d.ts +2 -3
  482. package/lib/components/ListBox/ListBoxMenu.js +5 -6
  483. package/lib/components/ListBox/ListBoxMenuIcon.js +4 -5
  484. package/lib/components/ListBox/ListBoxMenuItem.d.ts +2 -3
  485. package/lib/components/ListBox/ListBoxMenuItem.js +8 -10
  486. package/lib/components/ListBox/ListBoxSelection.js +8 -9
  487. package/lib/components/ListBox/next/ListBoxSelection.js +9 -10
  488. package/lib/components/ListBox/next/ListBoxTrigger.js +5 -6
  489. package/lib/components/ListItem/ListItem.js +5 -6
  490. package/lib/components/Loading/Loading.d.ts +3 -3
  491. package/lib/components/Loading/Loading.js +8 -9
  492. package/lib/components/Menu/Menu.js +23 -24
  493. package/lib/components/Menu/MenuItem.js +39 -44
  494. package/lib/components/MenuButton/index.js +16 -18
  495. package/lib/components/Modal/Modal.d.ts +2 -3
  496. package/lib/components/Modal/Modal.js +55 -63
  497. package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
  498. package/lib/components/MultiSelect/FilterableMultiSelect.js +46 -52
  499. package/lib/components/MultiSelect/MultiSelect.js +43 -45
  500. package/lib/components/MultiSelect/tools/sorting.js +11 -15
  501. package/lib/components/Notification/Notification.js +96 -105
  502. package/lib/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  503. package/lib/components/NumberInput/NumberFormatPropTypes.js +48 -0
  504. package/lib/components/NumberInput/NumberInput.Skeleton.js +6 -7
  505. package/lib/components/NumberInput/NumberInput.d.ts +39 -3
  506. package/lib/components/NumberInput/NumberInput.js +173 -43
  507. package/lib/components/OrderedList/OrderedList.js +7 -8
  508. package/lib/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  509. package/lib/components/OverflowMenu/OverflowMenu.js +35 -41
  510. package/lib/components/OverflowMenu/next/index.js +12 -13
  511. package/lib/components/PageHeader/PageHeader.d.ts +29 -5
  512. package/lib/components/PageHeader/PageHeader.js +119 -73
  513. package/lib/components/Pagination/Pagination.Skeleton.js +4 -5
  514. package/lib/components/Pagination/Pagination.js +24 -25
  515. package/lib/components/Pagination/experimental/PageSelector.js +8 -9
  516. package/lib/components/Pagination/experimental/Pagination.js +20 -21
  517. package/lib/components/PaginationNav/PaginationNav.js +33 -38
  518. package/lib/components/Popover/index.js +26 -28
  519. package/lib/components/ProgressBar/ProgressBar.js +11 -12
  520. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  521. package/lib/components/ProgressIndicator/ProgressIndicator.js +29 -32
  522. package/lib/components/RadioTile/RadioTile.js +17 -18
  523. package/lib/components/Search/Search.Skeleton.js +5 -6
  524. package/lib/components/Search/Search.js +26 -28
  525. package/lib/components/Select/Select.Skeleton.js +5 -6
  526. package/lib/components/Select/Select.js +24 -25
  527. package/lib/components/SelectItem/SelectItem.js +8 -9
  528. package/lib/components/SelectItemGroup/SelectItemGroup.js +7 -8
  529. package/lib/components/ShapeIndicator/index.js +7 -8
  530. package/lib/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
  531. package/lib/components/SkeletonIcon/SkeletonIcon.js +5 -10
  532. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  533. package/lib/components/SkeletonText/SkeletonText.js +8 -9
  534. package/lib/components/Slider/Slider.Skeleton.js +8 -9
  535. package/lib/components/Slider/Slider.js +69 -83
  536. package/lib/components/Slider/SliderHandles.js +6 -6
  537. package/lib/components/StructuredList/StructuredList.Skeleton.js +5 -6
  538. package/lib/components/Tabs/Tabs.Skeleton.js +5 -6
  539. package/lib/components/Tabs/Tabs.js +83 -98
  540. package/lib/components/Tabs/usePressable.js +7 -8
  541. package/lib/components/Tag/DismissibleTag.js +16 -17
  542. package/lib/components/Tag/OperationalTag.js +10 -11
  543. package/lib/components/Tag/SelectableTag.js +13 -14
  544. package/lib/components/Tag/Tag.Skeleton.js +5 -6
  545. package/lib/components/Tag/Tag.js +19 -20
  546. package/lib/components/Text/Text.js +6 -7
  547. package/lib/components/Text/TextDirection.js +5 -6
  548. package/lib/components/TextArea/TextArea.js +3 -3
  549. package/lib/components/TextInput/ControlledPasswordInput.d.ts +2 -3
  550. package/lib/components/TextInput/ControlledPasswordInput.js +24 -25
  551. package/lib/components/TextInput/PasswordInput.js +26 -27
  552. package/lib/components/TextInput/TextInput.Skeleton.js +5 -6
  553. package/lib/components/TextInput/TextInput.js +27 -28
  554. package/lib/components/TextInput/util.js +14 -17
  555. package/lib/components/Theme/index.js +10 -12
  556. package/lib/components/Tile/Tile.js +68 -74
  557. package/lib/components/TileGroup/TileGroup.d.ts +3 -4
  558. package/lib/components/TimePicker/TimePicker.d.ts +2 -3
  559. package/lib/components/Toggle/Toggle.Skeleton.js +4 -5
  560. package/lib/components/Toggle/Toggle.js +17 -18
  561. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  562. package/lib/components/Toggletip/index.js +33 -39
  563. package/lib/components/Tooltip/DefinitionTooltip.js +13 -14
  564. package/lib/components/Tooltip/Tooltip.d.ts +3 -0
  565. package/lib/components/Tooltip/Tooltip.js +33 -22
  566. package/lib/components/TreeView/TreeNode.js +40 -32
  567. package/lib/components/TreeView/TreeView.js +41 -34
  568. package/lib/components/UIShell/Content.js +6 -7
  569. package/lib/components/UIShell/Header.js +5 -6
  570. package/lib/components/UIShell/HeaderContainer.js +5 -6
  571. package/lib/components/UIShell/HeaderGlobalAction.js +12 -13
  572. package/lib/components/UIShell/HeaderGlobalBar.d.ts +1 -1
  573. package/lib/components/UIShell/HeaderMenu.d.ts +10 -112
  574. package/lib/components/UIShell/HeaderMenu.js +152 -199
  575. package/lib/components/UIShell/HeaderMenuButton.js +10 -11
  576. package/lib/components/UIShell/HeaderMenuItem.js +17 -16
  577. package/lib/components/UIShell/HeaderName.js +6 -7
  578. package/lib/components/UIShell/HeaderNavigation.js +7 -8
  579. package/lib/components/UIShell/HeaderPanel.js +9 -10
  580. package/lib/components/UIShell/HeaderSideNavItems.js +5 -6
  581. package/lib/components/UIShell/Link.js +8 -9
  582. package/lib/components/UIShell/SideNav.js +23 -25
  583. package/lib/components/UIShell/SideNavDetails.js +6 -7
  584. package/lib/components/UIShell/SideNavDivider.js +3 -4
  585. package/lib/components/UIShell/SideNavFooter.js +6 -7
  586. package/lib/components/UIShell/SideNavHeader.js +5 -6
  587. package/lib/components/UIShell/SideNavIcon.js +5 -6
  588. package/lib/components/UIShell/SideNavItem.js +5 -6
  589. package/lib/components/UIShell/SideNavItems.js +5 -6
  590. package/lib/components/UIShell/SideNavLink.js +10 -11
  591. package/lib/components/UIShell/SideNavLinkText.js +5 -6
  592. package/lib/components/UIShell/SideNavMenu.js +11 -12
  593. package/lib/components/UIShell/SkipToContent.js +7 -8
  594. package/lib/components/UIShell/Switcher.js +4 -5
  595. package/lib/components/UIShell/SwitcherDivider.js +4 -5
  596. package/lib/components/UnorderedList/UnorderedList.js +6 -7
  597. package/lib/index.js +81 -82
  598. package/lib/internal/FloatingMenu.js +26 -28
  599. package/lib/internal/Selection.js +15 -17
  600. package/{es/feature-flags.d.ts → lib/internal/__mocks__/mockHTMLElement.d.ts} +4 -2
  601. package/lib/internal/getAnnouncement.d.ts +8 -0
  602. package/lib/internal/getAnnouncement.js +26 -0
  603. package/lib/internal/keyboard/match.js +6 -7
  604. package/lib/internal/useControllableState.d.ts +1 -1
  605. package/lib/internal/useControllableState.js +8 -9
  606. package/lib/internal/useDelayedState.js +1 -2
  607. package/lib/internal/useDocumentLang.d.ts +12 -0
  608. package/lib/internal/useId.js +2 -4
  609. package/lib/internal/useMatchMedia.js +1 -2
  610. package/lib/internal/useMergedRefs.d.ts +1 -1
  611. package/lib/internal/useNoInteractiveChildren.js +2 -4
  612. package/lib/internal/useNormalizedInputProps.js +9 -10
  613. package/lib/internal/useResizeObserver.d.ts +14 -0
  614. package/lib/internal/useResizeObserver.js +77 -0
  615. package/lib/internal/useSavedCallback.js +1 -3
  616. package/lib/internal/wrapFocus.js +23 -35
  617. package/lib/prop-types/deprecate.js +1 -4
  618. package/lib/prop-types/deprecateValuesWithin.js +1 -4
  619. package/lib/prop-types/isRequiredOneOf.js +1 -4
  620. package/lib/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  621. package/lib/tools/events.js +1 -4
  622. package/lib/tools/mergeRefs.js +9 -14
  623. package/lib/tools/uniqueId.js +1 -2
  624. package/lib/tools/wrapComponent.d.ts +3 -4
  625. package/lib/tools/wrapComponent.js +9 -11
  626. package/lib/types/common.d.ts +0 -2
  627. package/package.json +21 -20
  628. package/scss/components/content-switcher/_tokens.scss +9 -0
  629. package/telemetry.yml +27 -2
  630. package/es/components/ContentSwitcher/index.js +0 -13
  631. package/es/components/DataTable/index.js +0 -76
  632. package/es/internal/useAnnouncer.js +0 -21
  633. package/lib/components/ContentSwitcher/index.js +0 -18
  634. package/lib/components/DataTable/index.js +0 -82
  635. package/lib/internal/useAnnouncer.js +0 -25
@@ -38,14 +38,13 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
38
38
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
39
39
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
40
40
 
41
- const ModalBody = /*#__PURE__*/React__default["default"].forwardRef(function ModalBody(_ref, ref) {
42
- let {
43
- className: customClassName,
44
- children,
45
- hasForm,
46
- hasScrollingContent,
47
- ...rest
48
- } = _ref;
41
+ const ModalBody = /*#__PURE__*/React__default["default"].forwardRef(function ModalBody({
42
+ className: customClassName,
43
+ children,
44
+ hasForm,
45
+ hasScrollingContent,
46
+ ...rest
47
+ }, ref) {
49
48
  const prefix = usePrefix.usePrefix();
50
49
  const contentRef = React.useRef(null);
51
50
  const [isScrollable, setIsScrollable] = React.useState(false);
@@ -103,27 +102,26 @@ ModalBody.propTypes = {
103
102
  */
104
103
  hasScrollingContent: PropTypes__default["default"].bool
105
104
  };
106
- const ComposedModal = /*#__PURE__*/React__default["default"].forwardRef(function ComposedModal(_ref2, ref) {
107
- let {
108
- ['aria-labelledby']: ariaLabelledBy,
109
- ['aria-label']: ariaLabel,
110
- children,
111
- className: customClassName,
112
- containerClassName,
113
- danger,
114
- decorator,
115
- isFullWidth,
116
- onClose,
117
- onKeyDown,
118
- open,
119
- preventCloseOnClickOutside,
120
- selectorPrimaryFocus = '[data-modal-primary-focus]',
121
- selectorsFloatingMenus,
122
- size,
123
- launcherButtonRef,
124
- slug,
125
- ...rest
126
- } = _ref2;
105
+ const ComposedModal = /*#__PURE__*/React__default["default"].forwardRef(function ComposedModal({
106
+ ['aria-labelledby']: ariaLabelledBy,
107
+ ['aria-label']: ariaLabel,
108
+ children,
109
+ className: customClassName,
110
+ containerClassName,
111
+ danger,
112
+ decorator,
113
+ isFullWidth,
114
+ onClose,
115
+ onKeyDown,
116
+ open,
117
+ preventCloseOnClickOutside,
118
+ selectorPrimaryFocus = '[data-modal-primary-focus]',
119
+ selectorsFloatingMenus,
120
+ size,
121
+ launcherButtonRef,
122
+ slug,
123
+ ...rest
124
+ }, ref) {
127
125
  const prefix = usePrefix.usePrefix();
128
126
  const [isOpen, setIsOpen] = React.useState(!!open);
129
127
  const [wasOpen, setWasOpen] = React.useState(!!open);
@@ -184,11 +182,10 @@ const ComposedModal = /*#__PURE__*/React__default["default"].forwardRef(function
184
182
  closeModal(evt);
185
183
  }
186
184
  }
187
- function handleBlur(_ref3) {
188
- let {
189
- target: oldActiveNode,
190
- relatedTarget: currentActiveNode
191
- } = _ref3;
185
+ function handleBlur({
186
+ target: oldActiveNode,
187
+ relatedTarget: currentActiveNode
188
+ }) {
192
189
  if (open && currentActiveNode && oldActiveNode && innerModal.current) {
193
190
  const {
194
191
  current: bodyNode
@@ -26,32 +26,28 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
26
26
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
27
27
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
28
28
 
29
- function SecondaryButtonSet(_ref) {
30
- let {
31
- secondaryButtons,
32
- secondaryButtonText,
33
- secondaryClassName,
34
- closeModal,
35
- onRequestClose,
36
- disabled
37
- } = _ref;
29
+ function SecondaryButtonSet({
30
+ secondaryButtons,
31
+ secondaryButtonText,
32
+ secondaryClassName,
33
+ closeModal,
34
+ onRequestClose,
35
+ disabled
36
+ }) {
38
37
  function handleRequestClose(evt) {
39
38
  closeModal(evt);
40
39
  onRequestClose(evt);
41
40
  }
42
41
  if (Array.isArray(secondaryButtons) && secondaryButtons.length <= 2) {
43
- return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, secondaryButtons.map((_ref2, i) => {
44
- let {
45
- buttonText,
46
- onClick: onButtonClick
47
- } = _ref2;
48
- return /*#__PURE__*/React__default["default"].createElement(Button["default"], {
49
- key: `${buttonText}-${i}`,
50
- className: secondaryClassName,
51
- kind: "secondary",
52
- onClick: onButtonClick || handleRequestClose
53
- }, buttonText);
54
- }));
42
+ return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, secondaryButtons.map(({
43
+ buttonText,
44
+ onClick: onButtonClick
45
+ }, i) => /*#__PURE__*/React__default["default"].createElement(Button["default"], {
46
+ key: `${buttonText}-${i}`,
47
+ className: secondaryClassName,
48
+ kind: "secondary",
49
+ onClick: onButtonClick || handleRequestClose
50
+ }, buttonText)));
55
51
  }
56
52
  if (secondaryButtonText) {
57
53
  return /*#__PURE__*/React__default["default"].createElement(Button["default"], {
@@ -85,27 +81,26 @@ SecondaryButtonSet.propTypes = {
85
81
  },
86
82
  secondaryClassName: PropTypes__default["default"].string
87
83
  };
88
- const ModalFooter = /*#__PURE__*/React__default["default"].forwardRef(function ModalFooter(_ref3, ref) {
89
- let {
90
- children,
91
- className: customClassName,
92
- closeModal = noopFn.noopFn,
93
- danger,
94
- inputref,
95
- onRequestClose = noopFn.noopFn,
96
- onRequestSubmit = noopFn.noopFn,
97
- primaryButtonDisabled,
98
- primaryButtonText,
99
- primaryClassName,
100
- secondaryButtonText,
101
- secondaryButtons,
102
- secondaryClassName,
103
- loadingStatus = 'inactive',
104
- loadingDescription,
105
- loadingIconDescription,
106
- onLoadingSuccess = noopFn.noopFn,
107
- ...rest
108
- } = _ref3;
84
+ const ModalFooter = /*#__PURE__*/React__default["default"].forwardRef(function ModalFooter({
85
+ children,
86
+ className: customClassName,
87
+ closeModal = noopFn.noopFn,
88
+ danger,
89
+ inputref,
90
+ onRequestClose = noopFn.noopFn,
91
+ onRequestSubmit = noopFn.noopFn,
92
+ primaryButtonDisabled,
93
+ primaryButtonText,
94
+ primaryClassName,
95
+ secondaryButtonText,
96
+ secondaryButtons,
97
+ secondaryClassName,
98
+ loadingStatus = 'inactive',
99
+ loadingDescription,
100
+ loadingIconDescription,
101
+ onLoadingSuccess = noopFn.noopFn,
102
+ ...rest
103
+ }, ref) {
109
104
  const prefix = usePrefix.usePrefix();
110
105
  const footerClass = cx__default["default"](`${prefix}--modal-footer`, customClassName, Array.isArray(secondaryButtons) && secondaryButtons.length === 2 ? `${prefix}--modal-footer--three-button` : null);
111
106
  const primaryButtonClass = cx__default["default"](primaryClassName, loadingStatus !== 'inactive' ? `${prefix}--btn--loading` : null);
@@ -23,21 +23,20 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
23
23
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
24
24
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
25
25
 
26
- const ModalHeader = /*#__PURE__*/React__default["default"].forwardRef(function ModalHeader(_ref, ref) {
27
- let {
28
- buttonOnClick,
29
- children,
30
- className: customClassName,
31
- closeClassName,
32
- closeIconClassName,
33
- closeModal,
34
- iconDescription = 'Close',
35
- label,
36
- labelClassName,
37
- title,
38
- titleClassName,
39
- ...rest
40
- } = _ref;
26
+ const ModalHeader = /*#__PURE__*/React__default["default"].forwardRef(function ModalHeader({
27
+ buttonOnClick,
28
+ children,
29
+ className: customClassName,
30
+ closeClassName,
31
+ closeIconClassName,
32
+ closeModal,
33
+ iconDescription = 'Close',
34
+ label,
35
+ labelClassName,
36
+ title,
37
+ titleClassName,
38
+ ...rest
39
+ }, ref) {
41
40
  const prefix = usePrefix.usePrefix();
42
41
  function handleCloseButtonClick(evt) {
43
42
  closeModal?.(evt);
@@ -48,17 +48,16 @@ function renderChildren(children) {
48
48
  }
49
49
  return children;
50
50
  }
51
- const ContainedList = _ref => {
52
- let {
53
- action,
54
- children,
55
- className,
56
- isInset,
57
- kind = variants[0],
58
- label,
59
- size,
60
- ...rest
61
- } = _ref;
51
+ const ContainedList = ({
52
+ action,
53
+ children,
54
+ className,
55
+ isInset,
56
+ kind = variants[0],
57
+ label,
58
+ size,
59
+ ...rest
60
+ }) => {
62
61
  const labelId = `${useId.useId('contained-list')}-header`;
63
62
  const prefix = usePrefix.usePrefix();
64
63
  const classes = cx__default["default"](`${prefix}--contained-list`, {
@@ -22,16 +22,15 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
22
22
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
23
23
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
24
24
 
25
- const ContainedListItem = _ref => {
26
- let {
27
- action,
28
- children,
29
- className,
30
- disabled = false,
31
- onClick,
32
- renderIcon: IconElement,
33
- ...rest
34
- } = _ref;
25
+ const ContainedListItem = ({
26
+ action,
27
+ children,
28
+ className,
29
+ disabled = false,
30
+ onClick,
31
+ renderIcon: IconElement,
32
+ ...rest
33
+ }) => {
35
34
  const prefix = usePrefix.usePrefix();
36
35
  const isClickable = onClick !== undefined;
37
36
  const classes = cx__default["default"](`${prefix}--contained-list-item`, className, {
@@ -1,11 +1,11 @@
1
1
  /**
2
- * Copyright IBM Corp. 2016, 2023
2
+ * Copyright IBM Corp. 2016, 2025
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
  import PropTypes from 'prop-types';
8
- import React, { HTMLAttributes, ReactElement } from 'react';
8
+ import { type HTMLAttributes, type ReactElement } from 'react';
9
9
  export interface SwitchEventHandlersParams {
10
10
  index?: number;
11
11
  name?: string | number;
@@ -28,6 +28,10 @@ export interface ContentSwitcherProps extends Omit<HTMLAttributes<HTMLElement>,
28
28
  * been deprecated in favor of the new `Layer` component. It will be removed in the next major release.
29
29
  */
30
30
  light?: boolean;
31
+ /**
32
+ * `true` to use the low contrast version.
33
+ */
34
+ lowContrast?: boolean;
31
35
  /**
32
36
  * Specify an `onChange` handler that is called whenever the ContentSwitcher
33
37
  * changes which item is selected
@@ -42,24 +46,14 @@ export interface ContentSwitcherProps extends Omit<HTMLAttributes<HTMLElement>,
42
46
  */
43
47
  selectionMode?: 'automatic' | 'manual';
44
48
  /**
45
- * Specify the size of the Content Switcher. Currently supports either `sm`, 'md' (default) or 'lg` as an option.
49
+ * Specify the size of the Content Switcher. Currently supports either `sm`, `md` (default) or `lg` as an option.
46
50
  */
47
51
  size: 'sm' | 'md' | 'lg';
48
52
  }
49
- export interface ContentSwitcherState {
50
- selectedIndex?: number;
51
- }
52
- export default class ContentSwitcher extends React.Component<ContentSwitcherProps, ContentSwitcherState> {
53
- /**
54
- * The DOM references of child `<Switch>`.
55
- * @type {Array<Element>}
56
- * @private
57
- */
58
- _switchRefs: HTMLButtonElement[];
59
- state: {
60
- selectedIndex: undefined;
61
- };
62
- static propTypes: {
53
+ export declare const ContentSwitcher: {
54
+ ({ children, className, light, lowContrast, selectedIndex: selectedIndexProp, selectionMode, size, onChange, ...other }: ContentSwitcherProps): import("react/jsx-runtime").JSX.Element;
55
+ displayName: string;
56
+ propTypes: {
63
57
  /**
64
58
  * Pass in Switch components to be rendered in the ContentSwitcher
65
59
  */
@@ -72,6 +66,10 @@ export default class ContentSwitcher extends React.Component<ContentSwitcherProp
72
66
  * `true` to use the light variant.
73
67
  */
74
68
  light: (props: any, propName: any, componentName: any, ...rest: any[]) => any;
69
+ /**
70
+ * `true` to use the low contrast version.
71
+ */
72
+ lowContrast: PropTypes.Requireable<boolean>;
75
73
  /**
76
74
  * Specify an `onChange` handler that is called whenever the ContentSwitcher
77
75
  * changes which item is selected
@@ -86,18 +84,8 @@ export default class ContentSwitcher extends React.Component<ContentSwitcherProp
86
84
  */
87
85
  selectionMode: PropTypes.Requireable<string>;
88
86
  /**
89
- * Specify the size of the Content Switcher. Currently supports either `sm`, 'md' (default) or 'lg` as an option.
87
+ * Specify the size of the Content Switcher. Currently supports either `sm`, `md` (default) or `lg` as an option.
90
88
  */
91
89
  size: PropTypes.Requireable<string>;
92
90
  };
93
- static contextType: React.Context<string>;
94
- static getDerivedStateFromProps({ selectedIndex }: {
95
- selectedIndex?: number | undefined;
96
- }, state: any): {
97
- selectedIndex: number;
98
- prevSelectedIndex: number;
99
- } | null;
100
- handleItemRef: (index: any) => (ref: any) => void;
101
- handleChildChange: (data: any) => void;
102
- render(): import("react/jsx-runtime").JSX.Element;
103
- }
91
+ };
@@ -28,129 +28,100 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
28
28
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
29
29
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
30
30
 
31
- class ContentSwitcher extends React__default["default"].Component {
32
- constructor() {
33
- super(...arguments);
34
- /**
35
- * The DOM references of child `<Switch>`.
36
- * @type {Array<Element>}
37
- * @private
38
- */
39
- _rollupPluginBabelHelpers.defineProperty(this, "_switchRefs", []);
40
- _rollupPluginBabelHelpers.defineProperty(this, "state", {
41
- selectedIndex: undefined
42
- });
43
- _rollupPluginBabelHelpers.defineProperty(this, "handleItemRef", index => ref => {
44
- this._switchRefs[index] = ref;
45
- });
46
- _rollupPluginBabelHelpers.defineProperty(this, "handleChildChange", data => {
47
- const {
48
- selectionMode = 'automatic'
49
- } = this.props;
50
- // the currently selected child index
51
- const {
52
- selectedIndex
53
- } = this.state;
54
- // the newly selected child index
55
- const {
56
- index
57
- } = data;
58
- const {
59
- key
60
- } = data;
61
- if (match.matches(data, [keys.ArrowRight, keys.ArrowLeft])) {
62
- const nextIndex = navigation.getNextIndex(key, index, this.props.children?.length);
63
- const children = React__default["default"].Children.toArray(this.props.children);
64
- if (selectionMode === 'manual') {
65
- const switchRef = this._switchRefs[nextIndex];
66
- switchRef && switchRef.focus();
67
- } else {
68
- this.setState({
69
- selectedIndex: nextIndex
70
- }, () => {
71
- if (typeof this.state.selectedIndex !== 'number') {
72
- return;
73
- }
74
- const child = children[this.state.selectedIndex];
75
- const switchRef = this._switchRefs[this.state.selectedIndex];
76
- switchRef && switchRef.focus();
77
- this.props.onChange({
78
- ...data,
79
- index: this.state.selectedIndex,
80
- name: child.props.name,
81
- text: child.props.text
82
- });
31
+ const ContentSwitcher = ({
32
+ children,
33
+ className,
34
+ light,
35
+ lowContrast,
36
+ selectedIndex: selectedIndexProp = 0,
37
+ selectionMode = 'automatic',
38
+ size,
39
+ onChange = noopFn.noopFn,
40
+ ...other
41
+ }) => {
42
+ const prefix = React.useContext(usePrefix.PrefixContext);
43
+ const [selectedIndex, setSelectedIndex] = React.useState(selectedIndexProp);
44
+ const prevSelectedIndexRef = React.useRef(selectedIndexProp);
45
+ const switchRefs = React.useRef([]);
46
+ const childrenArray = React.Children.toArray(children);
47
+ React.useEffect(() => {
48
+ if (prevSelectedIndexRef.current !== selectedIndexProp) {
49
+ setSelectedIndex(selectedIndexProp);
50
+ prevSelectedIndexRef.current = selectedIndexProp;
51
+ }
52
+ }, [selectedIndexProp]);
53
+ const handleItemRef = index => ref => {
54
+ if (ref) {
55
+ switchRefs.current[index] = ref;
56
+ }
57
+ };
58
+ const focusSwitch = index => {
59
+ const ref = switchRefs.current[index];
60
+ if (ref) {
61
+ ref.focus();
62
+ }
63
+ };
64
+ const isKeyboardEvent = event => event && typeof event === 'object' && 'key' in event;
65
+ const handleChildChange = event => {
66
+ if (typeof event.index === 'undefined') return;
67
+ const {
68
+ index
69
+ } = event;
70
+ if (isKeyboardEvent(event) && match.matches(event, [keys.ArrowRight, keys.ArrowLeft])) {
71
+ const nextIndex = navigation.getNextIndex(event.key, index, childrenArray.length);
72
+ if (typeof nextIndex !== 'number') return;
73
+ focusSwitch(nextIndex);
74
+ if (selectionMode !== 'manual') {
75
+ const child = childrenArray[nextIndex];
76
+ setSelectedIndex(nextIndex);
77
+ if (/*#__PURE__*/React.isValidElement(child)) {
78
+ onChange({
79
+ ...event,
80
+ index: nextIndex,
81
+ name: child.props.name,
82
+ text: child.props.text
83
83
  });
84
84
  }
85
- } else if (selectedIndex !== index) {
86
- this.setState({
87
- selectedIndex: index
88
- }, () => {
89
- const switchRef = this._switchRefs[index];
90
- switchRef && switchRef.focus();
91
- this.props.onChange(data);
92
- });
93
- }
94
- });
95
- }
96
- static getDerivedStateFromProps(_ref, state) {
97
- let {
98
- selectedIndex = 0
99
- } = _ref;
100
- const {
101
- prevSelectedIndex
102
- } = state;
103
- return prevSelectedIndex === selectedIndex ? null : {
104
- selectedIndex,
105
- prevSelectedIndex: selectedIndex
106
- };
107
- }
108
- render() {
109
- const prefix = this.context;
110
- const {
111
- children,
112
- className,
113
- light,
114
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
115
- selectedIndex = 0,
116
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
117
- selectionMode = 'automatic',
118
- size,
119
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
120
- onChange = noopFn.noopFn,
121
- ...other
122
- } = this.props;
123
- const isIconOnly = React__default["default"].Children?.map(children, child => {
124
- return child.type.displayName === 'IconSwitch';
125
- })?.every(val => val === true);
126
- const classes = cx__default["default"](`${prefix}--content-switcher`, className, {
127
- [`${prefix}--content-switcher--light`]: light,
128
- [`${prefix}--content-switcher--${size}`]: size,
129
- // TODO: V12 - Remove this class
130
- [`${prefix}--layout--size-${size}`]: size,
131
- [`${prefix}--content-switcher--icon-only`]: isIconOnly
132
- });
133
- return /*#__PURE__*/React__default["default"].createElement(index.LayoutConstraint, _rollupPluginBabelHelpers["extends"]({
134
- size: {
135
- default: 'md',
136
- min: 'sm',
137
- max: 'lg'
138
85
  }
139
- }, other, {
140
- className: classes,
141
- role: "tablist",
142
- onChange: undefined
143
- }), children && React__default["default"].Children.toArray(children).map((child, index) => /*#__PURE__*/React__default["default"].cloneElement(child, {
144
- index,
145
- onClick: events.composeEventHandlers([this.handleChildChange, child.props.onClick]),
146
- onKeyDown: this.handleChildChange,
147
- selected: index === this.state.selectedIndex,
148
- ref: this.handleItemRef(index),
149
- size
150
- })));
151
- }
152
- }
153
- _rollupPluginBabelHelpers.defineProperty(ContentSwitcher, "propTypes", {
86
+ } else if (selectedIndex !== index) {
87
+ setSelectedIndex(index);
88
+ focusSwitch(index);
89
+ onChange(event);
90
+ }
91
+ };
92
+ const isIconOnly = childrenArray.every(
93
+ // TODO: Update this code when
94
+ // https://github.com/carbon-design-system/carbon/pull/18971 is merged.
95
+ child => child.type.displayName === 'IconSwitch');
96
+ const classes = cx__default["default"](`${prefix}--content-switcher`, className, {
97
+ [`${prefix}--content-switcher--light`]: light,
98
+ [`${prefix}--content-switcher--${size}`]: size,
99
+ // TODO: V12 - Remove this class
100
+ [`${prefix}--layout--size-${size}`]: size,
101
+ [`${prefix}--content-switcher--icon-only`]: isIconOnly,
102
+ [`${prefix}--content-switcher--low-contrast`]: lowContrast
103
+ });
104
+ return /*#__PURE__*/React__default["default"].createElement(index.LayoutConstraint, _rollupPluginBabelHelpers["extends"]({
105
+ size: {
106
+ default: 'md',
107
+ min: 'sm',
108
+ max: 'lg'
109
+ }
110
+ }, other, {
111
+ className: classes,
112
+ role: "tablist",
113
+ onChange: undefined
114
+ }), children && React.Children.map(children, (child, index) => /*#__PURE__*/React.cloneElement(child, {
115
+ index,
116
+ onClick: events.composeEventHandlers([handleChildChange, child.props.onClick]),
117
+ onKeyDown: events.composeEventHandlers([handleChildChange, child.props.onKeyDown]),
118
+ selected: index === selectedIndex,
119
+ ref: handleItemRef(index),
120
+ size
121
+ })));
122
+ };
123
+ ContentSwitcher.displayName = 'ContentSwitcher';
124
+ ContentSwitcher.propTypes = {
154
125
  /**
155
126
  * Pass in Switch components to be rendered in the ContentSwitcher
156
127
  */
@@ -163,6 +134,10 @@ _rollupPluginBabelHelpers.defineProperty(ContentSwitcher, "propTypes", {
163
134
  * `true` to use the light variant.
164
135
  */
165
136
  light: deprecate["default"](PropTypes__default["default"].bool, 'The `light` prop for `ContentSwitcher` is no longer needed and has ' + 'been deprecated. It will be removed in the next major release.'),
137
+ /**
138
+ * `true` to use the low contrast version.
139
+ */
140
+ lowContrast: PropTypes__default["default"].bool,
166
141
  /**
167
142
  * Specify an `onChange` handler that is called whenever the ContentSwitcher
168
143
  * changes which item is selected
@@ -177,10 +152,9 @@ _rollupPluginBabelHelpers.defineProperty(ContentSwitcher, "propTypes", {
177
152
  */
178
153
  selectionMode: PropTypes__default["default"].oneOf(['automatic', 'manual']),
179
154
  /**
180
- * Specify the size of the Content Switcher. Currently supports either `sm`, 'md' (default) or 'lg` as an option.
155
+ * Specify the size of the Content Switcher. Currently supports either `sm`, `md` (default) or `lg` as an option.
181
156
  */
182
157
  size: PropTypes__default["default"].oneOf(['sm', 'md', 'lg'])
183
- });
184
- _rollupPluginBabelHelpers.defineProperty(ContentSwitcher, "contextType", usePrefix.PrefixContext);
158
+ };
185
159
 
186
- exports["default"] = ContentSwitcher;
160
+ exports.ContentSwitcher = ContentSwitcher;
@@ -1,10 +1,9 @@
1
1
  /**
2
- * Copyright IBM Corp. 2016, 2023
2
+ * Copyright IBM Corp. 2016, 2025
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
- import { ContentSwitcherProps } from './ContentSwitcher';
8
- declare const ContentSwitcher: import("react").FunctionComponent<ContentSwitcherProps>;
7
+ import { ContentSwitcher } from './ContentSwitcher';
9
8
  export default ContentSwitcher;
10
- export { ContentSwitcher };
9
+ export * from './ContentSwitcher';
@@ -15,8 +15,7 @@ var React = require('react');
15
15
  * @param {TriggerType} [trigger=document] The element or ref which should trigger the Menu on right-click
16
16
  * @returns {ContextMenuProps} Props object to pass onto Menu component
17
17
  */
18
- function useContextMenu() {
19
- let trigger = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : document;
18
+ function useContextMenu(trigger = document) {
20
19
  const [open, setOpen] = React.useState(false);
21
20
  const [position, setPosition] = React.useState([0, 0]);
22
21
  function openContextMenu(e) {