@carbon/react 1.83.0 → 1.84.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 (524) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +909 -874
  2. package/README.md +1 -1
  3. package/es/components/AILabel/index.js +27 -30
  4. package/es/components/AISkeleton/AISkeletonIcon.js +4 -5
  5. package/es/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  6. package/es/components/AISkeleton/AISkeletonText.js +4 -5
  7. package/es/components/Accordion/Accordion.Skeleton.js +9 -10
  8. package/es/components/Accordion/Accordion.js +10 -11
  9. package/es/components/Accordion/AccordionItem.js +13 -14
  10. package/es/components/Accordion/AccordionProvider.js +4 -5
  11. package/es/components/AspectRatio/AspectRatio.js +7 -8
  12. package/es/components/BadgeIndicator/index.js +5 -6
  13. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  14. package/es/components/Button/Button.Skeleton.js +7 -8
  15. package/es/components/Button/ButtonBase.js +23 -24
  16. package/es/components/ChatButton/ChatButton.Skeleton.js +5 -6
  17. package/es/components/ChatButton/ChatButton.js +11 -12
  18. package/es/components/Checkbox/Checkbox.Skeleton.js +4 -5
  19. package/es/components/Checkbox/Checkbox.js +19 -20
  20. package/es/components/CheckboxGroup/CheckboxGroup.js +16 -17
  21. package/es/components/ClassPrefix/index.js +4 -5
  22. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  23. package/es/components/CodeSnippet/CodeSnippet.js +25 -26
  24. package/es/components/ComboBox/ComboBox.js +24 -30
  25. package/es/components/ComboBox/tools/filter.js +9 -12
  26. package/es/components/ComboButton/index.js +16 -18
  27. package/es/components/ComposedModal/ComposedModal.js +50 -36
  28. package/es/components/ComposedModal/ModalFooter.js +37 -42
  29. package/es/components/ComposedModal/ModalHeader.js +14 -15
  30. package/es/components/ContainedList/ContainedList.js +10 -11
  31. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  32. package/es/components/ContentSwitcher/ContentSwitcher.d.ts +9 -29
  33. package/es/components/ContentSwitcher/ContentSwitcher.js +96 -128
  34. package/es/components/ContentSwitcher/index.d.ts +3 -4
  35. package/es/components/ContextMenu/useContextMenu.js +1 -2
  36. package/es/components/Copy/Copy.js +11 -12
  37. package/es/components/CopyButton/CopyButton.js +10 -11
  38. package/es/components/DataTable/DataTable.js +45 -53
  39. package/es/components/DataTable/Table.js +15 -18
  40. package/es/components/DataTable/TableBatchAction.js +8 -11
  41. package/es/components/DataTable/TableBatchActions.js +18 -20
  42. package/es/components/DataTable/TableBody.js +8 -11
  43. package/es/components/DataTable/TableContainer.js +9 -10
  44. package/es/components/DataTable/TableDecoratorRow.js +4 -5
  45. package/es/components/DataTable/TableExpandHeader.js +14 -15
  46. package/es/components/DataTable/TableExpandRow.js +13 -14
  47. package/es/components/DataTable/TableExpandedRow.js +6 -7
  48. package/es/components/DataTable/TableHeader.js +15 -16
  49. package/es/components/DataTable/TableSelectAll.js +11 -12
  50. package/es/components/DataTable/TableSelectRow.js +12 -13
  51. package/es/components/DataTable/TableSlugRow.js +4 -5
  52. package/es/components/DataTable/TableToolbar.js +7 -8
  53. package/es/components/DataTable/TableToolbarMenu.js +8 -9
  54. package/es/components/DataTable/TableToolbarSearch.js +22 -24
  55. package/es/components/DataTable/state/sorting.js +3 -4
  56. package/es/components/DataTable/tools/filter.js +10 -12
  57. package/es/components/DataTable/tools/normalize.js +6 -8
  58. package/es/components/DataTable/tools/sorting.js +24 -30
  59. package/es/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  60. package/es/components/DatePicker/DatePicker.Skeleton.js +7 -8
  61. package/es/components/DatePicker/DatePicker.js +88 -65
  62. package/es/components/DatePickerInput/DatePickerInput.js +5 -6
  63. package/es/components/Dialog/index.d.ts +193 -8
  64. package/es/components/Dialog/index.js +454 -35
  65. package/es/components/Dropdown/Dropdown.Skeleton.js +6 -7
  66. package/es/components/Dropdown/Dropdown.js +40 -43
  67. package/es/components/ErrorBoundary/ErrorBoundary.js +2 -2
  68. package/es/components/ExpandableSearch/ExpandableSearch.js +9 -10
  69. package/es/components/FeatureFlags/index.js +11 -12
  70. package/es/components/FileUploader/FileUploader.Skeleton.js +4 -5
  71. package/es/components/FileUploader/FileUploader.js +22 -24
  72. package/es/components/FileUploader/FileUploaderButton.js +16 -17
  73. package/es/components/FileUploader/FileUploaderDropContainer.js +15 -16
  74. package/es/components/FileUploader/FileUploaderItem.js +13 -14
  75. package/es/components/FileUploader/Filename.js +9 -10
  76. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  77. package/es/components/FluidComboBox/FluidComboBox.js +5 -6
  78. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  79. package/es/components/FluidDatePicker/FluidDatePicker.js +10 -11
  80. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  81. package/es/components/FluidDropdown/FluidDropdown.js +5 -6
  82. package/es/components/FluidForm/FluidForm.js +5 -6
  83. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  84. package/es/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  85. package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  86. package/es/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  87. package/es/components/FluidNumberInput/FluidNumberInput.js +38 -5
  88. package/es/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  89. package/es/components/FluidSearch/FluidSearch.js +4 -5
  90. package/es/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  91. package/es/components/FluidSelect/FluidSelect.js +5 -6
  92. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  93. package/es/components/FluidTextArea/FluidTextArea.js +4 -5
  94. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  95. package/es/components/FluidTextInput/FluidTextInput.js +5 -6
  96. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  97. package/es/components/FluidTimePicker/FluidTimePicker.js +11 -12
  98. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  99. package/es/components/Form/Form.js +5 -6
  100. package/es/components/FormGroup/FormGroup.js +11 -12
  101. package/es/components/FormItem/FormItem.js +5 -6
  102. package/es/components/FormLabel/FormLabel.js +6 -7
  103. package/es/components/Grid/CSSGrid.js +17 -19
  104. package/es/components/Grid/Column.js +28 -27
  105. package/es/components/Grid/ColumnHang.js +6 -7
  106. package/es/components/Grid/FlexGrid.js +9 -10
  107. package/es/components/Grid/GridContext.js +5 -6
  108. package/es/components/Grid/Row.js +8 -9
  109. package/es/components/Heading/index.js +5 -6
  110. package/es/components/Icon/Icon.Skeleton.js +4 -5
  111. package/es/components/IconButton/index.js +20 -21
  112. package/es/components/IconIndicator/index.js +7 -8
  113. package/es/components/IdPrefix/index.js +4 -5
  114. package/es/components/InlineLoading/InlineLoading.js +9 -10
  115. package/es/components/Layer/index.js +8 -9
  116. package/es/components/Layout/index.js +21 -26
  117. package/es/components/LayoutDirection/LayoutDirection.js +6 -7
  118. package/es/components/Link/Link.d.ts +1 -1
  119. package/es/components/Link/Link.js +14 -15
  120. package/es/components/ListBox/ListBoxField.js +6 -7
  121. package/es/components/ListBox/ListBoxMenu.js +5 -6
  122. package/es/components/ListBox/ListBoxMenuIcon.js +4 -5
  123. package/es/components/ListBox/ListBoxMenuItem.js +8 -10
  124. package/es/components/ListBox/ListBoxSelection.js +8 -9
  125. package/es/components/ListBox/next/ListBoxSelection.js +9 -10
  126. package/es/components/ListBox/next/ListBoxTrigger.js +5 -6
  127. package/es/components/ListItem/ListItem.js +5 -6
  128. package/es/components/Loading/Loading.js +8 -9
  129. package/es/components/Menu/Menu.js +23 -24
  130. package/es/components/Menu/MenuItem.js +39 -44
  131. package/es/components/MenuButton/index.js +16 -18
  132. package/es/components/Modal/Modal.js +74 -65
  133. package/es/components/ModalWrapper/ModalWrapper.js +2 -2
  134. package/es/components/MultiSelect/FilterableMultiSelect.js +67 -48
  135. package/es/components/MultiSelect/MultiSelect.js +43 -45
  136. package/es/components/MultiSelect/tools/sorting.js +11 -15
  137. package/es/components/Notification/Notification.js +96 -105
  138. package/es/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  139. package/es/components/NumberInput/NumberFormatPropTypes.js +40 -0
  140. package/es/components/NumberInput/NumberInput.Skeleton.js +6 -7
  141. package/es/components/NumberInput/NumberInput.d.ts +39 -3
  142. package/es/components/NumberInput/NumberInput.js +174 -44
  143. package/es/components/OrderedList/OrderedList.js +7 -8
  144. package/es/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  145. package/es/components/OverflowMenu/OverflowMenu.js +39 -46
  146. package/es/components/OverflowMenu/next/index.js +12 -13
  147. package/es/components/PageHeader/PageHeader.d.ts +39 -14
  148. package/es/components/PageHeader/PageHeader.js +187 -81
  149. package/es/components/PageHeader/index.d.ts +2 -2
  150. package/es/components/PageHeader/index.js +1 -1
  151. package/es/components/Pagination/Pagination.Skeleton.js +4 -5
  152. package/es/components/Pagination/Pagination.js +24 -25
  153. package/es/components/Pagination/experimental/PageSelector.js +8 -9
  154. package/es/components/Pagination/experimental/Pagination.js +20 -21
  155. package/es/components/PaginationNav/PaginationNav.js +33 -38
  156. package/es/components/Popover/index.js +26 -28
  157. package/es/components/ProgressBar/ProgressBar.js +11 -12
  158. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  159. package/es/components/ProgressIndicator/ProgressIndicator.js +29 -32
  160. package/es/components/RadioTile/RadioTile.js +17 -18
  161. package/es/components/Search/Search.Skeleton.js +5 -6
  162. package/es/components/Search/Search.js +26 -29
  163. package/es/components/Select/Select.Skeleton.js +5 -6
  164. package/es/components/Select/Select.js +24 -25
  165. package/es/components/SelectItem/SelectItem.js +8 -9
  166. package/es/components/SelectItemGroup/SelectItemGroup.js +7 -8
  167. package/es/components/ShapeIndicator/index.js +7 -8
  168. package/es/components/SkeletonIcon/SkeletonIcon.js +4 -5
  169. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  170. package/es/components/SkeletonText/SkeletonText.js +8 -9
  171. package/es/components/Slider/Slider.Skeleton.js +8 -9
  172. package/es/components/Slider/Slider.js +75 -83
  173. package/es/components/Slider/SliderHandles.js +6 -6
  174. package/es/components/StructuredList/StructuredList.Skeleton.js +5 -6
  175. package/es/components/Tabs/Tabs.Skeleton.js +5 -6
  176. package/es/components/Tabs/Tabs.js +83 -98
  177. package/es/components/Tabs/usePressable.js +7 -8
  178. package/es/components/Tag/DismissibleTag.js +16 -17
  179. package/es/components/Tag/OperationalTag.js +10 -11
  180. package/es/components/Tag/SelectableTag.js +13 -14
  181. package/es/components/Tag/Tag.Skeleton.js +5 -6
  182. package/es/components/Tag/Tag.js +19 -20
  183. package/es/components/Text/Text.js +6 -7
  184. package/es/components/Text/TextDirection.js +5 -6
  185. package/es/components/TextArea/TextArea.js +7 -7
  186. package/es/components/TextInput/ControlledPasswordInput.js +24 -25
  187. package/es/components/TextInput/PasswordInput.js +26 -27
  188. package/es/components/TextInput/TextInput.Skeleton.js +5 -6
  189. package/es/components/TextInput/TextInput.js +27 -28
  190. package/es/components/TextInput/util.js +14 -17
  191. package/es/components/Theme/index.js +10 -12
  192. package/es/components/Tile/Tile.js +68 -74
  193. package/es/components/TileGroup/TileGroup.d.ts +4 -4
  194. package/es/components/TileGroup/TileGroup.js +45 -53
  195. package/es/components/TileGroup/index.d.ts +3 -3
  196. package/es/components/Toggle/Toggle.Skeleton.js +4 -5
  197. package/es/components/Toggle/Toggle.js +17 -18
  198. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  199. package/es/components/Toggletip/index.js +33 -39
  200. package/es/components/Tooltip/DefinitionTooltip.js +13 -14
  201. package/es/components/Tooltip/Tooltip.js +15 -16
  202. package/es/components/TreeView/TreeNode.js +20 -21
  203. package/es/components/TreeView/TreeView.js +14 -16
  204. package/es/components/UIShell/Content.js +6 -7
  205. package/es/components/UIShell/Header.js +5 -6
  206. package/es/components/UIShell/HeaderContainer.js +5 -6
  207. package/es/components/UIShell/HeaderGlobalAction.js +12 -13
  208. package/es/components/UIShell/HeaderMenu.d.ts +10 -112
  209. package/es/components/UIShell/HeaderMenu.js +154 -201
  210. package/es/components/UIShell/HeaderMenuButton.js +10 -11
  211. package/es/components/UIShell/HeaderMenuItem.js +12 -12
  212. package/es/components/UIShell/HeaderName.js +6 -7
  213. package/es/components/UIShell/HeaderNavigation.js +7 -8
  214. package/es/components/UIShell/HeaderPanel.js +9 -10
  215. package/es/components/UIShell/HeaderSideNavItems.js +5 -6
  216. package/es/components/UIShell/Link.js +8 -9
  217. package/es/components/UIShell/SideNav.js +23 -25
  218. package/es/components/UIShell/SideNavDetails.js +6 -7
  219. package/es/components/UIShell/SideNavDivider.js +3 -4
  220. package/es/components/UIShell/SideNavFooter.js +6 -7
  221. package/es/components/UIShell/SideNavHeader.js +5 -6
  222. package/es/components/UIShell/SideNavIcon.js +5 -6
  223. package/es/components/UIShell/SideNavItem.js +5 -6
  224. package/es/components/UIShell/SideNavItems.js +5 -6
  225. package/es/components/UIShell/SideNavLink.js +10 -11
  226. package/es/components/UIShell/SideNavLinkText.js +5 -6
  227. package/es/components/UIShell/SideNavMenu.js +11 -12
  228. package/es/components/UIShell/SkipToContent.js +7 -8
  229. package/es/components/UIShell/Switcher.js +4 -5
  230. package/es/components/UIShell/SwitcherDivider.js +4 -5
  231. package/es/components/UnorderedList/UnorderedList.js +6 -7
  232. package/es/index.js +3 -3
  233. package/es/internal/FloatingMenu.js +26 -28
  234. package/es/internal/Selection.js +15 -17
  235. package/es/internal/getAnnouncement.d.ts +8 -0
  236. package/es/internal/getAnnouncement.js +22 -0
  237. package/es/internal/keyboard/match.js +6 -7
  238. package/es/internal/useControllableState.d.ts +1 -1
  239. package/es/internal/useControllableState.js +8 -9
  240. package/es/internal/useDelayedState.js +1 -2
  241. package/es/internal/useDocumentLang.d.ts +12 -0
  242. package/es/internal/useId.js +2 -4
  243. package/es/internal/useMatchMedia.js +1 -2
  244. package/es/internal/useMergedRefs.d.ts +1 -1
  245. package/es/internal/useNoInteractiveChildren.js +2 -4
  246. package/es/internal/useNormalizedInputProps.js +9 -10
  247. package/es/internal/useOverflowItems.d.ts +29 -0
  248. package/es/internal/useOverflowItems.js +122 -0
  249. package/es/internal/useResizeObserver.js +4 -5
  250. package/es/internal/useSavedCallback.js +1 -3
  251. package/es/internal/wrapFocus.js +20 -29
  252. package/es/prop-types/deprecate.js +1 -4
  253. package/es/prop-types/deprecateValuesWithin.js +1 -4
  254. package/es/prop-types/isRequiredOneOf.js +1 -4
  255. package/es/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  256. package/es/tools/events.js +1 -4
  257. package/es/tools/mergeRefs.js +9 -14
  258. package/es/tools/uniqueId.js +1 -2
  259. package/es/tools/wrapComponent.js +9 -11
  260. package/lib/components/AILabel/index.js +27 -30
  261. package/lib/components/AISkeleton/AISkeletonIcon.js +4 -5
  262. package/lib/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  263. package/lib/components/AISkeleton/AISkeletonText.js +4 -5
  264. package/lib/components/Accordion/Accordion.Skeleton.js +9 -10
  265. package/lib/components/Accordion/Accordion.js +10 -11
  266. package/lib/components/Accordion/AccordionItem.js +13 -14
  267. package/lib/components/Accordion/AccordionProvider.js +4 -5
  268. package/lib/components/AspectRatio/AspectRatio.js +7 -8
  269. package/lib/components/BadgeIndicator/index.js +5 -6
  270. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  271. package/lib/components/Button/Button.Skeleton.js +7 -8
  272. package/lib/components/Button/ButtonBase.js +23 -24
  273. package/lib/components/ChatButton/ChatButton.Skeleton.js +5 -6
  274. package/lib/components/ChatButton/ChatButton.js +11 -12
  275. package/lib/components/Checkbox/Checkbox.Skeleton.js +4 -5
  276. package/lib/components/Checkbox/Checkbox.js +19 -20
  277. package/lib/components/CheckboxGroup/CheckboxGroup.js +16 -17
  278. package/lib/components/ClassPrefix/index.js +4 -5
  279. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  280. package/lib/components/CodeSnippet/CodeSnippet.js +25 -26
  281. package/lib/components/ComboBox/ComboBox.js +24 -30
  282. package/lib/components/ComboBox/tools/filter.js +9 -12
  283. package/lib/components/ComboButton/index.js +16 -18
  284. package/lib/components/ComposedModal/ComposedModal.js +50 -36
  285. package/lib/components/ComposedModal/ModalFooter.js +37 -42
  286. package/lib/components/ComposedModal/ModalHeader.js +14 -15
  287. package/lib/components/ContainedList/ContainedList.js +10 -11
  288. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  289. package/lib/components/ContentSwitcher/ContentSwitcher.d.ts +9 -29
  290. package/lib/components/ContentSwitcher/ContentSwitcher.js +94 -126
  291. package/lib/components/ContentSwitcher/index.d.ts +3 -4
  292. package/lib/components/ContextMenu/useContextMenu.js +1 -2
  293. package/lib/components/Copy/Copy.js +11 -12
  294. package/lib/components/CopyButton/CopyButton.js +10 -11
  295. package/lib/components/DataTable/DataTable.js +45 -53
  296. package/lib/components/DataTable/Table.js +15 -18
  297. package/lib/components/DataTable/TableBatchAction.js +8 -11
  298. package/lib/components/DataTable/TableBatchActions.js +18 -20
  299. package/lib/components/DataTable/TableBody.js +8 -11
  300. package/lib/components/DataTable/TableContainer.js +9 -10
  301. package/lib/components/DataTable/TableDecoratorRow.js +4 -5
  302. package/lib/components/DataTable/TableExpandHeader.js +14 -15
  303. package/lib/components/DataTable/TableExpandRow.js +13 -14
  304. package/lib/components/DataTable/TableExpandedRow.js +6 -7
  305. package/lib/components/DataTable/TableHeader.js +15 -16
  306. package/lib/components/DataTable/TableSelectAll.js +11 -12
  307. package/lib/components/DataTable/TableSelectRow.js +12 -13
  308. package/lib/components/DataTable/TableSlugRow.js +4 -5
  309. package/lib/components/DataTable/TableToolbar.js +7 -8
  310. package/lib/components/DataTable/TableToolbarMenu.js +8 -9
  311. package/lib/components/DataTable/TableToolbarSearch.js +22 -24
  312. package/lib/components/DataTable/state/sorting.js +3 -4
  313. package/lib/components/DataTable/tools/filter.js +10 -12
  314. package/lib/components/DataTable/tools/normalize.js +6 -8
  315. package/lib/components/DataTable/tools/sorting.js +24 -30
  316. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  317. package/lib/components/DatePicker/DatePicker.Skeleton.js +7 -8
  318. package/lib/components/DatePicker/DatePicker.js +87 -64
  319. package/lib/components/DatePickerInput/DatePickerInput.js +5 -6
  320. package/lib/components/Dialog/index.d.ts +193 -8
  321. package/lib/components/Dialog/index.js +457 -33
  322. package/lib/components/Dropdown/Dropdown.Skeleton.js +6 -7
  323. package/lib/components/Dropdown/Dropdown.js +40 -43
  324. package/lib/components/ErrorBoundary/ErrorBoundary.js +2 -2
  325. package/lib/components/ExpandableSearch/ExpandableSearch.js +9 -10
  326. package/lib/components/FeatureFlags/index.js +11 -12
  327. package/lib/components/FileUploader/FileUploader.Skeleton.js +4 -5
  328. package/lib/components/FileUploader/FileUploader.js +22 -24
  329. package/lib/components/FileUploader/FileUploaderButton.js +16 -17
  330. package/lib/components/FileUploader/FileUploaderDropContainer.js +15 -16
  331. package/lib/components/FileUploader/FileUploaderItem.js +13 -14
  332. package/lib/components/FileUploader/Filename.js +9 -10
  333. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  334. package/lib/components/FluidComboBox/FluidComboBox.js +5 -6
  335. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  336. package/lib/components/FluidDatePicker/FluidDatePicker.js +10 -11
  337. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  338. package/lib/components/FluidDropdown/FluidDropdown.js +5 -6
  339. package/lib/components/FluidForm/FluidForm.js +5 -6
  340. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  341. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  342. package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  343. package/lib/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  344. package/lib/components/FluidNumberInput/FluidNumberInput.js +38 -5
  345. package/lib/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  346. package/lib/components/FluidSearch/FluidSearch.js +4 -5
  347. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  348. package/lib/components/FluidSelect/FluidSelect.js +5 -6
  349. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  350. package/lib/components/FluidTextArea/FluidTextArea.js +4 -5
  351. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  352. package/lib/components/FluidTextInput/FluidTextInput.js +5 -6
  353. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  354. package/lib/components/FluidTimePicker/FluidTimePicker.js +11 -12
  355. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  356. package/lib/components/Form/Form.js +5 -6
  357. package/lib/components/FormGroup/FormGroup.js +11 -12
  358. package/lib/components/FormItem/FormItem.js +5 -6
  359. package/lib/components/FormLabel/FormLabel.js +6 -7
  360. package/lib/components/Grid/CSSGrid.js +17 -19
  361. package/lib/components/Grid/Column.js +28 -27
  362. package/lib/components/Grid/ColumnHang.js +6 -7
  363. package/lib/components/Grid/FlexGrid.js +9 -10
  364. package/lib/components/Grid/GridContext.js +5 -6
  365. package/lib/components/Grid/Row.js +8 -9
  366. package/lib/components/Heading/index.js +5 -6
  367. package/lib/components/Icon/Icon.Skeleton.js +4 -5
  368. package/lib/components/IconButton/index.js +20 -21
  369. package/lib/components/IconIndicator/index.js +7 -8
  370. package/lib/components/IdPrefix/index.js +4 -5
  371. package/lib/components/InlineLoading/InlineLoading.js +9 -10
  372. package/lib/components/Layer/index.js +8 -9
  373. package/lib/components/Layout/index.js +21 -26
  374. package/lib/components/LayoutDirection/LayoutDirection.js +6 -7
  375. package/lib/components/Link/Link.d.ts +1 -1
  376. package/lib/components/Link/Link.js +14 -15
  377. package/lib/components/ListBox/ListBoxField.js +6 -7
  378. package/lib/components/ListBox/ListBoxMenu.js +5 -6
  379. package/lib/components/ListBox/ListBoxMenuIcon.js +4 -5
  380. package/lib/components/ListBox/ListBoxMenuItem.js +8 -10
  381. package/lib/components/ListBox/ListBoxSelection.js +8 -9
  382. package/lib/components/ListBox/next/ListBoxSelection.js +9 -10
  383. package/lib/components/ListBox/next/ListBoxTrigger.js +5 -6
  384. package/lib/components/ListItem/ListItem.js +5 -6
  385. package/lib/components/Loading/Loading.js +8 -9
  386. package/lib/components/Menu/Menu.js +23 -24
  387. package/lib/components/Menu/MenuItem.js +39 -44
  388. package/lib/components/MenuButton/index.js +16 -18
  389. package/lib/components/Modal/Modal.js +74 -65
  390. package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
  391. package/lib/components/MultiSelect/FilterableMultiSelect.js +66 -47
  392. package/lib/components/MultiSelect/MultiSelect.js +43 -45
  393. package/lib/components/MultiSelect/tools/sorting.js +11 -15
  394. package/lib/components/Notification/Notification.js +96 -105
  395. package/lib/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  396. package/lib/components/NumberInput/NumberFormatPropTypes.js +48 -0
  397. package/lib/components/NumberInput/NumberInput.Skeleton.js +6 -7
  398. package/lib/components/NumberInput/NumberInput.d.ts +39 -3
  399. package/lib/components/NumberInput/NumberInput.js +173 -43
  400. package/lib/components/OrderedList/OrderedList.js +7 -8
  401. package/lib/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  402. package/lib/components/OverflowMenu/OverflowMenu.js +39 -46
  403. package/lib/components/OverflowMenu/next/index.js +12 -13
  404. package/lib/components/PageHeader/PageHeader.d.ts +39 -14
  405. package/lib/components/PageHeader/PageHeader.js +185 -81
  406. package/lib/components/PageHeader/index.d.ts +2 -2
  407. package/lib/components/PageHeader/index.js +0 -2
  408. package/lib/components/Pagination/Pagination.Skeleton.js +4 -5
  409. package/lib/components/Pagination/Pagination.js +24 -25
  410. package/lib/components/Pagination/experimental/PageSelector.js +8 -9
  411. package/lib/components/Pagination/experimental/Pagination.js +20 -21
  412. package/lib/components/PaginationNav/PaginationNav.js +33 -38
  413. package/lib/components/Popover/index.js +26 -28
  414. package/lib/components/ProgressBar/ProgressBar.js +11 -12
  415. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  416. package/lib/components/ProgressIndicator/ProgressIndicator.js +29 -32
  417. package/lib/components/RadioTile/RadioTile.js +17 -18
  418. package/lib/components/Search/Search.Skeleton.js +5 -6
  419. package/lib/components/Search/Search.js +26 -29
  420. package/lib/components/Select/Select.Skeleton.js +5 -6
  421. package/lib/components/Select/Select.js +24 -25
  422. package/lib/components/SelectItem/SelectItem.js +8 -9
  423. package/lib/components/SelectItemGroup/SelectItemGroup.js +7 -8
  424. package/lib/components/ShapeIndicator/index.js +7 -8
  425. package/lib/components/SkeletonIcon/SkeletonIcon.js +4 -5
  426. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  427. package/lib/components/SkeletonText/SkeletonText.js +8 -9
  428. package/lib/components/Slider/Slider.Skeleton.js +8 -9
  429. package/lib/components/Slider/Slider.js +75 -83
  430. package/lib/components/Slider/SliderHandles.js +6 -6
  431. package/lib/components/StructuredList/StructuredList.Skeleton.js +5 -6
  432. package/lib/components/Tabs/Tabs.Skeleton.js +5 -6
  433. package/lib/components/Tabs/Tabs.js +83 -98
  434. package/lib/components/Tabs/usePressable.js +7 -8
  435. package/lib/components/Tag/DismissibleTag.js +16 -17
  436. package/lib/components/Tag/OperationalTag.js +10 -11
  437. package/lib/components/Tag/SelectableTag.js +13 -14
  438. package/lib/components/Tag/Tag.Skeleton.js +5 -6
  439. package/lib/components/Tag/Tag.js +19 -20
  440. package/lib/components/Text/Text.js +6 -7
  441. package/lib/components/Text/TextDirection.js +5 -6
  442. package/lib/components/TextArea/TextArea.js +7 -7
  443. package/lib/components/TextInput/ControlledPasswordInput.js +24 -25
  444. package/lib/components/TextInput/PasswordInput.js +26 -27
  445. package/lib/components/TextInput/TextInput.Skeleton.js +5 -6
  446. package/lib/components/TextInput/TextInput.js +27 -28
  447. package/lib/components/TextInput/util.js +14 -17
  448. package/lib/components/Theme/index.js +10 -12
  449. package/lib/components/Tile/Tile.js +68 -74
  450. package/lib/components/TileGroup/TileGroup.d.ts +4 -4
  451. package/lib/components/TileGroup/TileGroup.js +44 -52
  452. package/lib/components/TileGroup/index.d.ts +3 -3
  453. package/lib/components/Toggle/Toggle.Skeleton.js +4 -5
  454. package/lib/components/Toggle/Toggle.js +17 -18
  455. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  456. package/lib/components/Toggletip/index.js +33 -39
  457. package/lib/components/Tooltip/DefinitionTooltip.js +13 -14
  458. package/lib/components/Tooltip/Tooltip.js +15 -16
  459. package/lib/components/TreeView/TreeNode.js +20 -21
  460. package/lib/components/TreeView/TreeView.js +14 -16
  461. package/lib/components/UIShell/Content.js +6 -7
  462. package/lib/components/UIShell/Header.js +5 -6
  463. package/lib/components/UIShell/HeaderContainer.js +5 -6
  464. package/lib/components/UIShell/HeaderGlobalAction.js +12 -13
  465. package/lib/components/UIShell/HeaderMenu.d.ts +10 -112
  466. package/lib/components/UIShell/HeaderMenu.js +152 -199
  467. package/lib/components/UIShell/HeaderMenuButton.js +10 -11
  468. package/lib/components/UIShell/HeaderMenuItem.js +12 -12
  469. package/lib/components/UIShell/HeaderName.js +6 -7
  470. package/lib/components/UIShell/HeaderNavigation.js +7 -8
  471. package/lib/components/UIShell/HeaderPanel.js +9 -10
  472. package/lib/components/UIShell/HeaderSideNavItems.js +5 -6
  473. package/lib/components/UIShell/Link.js +8 -9
  474. package/lib/components/UIShell/SideNav.js +23 -25
  475. package/lib/components/UIShell/SideNavDetails.js +6 -7
  476. package/lib/components/UIShell/SideNavDivider.js +3 -4
  477. package/lib/components/UIShell/SideNavFooter.js +6 -7
  478. package/lib/components/UIShell/SideNavHeader.js +5 -6
  479. package/lib/components/UIShell/SideNavIcon.js +5 -6
  480. package/lib/components/UIShell/SideNavItem.js +5 -6
  481. package/lib/components/UIShell/SideNavItems.js +5 -6
  482. package/lib/components/UIShell/SideNavLink.js +10 -11
  483. package/lib/components/UIShell/SideNavLinkText.js +5 -6
  484. package/lib/components/UIShell/SideNavMenu.js +11 -12
  485. package/lib/components/UIShell/SkipToContent.js +7 -8
  486. package/lib/components/UIShell/Switcher.js +4 -5
  487. package/lib/components/UIShell/SwitcherDivider.js +4 -5
  488. package/lib/components/UnorderedList/UnorderedList.js +6 -7
  489. package/lib/index.js +36 -36
  490. package/lib/internal/FloatingMenu.js +26 -28
  491. package/lib/internal/Selection.js +15 -17
  492. package/lib/internal/getAnnouncement.d.ts +8 -0
  493. package/lib/internal/getAnnouncement.js +26 -0
  494. package/lib/internal/keyboard/match.js +6 -7
  495. package/lib/internal/useControllableState.d.ts +1 -1
  496. package/lib/internal/useControllableState.js +8 -9
  497. package/lib/internal/useDelayedState.js +1 -2
  498. package/lib/internal/useDocumentLang.d.ts +12 -0
  499. package/lib/internal/useId.js +2 -4
  500. package/lib/internal/useMatchMedia.js +1 -2
  501. package/lib/internal/useMergedRefs.d.ts +1 -1
  502. package/lib/internal/useNoInteractiveChildren.js +2 -4
  503. package/lib/internal/useNormalizedInputProps.js +9 -10
  504. package/lib/internal/useOverflowItems.d.ts +29 -0
  505. package/lib/internal/useOverflowItems.js +126 -0
  506. package/lib/internal/useResizeObserver.js +4 -5
  507. package/lib/internal/useSavedCallback.js +1 -3
  508. package/lib/internal/wrapFocus.js +20 -29
  509. package/lib/prop-types/deprecate.js +1 -4
  510. package/lib/prop-types/deprecateValuesWithin.js +1 -4
  511. package/lib/prop-types/isRequiredOneOf.js +1 -4
  512. package/lib/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  513. package/lib/tools/events.js +1 -4
  514. package/lib/tools/mergeRefs.js +9 -14
  515. package/lib/tools/uniqueId.js +1 -2
  516. package/lib/tools/wrapComponent.js +9 -11
  517. package/package.json +21 -19
  518. package/telemetry.yml +25 -1
  519. package/es/components/ContentSwitcher/index.js +0 -13
  520. package/es/feature-flags.d.ts +0 -7
  521. package/es/internal/useAnnouncer.js +0 -21
  522. package/lib/components/ContentSwitcher/index.js +0 -18
  523. package/lib/feature-flags.d.ts +0 -7
  524. package/lib/internal/useAnnouncer.js +0 -25
@@ -29,33 +29,32 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
29
29
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
30
30
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
31
31
 
32
- const PasswordInput = /*#__PURE__*/React__default["default"].forwardRef(function PasswordInput(_ref, ref) {
33
- let {
34
- className,
35
- disabled = false,
36
- helperText,
37
- hideLabel,
38
- hidePasswordLabel = 'Hide password',
39
- id,
40
- inline,
41
- invalid = false,
42
- invalidText,
43
- labelText,
44
- light,
45
- onChange = () => {},
46
- onClick = () => {},
47
- onTogglePasswordVisibility,
48
- placeholder,
49
- readOnly,
50
- size = 'md',
51
- showPasswordLabel = 'Show password',
52
- tooltipPosition = 'bottom',
53
- tooltipAlignment = 'end',
54
- type = 'password',
55
- warn = false,
56
- warnText,
57
- ...rest
58
- } = _ref;
32
+ const PasswordInput = /*#__PURE__*/React__default["default"].forwardRef(function PasswordInput({
33
+ className,
34
+ disabled = false,
35
+ helperText,
36
+ hideLabel,
37
+ hidePasswordLabel = 'Hide password',
38
+ id,
39
+ inline,
40
+ invalid = false,
41
+ invalidText,
42
+ labelText,
43
+ light,
44
+ onChange = () => {},
45
+ onClick = () => {},
46
+ onTogglePasswordVisibility,
47
+ placeholder,
48
+ readOnly,
49
+ size = 'md',
50
+ showPasswordLabel = 'Show password',
51
+ tooltipPosition = 'bottom',
52
+ tooltipAlignment = 'end',
53
+ type = 'password',
54
+ warn = false,
55
+ warnText,
56
+ ...rest
57
+ }, ref) {
59
58
  const [inputType, setInputType] = React.useState(type);
60
59
  const prefix = usePrefix.usePrefix();
61
60
  const normalizedProps = useNormalizedInputProps.useNormalizedInputProps({
@@ -21,12 +21,11 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
21
21
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
22
22
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
23
23
 
24
- const TextInputSkeleton = _ref => {
25
- let {
26
- hideLabel,
27
- className,
28
- ...rest
29
- } = _ref;
24
+ const TextInputSkeleton = ({
25
+ hideLabel,
26
+ className,
27
+ ...rest
28
+ }) => {
30
29
  const prefix = usePrefix.usePrefix();
31
30
  return /*#__PURE__*/React__default["default"].createElement("div", _rollupPluginBabelHelpers["extends"]({
32
31
  className: cx__default["default"](`${prefix}--form-item`, className)
@@ -18,7 +18,7 @@ var util = require('./util.js');
18
18
  require('../FluidForm/FluidForm.js');
19
19
  var FormContext = require('../FluidForm/FormContext.js');
20
20
  var usePrefix = require('../../internal/usePrefix.js');
21
- var useAnnouncer = require('../../internal/useAnnouncer.js');
21
+ var getAnnouncement = require('../../internal/getAnnouncement.js');
22
22
  require('../Text/index.js');
23
23
  var Text = require('../Text/Text.js');
24
24
 
@@ -28,32 +28,31 @@ 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
- const TextInput = /*#__PURE__*/React__default["default"].forwardRef(function TextInput(_ref, ref) {
32
- let {
33
- className,
34
- decorator,
35
- disabled = false,
36
- helperText,
37
- hideLabel,
38
- id,
39
- inline = false,
40
- invalid = false,
41
- invalidText,
42
- labelText,
43
- light,
44
- onChange = () => {},
45
- onClick = () => {},
46
- placeholder,
47
- readOnly,
48
- size,
49
- type = 'text',
50
- warn = false,
51
- warnText,
52
- enableCounter = false,
53
- maxCount,
54
- slug,
55
- ...rest
56
- } = _ref;
31
+ const TextInput = /*#__PURE__*/React__default["default"].forwardRef(function TextInput({
32
+ className,
33
+ decorator,
34
+ disabled = false,
35
+ helperText,
36
+ hideLabel,
37
+ id,
38
+ inline = false,
39
+ invalid = false,
40
+ invalidText,
41
+ labelText,
42
+ light,
43
+ onChange = () => {},
44
+ onClick = () => {},
45
+ placeholder,
46
+ readOnly,
47
+ size,
48
+ type = 'text',
49
+ warn = false,
50
+ warnText,
51
+ enableCounter = false,
52
+ maxCount,
53
+ slug,
54
+ ...rest
55
+ }, ref) {
57
56
  const prefix = usePrefix.usePrefix();
58
57
  const {
59
58
  defaultValue,
@@ -164,7 +163,7 @@ const TextInput = /*#__PURE__*/React__default["default"].forwardRef(function Tex
164
163
  } = React.useContext(FormContext.FormContext);
165
164
  const announcerRef = React.useRef(null);
166
165
  const [prevAnnouncement, setPrevAnnouncement] = React.useState('');
167
- const ariaAnnouncement = useAnnouncer.useAnnouncer(textCount, maxCount);
166
+ const ariaAnnouncement = getAnnouncement.getAnnouncement(textCount, maxCount);
168
167
  React.useEffect(() => {
169
168
  if (ariaAnnouncement && ariaAnnouncement !== prevAnnouncement) {
170
169
  const announcer = announcerRef.current;
@@ -25,22 +25,19 @@ const helperProps = helperId => ({
25
25
  * @param {{sharedTextInputProps: object, invalid?: boolean, invalidId?: string, warn?: boolean, warnId?: string, hasHelper?: boolean, helperId?: string}} config
26
26
  * @returns {object}
27
27
  */
28
- const textInputProps = _ref => {
29
- let {
30
- sharedTextInputProps,
31
- invalid,
32
- invalidId,
33
- warn,
34
- warnId,
35
- hasHelper,
36
- helperId
37
- } = _ref;
38
- return {
39
- ...sharedTextInputProps,
40
- ...(invalid ? invalidProps(invalidId) : {}),
41
- ...(warn ? warnProps(warnId) : {}),
42
- ...(hasHelper ? helperProps(helperId) : {})
43
- };
44
- };
28
+ const textInputProps = ({
29
+ sharedTextInputProps,
30
+ invalid,
31
+ invalidId,
32
+ warn,
33
+ warnId,
34
+ hasHelper,
35
+ helperId
36
+ }) => ({
37
+ ...sharedTextInputProps,
38
+ ...(invalid ? invalidProps(invalidId) : {}),
39
+ ...(warn ? warnProps(warnId) : {}),
40
+ ...(hasHelper ? helperProps(helperId) : {})
41
+ });
45
42
 
46
43
  exports.textInputProps = textInputProps;
@@ -26,11 +26,10 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
26
26
  const ThemeContext = /*#__PURE__*/React__default["default"].createContext({
27
27
  theme: 'white'
28
28
  });
29
- const GlobalTheme = /*#__PURE__*/React__default["default"].forwardRef(function GlobalTheme(_ref, ref) {
30
- let {
31
- children,
32
- theme
33
- } = _ref;
29
+ const GlobalTheme = /*#__PURE__*/React__default["default"].forwardRef(function GlobalTheme({
30
+ children,
31
+ theme
32
+ }, ref) {
34
33
  const value = React.useMemo(() => {
35
34
  return {
36
35
  theme
@@ -57,13 +56,12 @@ GlobalTheme.propTypes = {
57
56
  /**
58
57
  * Specify the theme to be applied to a page, or a region in a page
59
58
  */
60
- function Theme(_ref2) {
61
- let {
62
- as: BaseComponent = 'div',
63
- className: customClassName,
64
- theme,
65
- ...rest
66
- } = _ref2;
59
+ function Theme({
60
+ as: BaseComponent = 'div',
61
+ className: customClassName,
62
+ theme,
63
+ ...rest
64
+ }) {
67
65
  const prefix = usePrefix.usePrefix();
68
66
  const className = cx__default["default"](customClassName, {
69
67
  [`${prefix}--white`]: theme === 'white',
@@ -35,16 +35,15 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
35
35
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
36
36
 
37
37
  var _CheckboxCheckedFille, _Checkbox, _ChevronDown, _ChevronDown2;
38
- const Tile = /*#__PURE__*/React__default["default"].forwardRef(function Tile(_ref, ref) {
39
- let {
40
- children,
41
- className,
42
- decorator,
43
- light = false,
44
- slug,
45
- hasRoundedCorners = false,
46
- ...rest
47
- } = _ref;
38
+ const Tile = /*#__PURE__*/React__default["default"].forwardRef(function Tile({
39
+ children,
40
+ className,
41
+ decorator,
42
+ light = false,
43
+ slug,
44
+ hasRoundedCorners = false,
45
+ ...rest
46
+ }, ref) {
48
47
  const prefix = usePrefix.usePrefix();
49
48
  const tileClasses = cx__default["default"](`${prefix}--tile`, {
50
49
  [`${prefix}--tile--light`]: light,
@@ -91,22 +90,21 @@ Tile.propTypes = {
91
90
  */
92
91
  slug: deprecate["default"](PropTypes__default["default"].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.')
93
92
  };
94
- const ClickableTile = /*#__PURE__*/React__default["default"].forwardRef(function ClickableTile(_ref2, ref) {
95
- let {
96
- children,
97
- className,
98
- clicked = false,
99
- decorator,
100
- disabled,
101
- href,
102
- light,
103
- onClick = () => {},
104
- onKeyDown = () => {},
105
- renderIcon: Icon,
106
- hasRoundedCorners,
107
- slug,
108
- ...rest
109
- } = _ref2;
93
+ const ClickableTile = /*#__PURE__*/React__default["default"].forwardRef(function ClickableTile({
94
+ children,
95
+ className,
96
+ clicked = false,
97
+ decorator,
98
+ disabled,
99
+ href,
100
+ light,
101
+ onClick = () => {},
102
+ onKeyDown = () => {},
103
+ renderIcon: Icon,
104
+ hasRoundedCorners,
105
+ slug,
106
+ ...rest
107
+ }, ref) {
110
108
  const prefix = usePrefix.usePrefix();
111
109
  const classes = cx__default["default"](`${prefix}--tile`, `${prefix}--tile--clickable`, {
112
110
  [`${prefix}--tile--is-clicked`]: clicked,
@@ -215,24 +213,23 @@ ClickableTile.propTypes = {
215
213
  */
216
214
  renderIcon: PropTypes__default["default"].oneOfType([PropTypes__default["default"].func, PropTypes__default["default"].object])
217
215
  };
218
- const SelectableTile = /*#__PURE__*/React__default["default"].forwardRef(function SelectableTile(_ref3, ref) {
219
- let {
220
- children,
221
- className,
222
- decorator,
223
- disabled,
224
- id,
225
- light,
226
- onClick = () => {},
227
- onChange = () => {},
228
- onKeyDown = () => {},
229
- selected = false,
230
- tabIndex = 0,
231
- title = 'title',
232
- slug,
233
- hasRoundedCorners,
234
- ...rest
235
- } = _ref3;
216
+ const SelectableTile = /*#__PURE__*/React__default["default"].forwardRef(function SelectableTile({
217
+ children,
218
+ className,
219
+ decorator,
220
+ disabled,
221
+ id,
222
+ light,
223
+ onClick = () => {},
224
+ onChange = () => {},
225
+ onKeyDown = () => {},
226
+ selected = false,
227
+ tabIndex = 0,
228
+ title = 'title',
229
+ slug,
230
+ hasRoundedCorners,
231
+ ...rest
232
+ }, ref) {
236
233
  const prefix = usePrefix.usePrefix();
237
234
  const clickHandler = onClick;
238
235
  const keyDownHandler = onKeyDown;
@@ -382,28 +379,27 @@ SelectableTile.propTypes = {
382
379
  */
383
380
  value: deprecate["default"](PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].number]), 'The `value` property is no longer used. It will be removed in the next major release.`')
384
381
  };
385
- const ExpandableTile = /*#__PURE__*/React__default["default"].forwardRef(function ExpandableTile(_ref4, forwardRef) {
386
- let {
387
- tabIndex = 0,
388
- className,
389
- children,
390
- decorator,
391
- expanded = false,
392
- tileMaxHeight = 0,
393
- // eslint-disable-line
394
- tilePadding = 0,
395
- // eslint-disable-line
396
- onClick,
397
- onKeyUp,
398
- tileCollapsedIconText = 'Interact to expand Tile',
399
- tileExpandedIconText = 'Interact to collapse Tile',
400
- tileCollapsedLabel,
401
- tileExpandedLabel,
402
- light,
403
- slug,
404
- hasRoundedCorners,
405
- ...rest
406
- } = _ref4;
382
+ const ExpandableTile = /*#__PURE__*/React__default["default"].forwardRef(function ExpandableTile({
383
+ tabIndex = 0,
384
+ className,
385
+ children,
386
+ decorator,
387
+ expanded = false,
388
+ tileMaxHeight = 0,
389
+ // eslint-disable-line
390
+ tilePadding = 0,
391
+ // eslint-disable-line
392
+ onClick,
393
+ onKeyUp,
394
+ tileCollapsedIconText = 'Interact to expand Tile',
395
+ tileExpandedIconText = 'Interact to collapse Tile',
396
+ tileCollapsedLabel,
397
+ tileExpandedLabel,
398
+ light,
399
+ slug,
400
+ hasRoundedCorners,
401
+ ...rest
402
+ }, forwardRef) {
407
403
  const [isTileMaxHeight, setIsTileMaxHeight] = React.useState(tileMaxHeight);
408
404
  const [isTilePadding, setIsTilePadding] = React.useState(tilePadding);
409
405
  const [prevExpanded, setPrevExpanded] = React.useState(expanded);
@@ -629,10 +625,9 @@ ExpandableTile.propTypes = {
629
625
  tileExpandedLabel: PropTypes__default["default"].string
630
626
  };
631
627
  ExpandableTile.displayName = 'ExpandableTile';
632
- const TileAboveTheFoldContent = /*#__PURE__*/React__default["default"].forwardRef(function TilAboveTheFoldContent(_ref5, ref) {
633
- let {
634
- children
635
- } = _ref5;
628
+ const TileAboveTheFoldContent = /*#__PURE__*/React__default["default"].forwardRef(function TilAboveTheFoldContent({
629
+ children
630
+ }, ref) {
636
631
  const prefix = usePrefix.usePrefix();
637
632
  return /*#__PURE__*/React__default["default"].createElement("div", {
638
633
  ref: ref,
@@ -646,10 +641,9 @@ TileAboveTheFoldContent.propTypes = {
646
641
  children: PropTypes__default["default"].node
647
642
  };
648
643
  TileAboveTheFoldContent.displayName = 'TileAboveTheFoldContent';
649
- const TileBelowTheFoldContent = /*#__PURE__*/React__default["default"].forwardRef(function TileBelowTheFoldContent(_ref6, ref) {
650
- let {
651
- children
652
- } = _ref6;
644
+ const TileBelowTheFoldContent = /*#__PURE__*/React__default["default"].forwardRef(function TileBelowTheFoldContent({
645
+ children
646
+ }, ref) {
653
647
  const prefix = usePrefix.usePrefix();
654
648
  return /*#__PURE__*/React__default["default"].createElement("div", {
655
649
  ref: ref,
@@ -45,8 +45,9 @@ export interface TileGroupProps extends Omit<HTMLAttributes<HTMLFieldSetElement>
45
45
  */
46
46
  required?: boolean;
47
47
  }
48
- declare const TileGroup: {
49
- (props: any): import("react/jsx-runtime").JSX.Element;
48
+ export declare const TileGroup: {
49
+ ({ children, className, defaultSelected, disabled, legend, name, onChange, valueSelected, required, }: TileGroupProps): import("react/jsx-runtime").JSX.Element;
50
+ displayName: string;
50
51
  propTypes: {
51
52
  /**
52
53
  * Provide a collection of <RadioTile> components to render in the group
@@ -86,6 +87,5 @@ declare const TileGroup: {
86
87
  */
87
88
  valueSelected: PropTypes.Requireable<NonNullable<string | number | null | undefined>>;
88
89
  };
89
- displayName: string;
90
90
  };
91
- export default TileGroup;
91
+ export {};
@@ -21,35 +21,37 @@ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'defau
21
21
  var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
22
22
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
23
23
 
24
- const TileGroup = props => {
25
- const {
26
- children,
27
- className,
28
- defaultSelected,
29
- disabled,
30
- legend,
31
- name,
32
- onChange = noopFn.noopFn,
33
- valueSelected,
34
- required
35
- } = props;
24
+ const TileGroup = ({
25
+ children,
26
+ className,
27
+ defaultSelected,
28
+ disabled,
29
+ legend,
30
+ name,
31
+ onChange = noopFn.noopFn,
32
+ valueSelected,
33
+ required
34
+ }) => {
36
35
  const prefix = usePrefix.usePrefix();
37
36
  const [selected, setSelected] = React.useState(valueSelected ?? defaultSelected);
38
- const [prevValueSelected, setPrevValueSelected] = React.useState(valueSelected);
37
+ React.useEffect(() => {
38
+ if (typeof valueSelected !== 'undefined' && valueSelected !== selected) {
39
+ setSelected(valueSelected);
40
+ }
41
+ }, [valueSelected, selected]);
42
+ const handleChange = (value, name, evt) => {
43
+ if (value !== selected) {
44
+ setSelected(value);
45
+ onChange(value, name ?? '', evt);
46
+ }
47
+ };
48
+ const getRadioTilesWithWrappers = elements => {
49
+ const traverseAndModifyChildren = elements => {
50
+ return React.Children.map(elements, child => {
51
+ if (! /*#__PURE__*/React.isValidElement(child)) return child;
39
52
 
40
- /**
41
- * prop + state alignment - getDerivedStateFromProps
42
- * only update if selected prop changes
43
- */
44
- if (valueSelected !== prevValueSelected) {
45
- setSelected(valueSelected);
46
- setPrevValueSelected(valueSelected);
47
- }
48
- const getRadioTilesWithWrappers = children => {
49
- const traverseAndModifyChildren = children => {
50
- return React__default["default"].Children.map(children, child => {
51
- // If RadioTile found, return it with necessary props
52
- if (child?.type === RadioTile["default"]) {
53
+ // If a `RadioTile` is found, return it with necessary props,
54
+ if (/*#__PURE__*/React.isValidElement(child) && child.type === RadioTile["default"]) {
53
55
  const {
54
56
  value,
55
57
  ...otherProps
@@ -62,38 +64,29 @@ const TileGroup = props => {
62
64
  onChange: handleChange,
63
65
  checked: value === selected
64
66
  }));
65
- } else if (child?.props?.children) {
66
- // If the child is not RadioTile and has children, recheck the children
67
- return /*#__PURE__*/React__default["default"].cloneElement(child, {
68
- ...child.props,
69
- children: traverseAndModifyChildren(child.props.children)
70
- });
71
- } else {
72
- // If the child is neither a RadioTile nor has children, return it as is
73
- return child;
74
67
  }
68
+
69
+ // If the child is not RadioTile and has children, recheck the children
70
+ const children = child.props.children;
71
+ const hasChildren = React.Children.count(children) > 0;
72
+ if (hasChildren) {
73
+ return /*#__PURE__*/React.cloneElement(child, undefined, traverseAndModifyChildren(children));
74
+ }
75
+
76
+ // If the child is neither a RadioTile nor has children, return it as is
77
+ return child;
75
78
  });
76
79
  };
77
- return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, traverseAndModifyChildren(children));
78
- };
79
- const handleChange = (newSelection, value, evt) => {
80
- if (newSelection !== selected) {
81
- setSelected(newSelection);
82
- onChange(newSelection, name, evt);
83
- }
84
- };
85
- const renderLegend = legend => {
86
- if (legend) {
87
- return /*#__PURE__*/React__default["default"].createElement("legend", {
88
- className: `${prefix}--label`
89
- }, legend);
90
- }
80
+ return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, traverseAndModifyChildren(elements));
91
81
  };
92
82
  return /*#__PURE__*/React__default["default"].createElement("fieldset", {
93
83
  className: className ?? `${prefix}--tile-group`,
94
84
  disabled: disabled
95
- }, renderLegend(legend), /*#__PURE__*/React__default["default"].createElement("div", null, getRadioTilesWithWrappers(children)));
85
+ }, legend && /*#__PURE__*/React__default["default"].createElement("legend", {
86
+ className: `${prefix}--label`
87
+ }, legend), /*#__PURE__*/React__default["default"].createElement("div", null, getRadioTilesWithWrappers(children)));
96
88
  };
89
+ TileGroup.displayName = 'TileGroup';
97
90
  TileGroup.propTypes = {
98
91
  /**
99
92
  * Provide a collection of <RadioTile> components to render in the group
@@ -133,6 +126,5 @@ TileGroup.propTypes = {
133
126
  */
134
127
  valueSelected: PropTypes__default["default"].oneOfType([PropTypes__default["default"].string, PropTypes__default["default"].number])
135
128
  };
136
- TileGroup.displayName = 'TileGroup';
137
129
 
138
- exports["default"] = TileGroup;
130
+ exports.TileGroup = TileGroup;
@@ -1,9 +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 TileGroup, { type TileGroupProps } from './TileGroup';
7
+ import { TileGroup } from './TileGroup';
8
8
  export default TileGroup;
9
- export { TileGroup, type TileGroupProps };
9
+ export * from './TileGroup';
@@ -21,11 +21,10 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
21
21
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
22
22
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
23
23
 
24
- const ToggleSkeleton = _ref => {
25
- let {
26
- className,
27
- ...rest
28
- } = _ref;
24
+ const ToggleSkeleton = ({
25
+ className,
26
+ ...rest
27
+ }) => {
29
28
  const prefix = usePrefix.usePrefix();
30
29
  const skeletonClassNames = cx__default["default"](`${prefix}--toggle ${prefix}--toggle--skeleton`, className);
31
30
  return /*#__PURE__*/React__default["default"].createElement("div", _rollupPluginBabelHelpers["extends"]({
@@ -25,24 +25,23 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
25
25
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
26
26
 
27
27
  var _path;
28
- function Toggle(_ref) {
29
- let {
30
- 'aria-labelledby': ariaLabelledby,
31
- className,
32
- defaultToggled = false,
33
- disabled = false,
34
- hideLabel = false,
35
- id,
36
- labelA = 'Off',
37
- labelB = 'On',
38
- labelText,
39
- onClick,
40
- onToggle,
41
- readOnly,
42
- size = 'md',
43
- toggled,
44
- ...other
45
- } = _ref;
28
+ function Toggle({
29
+ 'aria-labelledby': ariaLabelledby,
30
+ className,
31
+ defaultToggled = false,
32
+ disabled = false,
33
+ hideLabel = false,
34
+ id,
35
+ labelA = 'Off',
36
+ labelB = 'On',
37
+ labelText,
38
+ onClick,
39
+ onToggle,
40
+ readOnly,
41
+ size = 'md',
42
+ toggled,
43
+ ...other
44
+ }) {
46
45
  const prefix = usePrefix.usePrefix();
47
46
  const buttonElement = React.useRef(null);
48
47
  const [checked, setChecked] = useControllableState.useControllableState({
@@ -22,13 +22,12 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
22
22
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
23
23
 
24
24
  var _path;
25
- const ToggleSmallSkeleton = _ref => {
26
- let {
27
- id,
28
- labelText,
29
- className,
30
- ...rest
31
- } = _ref;
25
+ const ToggleSmallSkeleton = ({
26
+ id,
27
+ labelText,
28
+ className,
29
+ ...rest
30
+ }) => {
32
31
  const prefix = React.useContext(usePrefix.PrefixContext);
33
32
  return /*#__PURE__*/React__default["default"].createElement("div", _rollupPluginBabelHelpers["extends"]({
34
33
  className: cx__default["default"](`${prefix}--form-item`, className)