@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
@@ -7,26 +7,50 @@
7
7
 
8
8
  import { extends as _extends } from '../../_virtual/_rollupPluginBabelHelpers.js';
9
9
  import PropTypes from 'prop-types';
10
- import React, { useRef, useEffect } from 'react';
10
+ import React, { useRef, useEffect, useContext, useState, createContext } from 'react';
11
+ import useIsomorphicEffect from '../../internal/useIsomorphicEffect.js';
11
12
  import { usePrefix } from '../../internal/usePrefix.js';
12
13
  import cx from 'classnames';
13
14
  import { Close } from '@carbon/icons-react';
14
15
  import { IconButton } from '../IconButton/index.js';
15
16
  import { noopFn } from '../../internal/noopFn.js';
17
+ import '../Text/index.js';
18
+ import { Layer } from '../Layer/index.js';
19
+ import ButtonSet from '../ButtonSet/ButtonSet.js';
20
+ import Button from '../Button/Button.js';
21
+ import '../Button/Button.Skeleton.js';
22
+ import { useId } from '../../internal/useId.js';
23
+ import InlineLoading from '../InlineLoading/InlineLoading.js';
24
+ import { debounce } from '../../node_modules/es-toolkit/dist/compat/function/debounce.mjs.js';
25
+ import { Text } from '../Text/Text.js';
16
26
 
17
- const unstable__Dialog = /*#__PURE__*/React.forwardRef((_ref, forwardRef) => {
18
- let {
19
- children,
20
- className,
21
- modal,
22
- onCancel = noopFn,
23
- onClick = noopFn,
24
- onClose = noopFn,
25
- onRequestClose = noopFn,
26
- open = false,
27
- ...rest
28
- } = _ref;
27
+ const DialogContext = /*#__PURE__*/createContext({});
28
+
29
+ /**
30
+ * ----------
31
+ * Dialog
32
+ * ----------
33
+ */
34
+
35
+ const unstable__Dialog = /*#__PURE__*/React.forwardRef(({
36
+ children,
37
+ className,
38
+ modal,
39
+ onCancel = noopFn,
40
+ onClick = noopFn,
41
+ onClose = noopFn,
42
+ onRequestClose = noopFn,
43
+ open = false,
44
+ role,
45
+ ariaLabel,
46
+ ariaLabelledBy,
47
+ ariaDescribedBy,
48
+ ...rest
49
+ }, forwardRef) => {
29
50
  const prefix = usePrefix();
51
+ const dialogId = useId();
52
+ const titleId = `${prefix}--dialog-header__heading--${dialogId}`;
53
+ const subtitleId = `${prefix}--dialog-header__label--${dialogId}`;
30
54
 
31
55
  // This component needs access to a ref, placed on the dialog, to call the
32
56
  // various imperative dialog functions (show(), close(), etc.).
@@ -69,15 +93,40 @@ const unstable__Dialog = /*#__PURE__*/React.forwardRef((_ref, forwardRef) => {
69
93
  }
70
94
  }
71
95
  }, [modal, open]);
72
- return /*#__PURE__*/React.createElement("dialog", _extends({}, rest, {
96
+ const containerClasses = cx(`${prefix}--dialog-container`);
97
+ const contextValue = {
98
+ dialogId,
99
+ titleId,
100
+ subtitleId,
101
+ isOpen: open
102
+ };
103
+ useEffect(() => {
104
+ if (ref.current && open && !ariaLabel && !ariaLabelledBy) {
105
+ const title = ref.current.querySelector(`.${prefix}--dialog-header__heading`);
106
+
107
+ // Set aria-labelledby to the title's ID if it exists
108
+ if (title && title.id) {
109
+ ref.current.setAttribute('aria-labelledby', title.id);
110
+ }
111
+ }
112
+ }, [open, ariaLabel, ariaLabelledBy, prefix]);
113
+ return /*#__PURE__*/React.createElement(DialogContext.Provider, {
114
+ value: contextValue
115
+ }, /*#__PURE__*/React.createElement("dialog", _extends({}, rest, {
73
116
  className: cx(`${prefix}--dialog`, {
74
117
  [`${prefix}--dialog--modal`]: modal
75
118
  }, className),
76
119
  ref: ref,
77
120
  onCancel: onCancel,
78
121
  onClick: handleClick,
79
- onClose: onClose
80
- }), children);
122
+ onClose: onClose,
123
+ role: role,
124
+ "aria-label": ariaLabel,
125
+ "aria-labelledby": !ariaLabel ? ariaLabelledBy || titleId : undefined,
126
+ "aria-describedby": ariaDescribedBy
127
+ }), /*#__PURE__*/React.createElement("div", {
128
+ className: containerClasses
129
+ }, children)));
81
130
  });
82
131
  unstable__Dialog.displayName = 'Dialog';
83
132
  unstable__Dialog.propTypes = {
@@ -102,30 +151,59 @@ unstable__Dialog.propTypes = {
102
151
  /**
103
152
  * open initial state
104
153
  */
105
- open: PropTypes.bool
154
+ open: PropTypes.bool,
155
+ /**
156
+ * Specify the role of the dialog for accessibility
157
+ */
158
+ role: PropTypes.oneOf(['dialog', 'alertdialog']),
159
+ /**
160
+ * Specify a label for screen readers
161
+ */
162
+ 'aria-label': PropTypes.string,
163
+ /**
164
+ * Specify the ID of an element that labels this dialog
165
+ */
166
+ 'aria-labelledby': PropTypes.string,
167
+ /**
168
+ * Specify the ID of an element that describes this dialog
169
+ */
170
+ ariaDescribedBy: PropTypes.string
106
171
  };
107
- const DialogHeader = /*#__PURE__*/React.forwardRef((_ref2, ref) => {
108
- let {
109
- children,
110
- ...rest
111
- } = _ref2;
172
+
173
+ /**
174
+ * -------------
175
+ * DialogHeader
176
+ * -------------
177
+ */
178
+
179
+ const DialogHeader = /*#__PURE__*/React.forwardRef(({
180
+ children,
181
+ ...rest
182
+ }, ref) => {
112
183
  const prefix = usePrefix();
113
184
  return /*#__PURE__*/React.createElement("div", _extends({
114
185
  className: `${prefix}--dialog__header`,
115
186
  ref: ref
116
187
  }, rest), children);
117
188
  });
189
+ DialogHeader.displayName = 'DialogHeader';
118
190
  DialogHeader.propTypes = {
119
191
  /**
120
192
  * Provide the contents to be rendered inside of this component
121
193
  */
122
194
  children: PropTypes.node
123
195
  };
124
- const DialogControls = /*#__PURE__*/React.forwardRef((_ref3, ref) => {
125
- let {
126
- children,
127
- ...rest
128
- } = _ref3;
196
+
197
+ /**
198
+ * ---------------
199
+ * DialogControls
200
+ * ---------------
201
+ */
202
+
203
+ const DialogControls = /*#__PURE__*/React.forwardRef(({
204
+ children,
205
+ ...rest
206
+ }, ref) => {
129
207
  const prefix = usePrefix();
130
208
  return (
131
209
  /*#__PURE__*/
@@ -136,17 +214,24 @@ const DialogControls = /*#__PURE__*/React.forwardRef((_ref3, ref) => {
136
214
  }, rest), children)
137
215
  );
138
216
  });
217
+ DialogControls.displayName = 'DialogControls';
139
218
  DialogControls.propTypes = {
140
219
  /**
141
220
  * Provide children to be rendered inside of this component
142
221
  */
143
222
  children: PropTypes.node
144
223
  };
145
- const DialogCloseButton = /*#__PURE__*/React.forwardRef((_ref4, ref) => {
146
- let {
147
- onClick,
148
- ...rest
149
- } = _ref4;
224
+
225
+ /**
226
+ * -------------------
227
+ * DialogCloseButton
228
+ * -------------------
229
+ */
230
+
231
+ const DialogCloseButton = /*#__PURE__*/React.forwardRef(({
232
+ onClick,
233
+ ...rest
234
+ }, ref) => {
150
235
  const prefix = usePrefix();
151
236
  return (
152
237
  /*#__PURE__*/
@@ -158,15 +243,17 @@ const DialogCloseButton = /*#__PURE__*/React.forwardRef((_ref4, ref) => {
158
243
  title: "Close",
159
244
  "aria-label": "Close",
160
245
  align: "left",
161
- onClick: onClick
246
+ onClick: onClick,
247
+ ref: ref
162
248
  }, rest), /*#__PURE__*/React.createElement(Close, {
163
249
  size: 20,
164
250
  "aria-hidden": "true",
165
- tabIndex: "-1",
251
+ tabIndex: -1,
166
252
  className: `${prefix}--icon__close`
167
253
  }))
168
254
  );
169
255
  });
256
+ DialogCloseButton.displayName = 'DialogCloseButton';
170
257
  DialogCloseButton.propTypes = {
171
258
  /**
172
259
  * Specify a click handler applied to the IconButton
@@ -174,4 +261,336 @@ DialogCloseButton.propTypes = {
174
261
  onClick: PropTypes.func
175
262
  };
176
263
 
177
- export { DialogCloseButton, DialogControls, DialogHeader, unstable__Dialog };
264
+ /**
265
+ * ------------
266
+ * DialogTitle
267
+ * ------------
268
+ */
269
+
270
+ const DialogTitle = /*#__PURE__*/React.forwardRef(({
271
+ children,
272
+ className,
273
+ id,
274
+ ...rest
275
+ }, ref) => {
276
+ const prefix = usePrefix();
277
+ const {
278
+ titleId
279
+ } = useContext(DialogContext);
280
+ const headingId = id || titleId;
281
+ return /*#__PURE__*/React.createElement(Text, _extends({
282
+ as: "h2",
283
+ id: headingId,
284
+ className: cx(`${prefix}--dialog-header__heading`, className),
285
+ ref: ref
286
+ }, rest), children);
287
+ });
288
+ DialogTitle.displayName = 'DialogTitle';
289
+ DialogTitle.propTypes = {
290
+ /**
291
+ * Provide the contents to be rendered inside of this component
292
+ */
293
+ children: PropTypes.node,
294
+ /**
295
+ * Specify an optional className to be applied to the title node
296
+ */
297
+ className: PropTypes.string,
298
+ /**
299
+ * Specify an optional id for the title element
300
+ */
301
+ id: PropTypes.string
302
+ };
303
+
304
+ /**
305
+ * ---------------
306
+ * DialogSubtitle
307
+ * ---------------
308
+ */
309
+
310
+ const DialogSubtitle = /*#__PURE__*/React.forwardRef(({
311
+ children,
312
+ className,
313
+ id,
314
+ ...rest
315
+ }, ref) => {
316
+ const prefix = usePrefix();
317
+ const {
318
+ subtitleId
319
+ } = useContext(DialogContext);
320
+ const labelId = id || subtitleId;
321
+ return /*#__PURE__*/React.createElement(Text, _extends({
322
+ as: "h2",
323
+ id: labelId,
324
+ className: cx(`${prefix}--dialog-header__label`, className),
325
+ ref: ref
326
+ }, rest), children);
327
+ });
328
+ DialogSubtitle.displayName = 'DialogSubtitle';
329
+ DialogSubtitle.propTypes = {
330
+ /**
331
+ * Provide the contents to be rendered inside of this component
332
+ */
333
+ children: PropTypes.node,
334
+ /**
335
+ * Specify an optional className to be applied to the subtitle node
336
+ */
337
+ className: PropTypes.string,
338
+ /**
339
+ * Specify an optional id for the subtitle element
340
+ */
341
+ id: PropTypes.string
342
+ };
343
+
344
+ /**
345
+ * -----------
346
+ * DialogBody
347
+ * -----------
348
+ */
349
+
350
+ const DialogBody = /*#__PURE__*/React.forwardRef(({
351
+ children,
352
+ className,
353
+ hasScrollingContent,
354
+ ...rest
355
+ }, ref) => {
356
+ const prefix = usePrefix();
357
+ const contentRef = useRef(null);
358
+ const [isScrollable, setIsScrollable] = useState(false);
359
+ const dialogId = useId();
360
+ const dialogBodyId = `${prefix}--dialog-body--${dialogId}`;
361
+ useIsomorphicEffect(() => {
362
+ if (contentRef.current) {
363
+ setIsScrollable(contentRef.current.scrollHeight > contentRef.current.clientHeight);
364
+ }
365
+ function handler() {
366
+ if (contentRef.current) {
367
+ setIsScrollable(contentRef.current.scrollHeight > contentRef.current.clientHeight);
368
+ }
369
+ }
370
+ const debouncedHandler = debounce(handler, 200);
371
+ window.addEventListener('resize', debouncedHandler);
372
+ return () => {
373
+ debouncedHandler.cancel();
374
+ window.removeEventListener('resize', debouncedHandler);
375
+ };
376
+ }, []);
377
+ const contentClasses = cx(`${prefix}--dialog-content`, {
378
+ [`${prefix}--dialog-scroll-content`]: hasScrollingContent || isScrollable
379
+ }, className);
380
+ const hasScrollingContentProps = hasScrollingContent || isScrollable ? {
381
+ tabIndex: 0,
382
+ role: 'region'
383
+ } : {};
384
+ const combinedRef = el => {
385
+ if (typeof ref === 'function') {
386
+ ref(el);
387
+ } else if (ref) {
388
+ ref.current = el;
389
+ }
390
+ contentRef.current = el;
391
+ };
392
+ return /*#__PURE__*/React.createElement(Layer, _extends({
393
+ ref: combinedRef,
394
+ id: dialogBodyId,
395
+ className: contentClasses
396
+ }, hasScrollingContentProps, rest), children);
397
+ });
398
+ DialogBody.displayName = 'DialogBody';
399
+ DialogBody.propTypes = {
400
+ /**
401
+ * Provide the contents to be rendered inside of this component
402
+ */
403
+ children: PropTypes.node,
404
+ /**
405
+ * Specify an optional className to be applied to the body node
406
+ */
407
+ className: PropTypes.string,
408
+ /**
409
+ * Specify whether the content has overflow that should be scrollable
410
+ */
411
+ hasScrollingContent: PropTypes.bool
412
+ };
413
+
414
+ /**
415
+ * -------------
416
+ * DialogFooter
417
+ * -------------
418
+ */
419
+
420
+ const DialogFooter = /*#__PURE__*/React.forwardRef(({
421
+ children,
422
+ className,
423
+ onRequestClose = noopFn,
424
+ onSecondarySubmit,
425
+ onRequestSubmit = noopFn,
426
+ primaryButtonText = 'Save',
427
+ primaryButtonDisabled = false,
428
+ secondaryButtonText = 'Cancel',
429
+ secondaryButtons,
430
+ loadingStatus = 'inactive',
431
+ loadingDescription,
432
+ loadingIconDescription,
433
+ onLoadingSuccess = noopFn,
434
+ danger = false,
435
+ ...rest
436
+ }, ref) => {
437
+ const prefix = usePrefix();
438
+ const button = useRef(null);
439
+ const {
440
+ isOpen
441
+ } = useContext(DialogContext);
442
+ const [secondaryButtonRef, setSecondaryButtonRef] = useState(null);
443
+ useEffect(() => {
444
+ if (danger && secondaryButtonRef) {
445
+ const focusFrame = requestAnimationFrame(() => {
446
+ secondaryButtonRef.focus();
447
+ });
448
+ return () => cancelAnimationFrame(focusFrame);
449
+ }
450
+ }, [danger, secondaryButtonRef, isOpen]);
451
+ const classes = cx(`${prefix}--dialog-footer`, className, {
452
+ [`${prefix}--dialog-footer--three-button`]: Array.isArray(secondaryButtons) && secondaryButtons.length === 2
453
+ });
454
+ const loadingActive = loadingStatus !== 'inactive';
455
+ const primaryButtonClass = cx({
456
+ [`${prefix}--btn--loading`]: loadingStatus !== 'inactive'
457
+ });
458
+ const onSecondaryButtonClick = onSecondarySubmit ? onSecondarySubmit : onRequestClose;
459
+ if (children) {
460
+ return /*#__PURE__*/React.createElement(ButtonSet, _extends({
461
+ className: classes,
462
+ ref: ref
463
+ }, rest), children);
464
+ }
465
+ return /*#__PURE__*/React.createElement(ButtonSet, _extends({
466
+ className: classes,
467
+ "aria-busy": loadingActive,
468
+ ref: ref
469
+ }, rest), Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map(({
470
+ buttonText,
471
+ onClick: onButtonClick
472
+ }, i) => /*#__PURE__*/React.createElement(Button, {
473
+ key: `${buttonText}-${i}`,
474
+ autoFocus: danger,
475
+ kind: "secondary",
476
+ ref: i === 0 && danger ? setSecondaryButtonRef : undefined,
477
+ onClick: onButtonClick
478
+ }, buttonText)) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
479
+ ref: danger ? setSecondaryButtonRef : undefined,
480
+ disabled: loadingActive,
481
+ kind: "secondary",
482
+ autoFocus: danger,
483
+ onClick: onSecondaryButtonClick
484
+ }, secondaryButtonText), /*#__PURE__*/React.createElement(Button, {
485
+ className: primaryButtonClass,
486
+ kind: danger ? 'danger' : 'primary',
487
+ disabled: loadingActive || primaryButtonDisabled,
488
+ onClick: onRequestSubmit,
489
+ ref: button
490
+ }, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/React.createElement(InlineLoading, {
491
+ status: loadingStatus,
492
+ description: loadingDescription,
493
+ iconDescription: loadingIconDescription,
494
+ className: `${prefix}--inline-loading--btn`,
495
+ onSuccess: onLoadingSuccess
496
+ })));
497
+ });
498
+ DialogFooter.displayName = 'DialogFooter';
499
+ DialogFooter.propTypes = {
500
+ /**
501
+ * Provide the contents to be rendered inside of this component
502
+ */
503
+ children: PropTypes.node,
504
+ /**
505
+ * Specify an optional className to be applied to the footer node
506
+ */
507
+ className: PropTypes.string,
508
+ /**
509
+ * Specify a handler for closing dialog.
510
+ */
511
+ onRequestClose: PropTypes.func,
512
+ /**
513
+ * Specify a handler for the secondary button.
514
+ */
515
+ onSecondarySubmit: PropTypes.func,
516
+ /**
517
+ * Specify a handler for submitting dialog.
518
+ */
519
+ onRequestSubmit: PropTypes.func,
520
+ /**
521
+ * Specify the text for the primary button
522
+ */
523
+ primaryButtonText: PropTypes.node,
524
+ /**
525
+ * Specify whether the Button should be disabled, or not
526
+ */
527
+ primaryButtonDisabled: PropTypes.bool,
528
+ /**
529
+ * Specify the text for the secondary button
530
+ */
531
+ secondaryButtonText: PropTypes.node,
532
+ /**
533
+ * Specify an array of config objects for secondary buttons
534
+ */
535
+ secondaryButtons: (props, propName, componentName) => {
536
+ if (props.secondaryButtons) {
537
+ if (!Array.isArray(props.secondaryButtons) || props.secondaryButtons.length !== 2) {
538
+ return new Error(`${propName} needs to be an array of two button config objects`);
539
+ }
540
+ const shape = {
541
+ buttonText: PropTypes.node,
542
+ onClick: PropTypes.func
543
+ };
544
+ props[propName].forEach(secondaryButton => {
545
+ PropTypes.checkPropTypes(shape, secondaryButton, propName, componentName);
546
+ });
547
+ }
548
+ return null;
549
+ },
550
+ /**
551
+ * Specify whether the Dialog is for dangerous actions
552
+ */
553
+ danger: PropTypes.bool,
554
+ /**
555
+ * Specify loading status
556
+ */
557
+ loadingStatus: PropTypes.oneOf(['inactive', 'active', 'finished', 'error']),
558
+ /**
559
+ * Specify the description for the loading text
560
+ */
561
+ loadingDescription: PropTypes.string,
562
+ /**
563
+ * Specify the description for the loading icon
564
+ */
565
+ loadingIconDescription: PropTypes.string,
566
+ /**
567
+ * Provide an optional handler to be invoked when loading is
568
+ * successful
569
+ */
570
+ onLoadingSuccess: PropTypes.func
571
+ };
572
+ /**
573
+ * -------
574
+ * Exports
575
+ * -------
576
+ */
577
+
578
+ const Dialog = unstable__Dialog;
579
+ Dialog.Root = unstable__Dialog;
580
+ Dialog.Root.displayName = 'Dialog.Root';
581
+ Dialog.Header = DialogHeader;
582
+ Dialog.Header.displayName = 'Dialog.Header';
583
+ Dialog.Controls = DialogControls;
584
+ Dialog.Controls.displayName = 'Dialog.Controls';
585
+ Dialog.CloseButton = DialogCloseButton;
586
+ Dialog.CloseButton.displayName = 'Dialog.CloseButton';
587
+ Dialog.Title = DialogTitle;
588
+ Dialog.Title.displayName = 'Dialog.Title';
589
+ Dialog.Subtitle = DialogSubtitle;
590
+ Dialog.Subtitle.displayName = 'Dialog.Subtitle';
591
+ Dialog.Body = DialogBody;
592
+ Dialog.Body.displayName = 'Dialog.Body';
593
+ Dialog.Footer = DialogFooter;
594
+ Dialog.Footer.displayName = 'Dialog.Footer';
595
+
596
+ export { Dialog, DialogBody, DialogCloseButton, DialogControls, DialogFooter, DialogHeader, DialogSubtitle, DialogTitle, unstable__Dialog };
@@ -13,13 +13,12 @@ import '../ListBox/index.js';
13
13
  import { usePrefix } from '../../internal/usePrefix.js';
14
14
  import { ListBoxSizePropType } from '../ListBox/ListBoxPropTypes.js';
15
15
 
16
- const DropdownSkeleton = _ref => {
17
- let {
18
- className,
19
- size,
20
- hideLabel,
21
- ...rest
22
- } = _ref;
16
+ const DropdownSkeleton = ({
17
+ className,
18
+ size,
19
+ hideLabel,
20
+ ...rest
21
+ }) => {
23
22
  const prefix = usePrefix();
24
23
  const wrapperClasses = cx(className, `${prefix}--skeleton`, `${prefix}--form-item`, {
25
24
  [`${prefix}--list-box--${size}`]: size
@@ -74,40 +74,39 @@ function stateReducer(state, actionAndChanges) {
74
74
  return changes;
75
75
  }
76
76
  }
77
- const Dropdown = /*#__PURE__*/React.forwardRef((_ref, ref) => {
78
- let {
79
- autoAlign = false,
80
- className: containerClassName,
81
- decorator,
82
- disabled = false,
83
- direction = 'bottom',
84
- items: itemsProp,
85
- label,
86
- ['aria-label']: ariaLabel,
87
- ariaLabel: deprecatedAriaLabel,
88
- itemToString = defaultItemToString,
89
- itemToElement = null,
90
- renderSelectedItem,
91
- type = 'default',
92
- size: size$1,
93
- onChange,
94
- id,
95
- titleText = '',
96
- hideLabel,
97
- helperText = '',
98
- translateWithId,
99
- light,
100
- invalid,
101
- invalidText,
102
- warn,
103
- warnText,
104
- initialSelectedItem,
105
- selectedItem: controlledSelectedItem,
106
- downshiftProps,
107
- readOnly,
108
- slug,
109
- ...other
110
- } = _ref;
77
+ const Dropdown = /*#__PURE__*/React.forwardRef(({
78
+ autoAlign = false,
79
+ className: containerClassName,
80
+ decorator,
81
+ disabled = false,
82
+ direction = 'bottom',
83
+ items: itemsProp,
84
+ label,
85
+ ['aria-label']: ariaLabel,
86
+ ariaLabel: deprecatedAriaLabel,
87
+ itemToString = defaultItemToString,
88
+ itemToElement = null,
89
+ renderSelectedItem,
90
+ type = 'default',
91
+ size: size$1,
92
+ onChange,
93
+ id,
94
+ titleText = '',
95
+ hideLabel,
96
+ helperText = '',
97
+ translateWithId,
98
+ light,
99
+ invalid,
100
+ invalidText,
101
+ warn,
102
+ warnText,
103
+ initialSelectedItem,
104
+ selectedItem: controlledSelectedItem,
105
+ downshiftProps,
106
+ readOnly,
107
+ slug,
108
+ ...other
109
+ }, ref) => {
111
110
  const enableFloatingStyles = useFeatureFlag('enable-v12-dynamic-floating-styles');
112
111
  const {
113
112
  refs,
@@ -122,11 +121,10 @@ const Dropdown = /*#__PURE__*/React.forwardRef((_ref, ref) => {
122
121
  strategy: 'fixed',
123
122
  // Middleware order matters, arrow should be last
124
123
  middleware: [size({
125
- apply(_ref2) {
126
- let {
127
- rects,
128
- elements
129
- } = _ref2;
124
+ apply({
125
+ rects,
126
+ elements
127
+ }) {
130
128
  Object.assign(elements.floating.style, {
131
129
  width: `${rects.reference.width}px`
132
130
  });
@@ -154,10 +152,9 @@ const Dropdown = /*#__PURE__*/React.forwardRef((_ref, ref) => {
154
152
  const {
155
153
  isFluid
156
154
  } = useContext(FormContext);
157
- const onSelectedItemChange = useCallback(_ref3 => {
158
- let {
159
- selectedItem
160
- } = _ref3;
155
+ const onSelectedItemChange = useCallback(({
156
+ selectedItem
157
+ }) => {
161
158
  if (onChange) {
162
159
  onChange({
163
160
  selectedItem: selectedItem ?? null
@@ -29,8 +29,8 @@ import { ErrorBoundaryContext } from './ErrorBoundaryContext.js';
29
29
  */
30
30
 
31
31
  class ErrorBoundary extends React.Component {
32
- constructor() {
33
- super(...arguments);
32
+ constructor(...args) {
33
+ super(...args);
34
34
  _defineProperty(this, "context", void 0);
35
35
  _defineProperty(this, "state", {
36
36
  hasError: false