@carbon/react 1.83.0-rc.0 → 1.84.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (635) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +895 -790
  2. package/README.md +1 -1
  3. package/es/components/AILabel/index.js +37 -40
  4. package/es/components/AISkeleton/AISkeletonIcon.js +6 -7
  5. package/es/components/AISkeleton/AISkeletonPlaceholder.js +6 -7
  6. package/es/components/AISkeleton/AISkeletonText.js +6 -7
  7. package/es/components/Accordion/Accordion.Skeleton.js +24 -25
  8. package/es/components/Accordion/Accordion.js +13 -14
  9. package/es/components/Accordion/AccordionItem.js +22 -23
  10. package/es/components/Accordion/AccordionProvider.js +6 -7
  11. package/es/components/AspectRatio/AspectRatio.js +9 -10
  12. package/es/components/BadgeIndicator/index.js +7 -8
  13. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +9 -10
  14. package/es/components/Breadcrumb/Breadcrumb.js +3 -3
  15. package/es/components/Breadcrumb/BreadcrumbItem.js +9 -9
  16. package/es/components/Button/Button.Skeleton.js +10 -11
  17. package/es/components/Button/Button.js +5 -5
  18. package/es/components/Button/ButtonBase.js +27 -28
  19. package/es/components/ButtonSet/ButtonSet.js +2 -2
  20. package/es/components/ChatButton/ChatButton.Skeleton.js +7 -8
  21. package/es/components/ChatButton/ChatButton.js +13 -14
  22. package/es/components/Checkbox/Checkbox.Skeleton.js +8 -9
  23. package/es/components/Checkbox/Checkbox.js +33 -34
  24. package/es/components/CheckboxGroup/CheckboxGroup.js +28 -29
  25. package/es/components/ClassPrefix/index.js +6 -7
  26. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +12 -13
  27. package/es/components/CodeSnippet/CodeSnippet.js +41 -42
  28. package/es/components/ComboBox/ComboBox.js +42 -48
  29. package/es/components/ComboBox/tools/filter.js +9 -12
  30. package/es/components/ComboButton/index.js +22 -24
  31. package/es/components/ComposedModal/ComposedModal.js +49 -52
  32. package/es/components/ComposedModal/ModalFooter.js +42 -47
  33. package/es/components/ComposedModal/ModalHeader.js +21 -22
  34. package/es/components/ContainedList/ContainedList.js +17 -18
  35. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +16 -17
  36. package/es/components/ContentSwitcher/ContentSwitcher.d.ts +17 -29
  37. package/es/components/ContentSwitcher/ContentSwitcher.js +100 -126
  38. package/es/components/ContentSwitcher/index.d.ts +3 -4
  39. package/es/components/ContextMenu/useContextMenu.js +1 -2
  40. package/es/components/Copy/Copy.js +13 -14
  41. package/es/components/CopyButton/CopyButton.js +14 -15
  42. package/es/components/DangerButton/DangerButton.js +2 -2
  43. package/es/components/DataTable/DataTable.d.ts +81 -283
  44. package/es/components/DataTable/DataTable.js +124 -172
  45. package/es/components/DataTable/Table.d.ts +2 -2
  46. package/es/components/DataTable/Table.js +19 -22
  47. package/es/components/DataTable/TableActionList.d.ts +1 -1
  48. package/es/components/DataTable/TableBatchAction.js +9 -12
  49. package/es/components/DataTable/TableBatchActions.js +27 -29
  50. package/es/components/DataTable/TableBody.d.ts +3 -3
  51. package/es/components/DataTable/TableBody.js +9 -12
  52. package/es/components/DataTable/TableCell.d.ts +3 -4
  53. package/es/components/DataTable/TableCell.js +2 -2
  54. package/es/components/DataTable/TableContainer.d.ts +2 -3
  55. package/es/components/DataTable/TableContainer.js +15 -16
  56. package/es/components/DataTable/TableDecoratorRow.js +8 -9
  57. package/es/components/DataTable/TableExpandHeader.d.ts +2 -3
  58. package/es/components/DataTable/TableExpandHeader.js +18 -19
  59. package/es/components/DataTable/TableExpandRow.js +20 -21
  60. package/es/components/DataTable/TableExpandedRow.d.ts +3 -3
  61. package/es/components/DataTable/TableExpandedRow.js +10 -11
  62. package/es/components/DataTable/TableHead.d.ts +1 -1
  63. package/es/components/DataTable/TableHeader.d.ts +4 -4
  64. package/es/components/DataTable/TableHeader.js +29 -30
  65. package/es/components/DataTable/TableRow.d.ts +3 -4
  66. package/es/components/DataTable/TableRow.js +4 -4
  67. package/es/components/DataTable/TableSelectAll.js +14 -15
  68. package/es/components/DataTable/TableSelectRow.js +16 -17
  69. package/es/components/DataTable/TableSlugRow.js +7 -8
  70. package/es/components/DataTable/TableToolbar.js +9 -10
  71. package/es/components/DataTable/TableToolbarAction.js +2 -2
  72. package/es/components/DataTable/TableToolbarContent.d.ts +1 -1
  73. package/es/components/DataTable/TableToolbarMenu.js +10 -11
  74. package/es/components/DataTable/TableToolbarSearch.js +24 -26
  75. package/es/components/DataTable/index.d.ts +1 -1
  76. package/es/components/DataTable/state/sorting.js +3 -4
  77. package/es/components/DataTable/tools/filter.js +10 -12
  78. package/es/components/DataTable/tools/normalize.js +6 -8
  79. package/es/components/DataTable/tools/sorting.js +24 -30
  80. package/es/components/DataTableSkeleton/DataTableSkeleton.js +26 -27
  81. package/es/components/DatePicker/DatePicker.Skeleton.js +15 -16
  82. package/es/components/DatePicker/DatePicker.js +104 -81
  83. package/es/components/DatePickerInput/DatePickerInput.d.ts +3 -4
  84. package/es/components/DatePickerInput/DatePickerInput.js +24 -25
  85. package/es/components/Dialog/index.d.ts +194 -10
  86. package/es/components/Dialog/index.js +458 -39
  87. package/es/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
  88. package/es/components/Dropdown/Dropdown.Skeleton.js +10 -11
  89. package/es/components/Dropdown/Dropdown.d.ts +3 -3
  90. package/es/components/Dropdown/Dropdown.js +57 -60
  91. package/es/components/ErrorBoundary/ErrorBoundary.js +4 -4
  92. package/es/components/ExpandableSearch/ExpandableSearch.js +11 -12
  93. package/es/components/FeatureFlags/index.js +13 -14
  94. package/es/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
  95. package/es/components/FileUploader/FileUploader.Skeleton.js +9 -10
  96. package/es/components/FileUploader/FileUploader.d.ts +2 -3
  97. package/es/components/FileUploader/FileUploader.js +33 -35
  98. package/es/components/FileUploader/FileUploaderButton.d.ts +2 -3
  99. package/es/components/FileUploader/FileUploaderButton.js +20 -21
  100. package/es/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
  101. package/es/components/FileUploader/FileUploaderDropContainer.js +20 -21
  102. package/es/components/FileUploader/FileUploaderItem.d.ts +2 -3
  103. package/es/components/FileUploader/FileUploaderItem.js +26 -27
  104. package/es/components/FileUploader/Filename.d.ts +3 -4
  105. package/es/components/FileUploader/Filename.js +16 -17
  106. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +9 -10
  107. package/es/components/FluidComboBox/FluidComboBox.js +8 -9
  108. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +16 -17
  109. package/es/components/FluidDatePicker/FluidDatePicker.js +13 -14
  110. package/es/components/FluidDatePickerInput/FluidDatePickerInput.js +3 -3
  111. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +9 -10
  112. package/es/components/FluidDropdown/FluidDropdown.js +8 -9
  113. package/es/components/FluidForm/FluidForm.d.ts +3 -4
  114. package/es/components/FluidForm/FluidForm.js +8 -9
  115. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +9 -10
  116. package/es/components/FluidMultiSelect/FluidMultiSelect.js +10 -11
  117. package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +9 -10
  118. package/es/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  119. package/es/components/FluidNumberInput/FluidNumberInput.js +41 -8
  120. package/es/components/FluidSearch/FluidSearch.Skeleton.js +9 -10
  121. package/es/components/FluidSearch/FluidSearch.js +7 -8
  122. package/es/components/FluidSelect/FluidSelect.Skeleton.js +9 -10
  123. package/es/components/FluidSelect/FluidSelect.js +8 -9
  124. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +9 -10
  125. package/es/components/FluidTextArea/FluidTextArea.js +7 -8
  126. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +9 -10
  127. package/es/components/FluidTextInput/FluidTextInput.js +9 -10
  128. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +8 -9
  129. package/es/components/FluidTimePicker/FluidTimePicker.js +23 -24
  130. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +7 -8
  131. package/es/components/Form/Form.js +7 -8
  132. package/es/components/FormGroup/FormGroup.d.ts +3 -4
  133. package/es/components/FormGroup/FormGroup.js +15 -16
  134. package/es/components/FormItem/FormItem.js +7 -8
  135. package/es/components/FormLabel/FormLabel.js +8 -9
  136. package/es/components/Grid/CSSGrid.js +23 -25
  137. package/es/components/Grid/Column.js +32 -31
  138. package/es/components/Grid/ColumnHang.js +8 -9
  139. package/es/components/Grid/FlexGrid.js +12 -13
  140. package/es/components/Grid/Grid.js +3 -3
  141. package/es/components/Grid/GridContext.d.ts +2 -2
  142. package/es/components/Grid/GridContext.js +6 -7
  143. package/es/components/Grid/Row.js +10 -11
  144. package/es/components/Heading/index.js +13 -14
  145. package/es/components/Icon/Icon.Skeleton.js +6 -7
  146. package/es/components/IconButton/index.js +30 -26
  147. package/es/components/IconIndicator/index.js +10 -11
  148. package/es/components/IdPrefix/index.js +6 -7
  149. package/es/components/InlineCheckbox/InlineCheckbox.js +6 -6
  150. package/es/components/InlineLoading/InlineLoading.js +19 -20
  151. package/es/components/Layer/LayerContext.js +2 -2
  152. package/es/components/Layer/index.d.ts +4 -0
  153. package/es/components/Layer/index.js +21 -15
  154. package/es/components/Layout/index.js +24 -29
  155. package/es/components/LayoutDirection/LayoutDirection.js +10 -11
  156. package/es/components/LayoutDirection/LayoutDirectionContext.js +2 -2
  157. package/es/components/Link/Link.d.ts +1 -1
  158. package/es/components/Link/Link.js +19 -20
  159. package/es/components/ListBox/ListBox.d.ts +2 -3
  160. package/es/components/ListBox/ListBox.js +5 -5
  161. package/es/components/ListBox/ListBoxField.d.ts +3 -4
  162. package/es/components/ListBox/ListBoxField.js +8 -9
  163. package/es/components/ListBox/ListBoxMenu.d.ts +2 -3
  164. package/es/components/ListBox/ListBoxMenu.js +7 -8
  165. package/es/components/ListBox/ListBoxMenuIcon.js +8 -9
  166. package/es/components/ListBox/ListBoxMenuItem.d.ts +2 -3
  167. package/es/components/ListBox/ListBoxMenuItem.js +11 -13
  168. package/es/components/ListBox/ListBoxSelection.js +14 -15
  169. package/es/components/ListBox/next/ListBoxSelection.js +16 -17
  170. package/es/components/ListBox/next/ListBoxTrigger.js +8 -9
  171. package/es/components/ListItem/ListItem.js +7 -8
  172. package/es/components/Loading/Loading.d.ts +3 -3
  173. package/es/components/Loading/Loading.js +14 -15
  174. package/es/components/Menu/Menu.js +26 -27
  175. package/es/components/Menu/MenuItem.js +55 -60
  176. package/es/components/MenuButton/index.js +20 -22
  177. package/es/components/Modal/Modal.d.ts +2 -3
  178. package/es/components/Modal/Modal.js +85 -93
  179. package/es/components/ModalWrapper/ModalWrapper.js +9 -9
  180. package/es/components/MultiSelect/FilterableMultiSelect.js +68 -74
  181. package/es/components/MultiSelect/MultiSelect.js +65 -67
  182. package/es/components/MultiSelect/tools/sorting.js +11 -15
  183. package/es/components/Notification/Notification.js +137 -146
  184. package/es/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  185. package/es/components/NumberInput/NumberFormatPropTypes.js +40 -0
  186. package/es/components/NumberInput/NumberInput.Skeleton.js +10 -11
  187. package/es/components/NumberInput/NumberInput.d.ts +39 -3
  188. package/es/components/NumberInput/NumberInput.js +195 -65
  189. package/es/components/OrderedList/OrderedList.js +9 -10
  190. package/es/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  191. package/es/components/OverflowMenu/OverflowMenu.js +42 -48
  192. package/es/components/OverflowMenu/index.js +3 -3
  193. package/es/components/OverflowMenu/next/index.js +17 -18
  194. package/es/components/OverflowMenuItem/OverflowMenuItem.js +4 -4
  195. package/es/components/OverflowMenuV2/index.js +3 -3
  196. package/es/components/PageHeader/PageHeader.d.ts +29 -5
  197. package/es/components/PageHeader/PageHeader.js +136 -90
  198. package/es/components/Pagination/Pagination.Skeleton.js +12 -13
  199. package/es/components/Pagination/Pagination.js +40 -41
  200. package/es/components/Pagination/experimental/PageSelector.js +11 -12
  201. package/es/components/Pagination/experimental/Pagination.js +34 -35
  202. package/es/components/PaginationNav/PaginationNav.js +63 -68
  203. package/es/components/Popover/index.js +40 -42
  204. package/es/components/PrimaryButton/PrimaryButton.js +2 -2
  205. package/es/components/ProgressBar/ProgressBar.js +24 -25
  206. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +12 -13
  207. package/es/components/ProgressIndicator/ProgressIndicator.js +49 -52
  208. package/es/components/RadioButton/RadioButton.Skeleton.js +4 -4
  209. package/es/components/RadioButton/RadioButton.js +10 -10
  210. package/es/components/RadioButtonGroup/RadioButtonGroup.js +16 -16
  211. package/es/components/RadioTile/RadioTile.js +28 -29
  212. package/es/components/Search/Search.Skeleton.js +9 -10
  213. package/es/components/Search/Search.js +36 -38
  214. package/es/components/SecondaryButton/SecondaryButton.js +2 -2
  215. package/es/components/Select/Select.Skeleton.js +10 -11
  216. package/es/components/Select/Select.js +42 -43
  217. package/es/components/SelectItem/SelectItem.js +10 -11
  218. package/es/components/SelectItemGroup/SelectItemGroup.js +9 -10
  219. package/es/components/ShapeIndicator/index.js +13 -14
  220. package/es/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
  221. package/es/components/SkeletonIcon/SkeletonIcon.js +7 -12
  222. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +6 -7
  223. package/es/components/SkeletonText/SkeletonText.js +12 -13
  224. package/es/components/Slider/Slider.Skeleton.js +25 -26
  225. package/es/components/Slider/Slider.js +99 -113
  226. package/es/components/Slider/SliderHandles.js +20 -20
  227. package/es/components/Stack/HStack.js +2 -2
  228. package/es/components/Stack/Stack.js +2 -2
  229. package/es/components/Stack/VStack.js +2 -2
  230. package/es/components/StructuredList/StructuredList.Skeleton.js +17 -18
  231. package/es/components/StructuredList/StructuredList.js +24 -24
  232. package/es/components/Switch/IconSwitch.js +3 -3
  233. package/es/components/Switch/Switch.js +4 -4
  234. package/es/components/TabContent/TabContent.js +2 -2
  235. package/es/components/Tabs/Tabs.Skeleton.js +12 -13
  236. package/es/components/Tabs/Tabs.js +141 -156
  237. package/es/components/Tabs/usePressable.js +7 -8
  238. package/es/components/Tag/DismissibleTag.js +26 -27
  239. package/es/components/Tag/OperationalTag.js +16 -17
  240. package/es/components/Tag/SelectableTag.js +19 -20
  241. package/es/components/Tag/Tag.Skeleton.js +7 -8
  242. package/es/components/Tag/Tag.js +33 -34
  243. package/es/components/Text/Text.js +9 -10
  244. package/es/components/Text/TextDirection.js +7 -8
  245. package/es/components/Text/createTextComponent.js +2 -2
  246. package/es/components/TextArea/TextArea.Skeleton.js +4 -4
  247. package/es/components/TextArea/TextArea.js +22 -22
  248. package/es/components/TextInput/ControlledPasswordInput.d.ts +2 -3
  249. package/es/components/TextInput/ControlledPasswordInput.js +36 -37
  250. package/es/components/TextInput/PasswordInput.js +40 -41
  251. package/es/components/TextInput/TextInput.Skeleton.js +9 -10
  252. package/es/components/TextInput/TextInput.js +43 -44
  253. package/es/components/TextInput/util.js +14 -17
  254. package/es/components/Theme/index.js +19 -21
  255. package/es/components/Tile/Tile.js +98 -104
  256. package/es/components/TileGroup/TileGroup.d.ts +3 -4
  257. package/es/components/TileGroup/TileGroup.js +8 -8
  258. package/es/components/TimePicker/TimePicker.d.ts +2 -3
  259. package/es/components/TimePicker/TimePicker.js +14 -14
  260. package/es/components/TimePickerSelect/TimePickerSelect.js +4 -4
  261. package/es/components/Toggle/Toggle.Skeleton.js +8 -9
  262. package/es/components/Toggle/Toggle.js +27 -28
  263. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +14 -15
  264. package/es/components/Toggletip/index.js +43 -49
  265. package/es/components/Tooltip/DefinitionTooltip.js +17 -18
  266. package/es/components/Tooltip/Tooltip.d.ts +3 -0
  267. package/es/components/Tooltip/Tooltip.js +39 -28
  268. package/es/components/TreeView/TreeNode.js +64 -56
  269. package/es/components/TreeView/TreeView.js +44 -37
  270. package/es/components/UIShell/Content.js +8 -9
  271. package/es/components/UIShell/Header.js +7 -8
  272. package/es/components/UIShell/HeaderContainer.js +7 -8
  273. package/es/components/UIShell/HeaderGlobalAction.js +14 -15
  274. package/es/components/UIShell/HeaderGlobalBar.d.ts +1 -1
  275. package/es/components/UIShell/HeaderMenu.d.ts +10 -112
  276. package/es/components/UIShell/HeaderMenu.js +154 -201
  277. package/es/components/UIShell/HeaderMenuButton.js +14 -15
  278. package/es/components/UIShell/HeaderMenuItem.js +21 -20
  279. package/es/components/UIShell/HeaderName.js +9 -10
  280. package/es/components/UIShell/HeaderNavigation.js +10 -11
  281. package/es/components/UIShell/HeaderPanel.js +11 -12
  282. package/es/components/UIShell/HeaderSideNavItems.js +7 -8
  283. package/es/components/UIShell/Link.js +11 -12
  284. package/es/components/UIShell/SideNav.js +30 -32
  285. package/es/components/UIShell/SideNavDetails.js +9 -10
  286. package/es/components/UIShell/SideNavDivider.js +6 -7
  287. package/es/components/UIShell/SideNavFooter.js +13 -14
  288. package/es/components/UIShell/SideNavHeader.js +8 -9
  289. package/es/components/UIShell/SideNavIcon.js +7 -8
  290. package/es/components/UIShell/SideNavItem.js +7 -8
  291. package/es/components/UIShell/SideNavItems.js +10 -11
  292. package/es/components/UIShell/SideNavLink.js +15 -16
  293. package/es/components/UIShell/SideNavLinkText.js +7 -8
  294. package/es/components/UIShell/SideNavMenu.js +20 -21
  295. package/es/components/UIShell/SideNavMenuItem.js +5 -5
  296. package/es/components/UIShell/SideNavSwitcher.js +8 -8
  297. package/es/components/UIShell/SkipToContent.js +9 -10
  298. package/es/components/UIShell/Switcher.js +12 -13
  299. package/es/components/UIShell/SwitcherDivider.js +6 -7
  300. package/es/components/UIShell/SwitcherItem.js +3 -3
  301. package/es/components/UnorderedList/UnorderedList.js +8 -9
  302. package/es/index.js +25 -26
  303. package/es/internal/FloatingMenu.js +30 -32
  304. package/es/internal/Selection.js +15 -17
  305. package/{lib/feature-flags.d.ts → es/internal/__mocks__/mockHTMLElement.d.ts} +4 -2
  306. package/es/internal/createClassWrapper.js +2 -2
  307. package/es/internal/getAnnouncement.d.ts +8 -0
  308. package/es/internal/getAnnouncement.js +22 -0
  309. package/es/internal/keyboard/match.js +6 -7
  310. package/es/internal/useControllableState.d.ts +1 -1
  311. package/es/internal/useControllableState.js +8 -9
  312. package/es/internal/useDelayedState.js +1 -2
  313. package/es/internal/useDocumentLang.d.ts +12 -0
  314. package/es/internal/useId.js +4 -6
  315. package/es/internal/useIdPrefix.js +3 -3
  316. package/es/internal/useMatchMedia.js +1 -2
  317. package/es/internal/useMergedRefs.d.ts +1 -1
  318. package/es/internal/useNoInteractiveChildren.js +2 -4
  319. package/es/internal/useNormalizedInputProps.js +12 -13
  320. package/es/internal/usePrefix.js +3 -3
  321. package/es/internal/useResizeObserver.d.ts +14 -0
  322. package/es/internal/useResizeObserver.js +73 -0
  323. package/es/internal/useSavedCallback.js +1 -3
  324. package/es/internal/wrapFocus.js +23 -35
  325. package/es/prop-types/deprecate.js +1 -4
  326. package/es/prop-types/deprecateValuesWithin.js +1 -4
  327. package/es/prop-types/isRequiredOneOf.js +1 -4
  328. package/es/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  329. package/es/tools/events.js +1 -4
  330. package/es/tools/mergeRefs.js +9 -14
  331. package/es/tools/uniqueId.js +1 -2
  332. package/es/tools/wrapComponent.d.ts +3 -4
  333. package/es/tools/wrapComponent.js +11 -13
  334. package/es/types/common.d.ts +0 -2
  335. package/lib/components/AILabel/index.js +27 -30
  336. package/lib/components/AISkeleton/AISkeletonIcon.js +4 -5
  337. package/lib/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  338. package/lib/components/AISkeleton/AISkeletonText.js +4 -5
  339. package/lib/components/Accordion/Accordion.Skeleton.js +9 -10
  340. package/lib/components/Accordion/Accordion.js +10 -11
  341. package/lib/components/Accordion/AccordionItem.js +13 -14
  342. package/lib/components/Accordion/AccordionProvider.js +4 -5
  343. package/lib/components/AspectRatio/AspectRatio.js +7 -8
  344. package/lib/components/BadgeIndicator/index.js +5 -6
  345. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  346. package/lib/components/Button/Button.Skeleton.js +7 -8
  347. package/lib/components/Button/ButtonBase.js +23 -24
  348. package/lib/components/ChatButton/ChatButton.Skeleton.js +5 -6
  349. package/lib/components/ChatButton/ChatButton.js +11 -12
  350. package/lib/components/Checkbox/Checkbox.Skeleton.js +4 -5
  351. package/lib/components/Checkbox/Checkbox.js +19 -20
  352. package/lib/components/CheckboxGroup/CheckboxGroup.js +16 -17
  353. package/lib/components/ClassPrefix/index.js +4 -5
  354. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  355. package/lib/components/CodeSnippet/CodeSnippet.js +27 -29
  356. package/lib/components/ComboBox/ComboBox.js +24 -30
  357. package/lib/components/ComboBox/tools/filter.js +9 -12
  358. package/lib/components/ComboButton/index.js +16 -18
  359. package/lib/components/ComposedModal/ComposedModal.js +31 -34
  360. package/lib/components/ComposedModal/ModalFooter.js +37 -42
  361. package/lib/components/ComposedModal/ModalHeader.js +14 -15
  362. package/lib/components/ContainedList/ContainedList.js +10 -11
  363. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  364. package/lib/components/ContentSwitcher/ContentSwitcher.d.ts +17 -29
  365. package/lib/components/ContentSwitcher/ContentSwitcher.js +98 -124
  366. package/lib/components/ContentSwitcher/index.d.ts +3 -4
  367. package/lib/components/ContextMenu/useContextMenu.js +1 -2
  368. package/lib/components/Copy/Copy.js +11 -12
  369. package/lib/components/CopyButton/CopyButton.js +10 -11
  370. package/lib/components/DataTable/DataTable.d.ts +81 -283
  371. package/lib/components/DataTable/DataTable.js +123 -172
  372. package/lib/components/DataTable/Table.d.ts +2 -2
  373. package/lib/components/DataTable/Table.js +15 -18
  374. package/lib/components/DataTable/TableActionList.d.ts +1 -1
  375. package/lib/components/DataTable/TableBatchAction.js +8 -11
  376. package/lib/components/DataTable/TableBatchActions.js +18 -20
  377. package/lib/components/DataTable/TableBody.d.ts +3 -3
  378. package/lib/components/DataTable/TableBody.js +8 -11
  379. package/lib/components/DataTable/TableCell.d.ts +3 -4
  380. package/lib/components/DataTable/TableContainer.d.ts +2 -3
  381. package/lib/components/DataTable/TableContainer.js +9 -10
  382. package/lib/components/DataTable/TableDecoratorRow.js +4 -5
  383. package/lib/components/DataTable/TableExpandHeader.d.ts +2 -3
  384. package/lib/components/DataTable/TableExpandHeader.js +14 -15
  385. package/lib/components/DataTable/TableExpandRow.js +13 -14
  386. package/lib/components/DataTable/TableExpandedRow.d.ts +3 -3
  387. package/lib/components/DataTable/TableExpandedRow.js +6 -7
  388. package/lib/components/DataTable/TableHead.d.ts +1 -1
  389. package/lib/components/DataTable/TableHeader.d.ts +4 -4
  390. package/lib/components/DataTable/TableHeader.js +15 -16
  391. package/lib/components/DataTable/TableRow.d.ts +3 -4
  392. package/lib/components/DataTable/TableSelectAll.js +11 -12
  393. package/lib/components/DataTable/TableSelectRow.js +12 -13
  394. package/lib/components/DataTable/TableSlugRow.js +4 -5
  395. package/lib/components/DataTable/TableToolbar.js +7 -8
  396. package/lib/components/DataTable/TableToolbarContent.d.ts +1 -1
  397. package/lib/components/DataTable/TableToolbarMenu.js +8 -9
  398. package/lib/components/DataTable/TableToolbarSearch.js +22 -24
  399. package/lib/components/DataTable/index.d.ts +1 -1
  400. package/lib/components/DataTable/state/sorting.js +3 -4
  401. package/lib/components/DataTable/tools/filter.js +10 -12
  402. package/lib/components/DataTable/tools/normalize.js +6 -8
  403. package/lib/components/DataTable/tools/sorting.js +24 -30
  404. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  405. package/lib/components/DatePicker/DatePicker.Skeleton.js +7 -8
  406. package/lib/components/DatePicker/DatePicker.js +87 -64
  407. package/lib/components/DatePickerInput/DatePickerInput.d.ts +3 -4
  408. package/lib/components/DatePickerInput/DatePickerInput.js +5 -6
  409. package/lib/components/Dialog/index.d.ts +194 -10
  410. package/lib/components/Dialog/index.js +457 -33
  411. package/lib/components/Dropdown/Dropdown.Skeleton.d.ts +2 -3
  412. package/lib/components/Dropdown/Dropdown.Skeleton.js +6 -7
  413. package/lib/components/Dropdown/Dropdown.d.ts +3 -3
  414. package/lib/components/Dropdown/Dropdown.js +40 -43
  415. package/lib/components/ErrorBoundary/ErrorBoundary.js +2 -2
  416. package/lib/components/ExpandableSearch/ExpandableSearch.js +9 -10
  417. package/lib/components/FeatureFlags/index.js +11 -12
  418. package/lib/components/FileUploader/FileUploader.Skeleton.d.ts +3 -3
  419. package/lib/components/FileUploader/FileUploader.Skeleton.js +4 -5
  420. package/lib/components/FileUploader/FileUploader.d.ts +2 -3
  421. package/lib/components/FileUploader/FileUploader.js +22 -24
  422. package/lib/components/FileUploader/FileUploaderButton.d.ts +2 -3
  423. package/lib/components/FileUploader/FileUploaderButton.js +16 -17
  424. package/lib/components/FileUploader/FileUploaderDropContainer.d.ts +2 -3
  425. package/lib/components/FileUploader/FileUploaderDropContainer.js +15 -16
  426. package/lib/components/FileUploader/FileUploaderItem.d.ts +2 -3
  427. package/lib/components/FileUploader/FileUploaderItem.js +13 -14
  428. package/lib/components/FileUploader/Filename.d.ts +3 -4
  429. package/lib/components/FileUploader/Filename.js +9 -10
  430. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  431. package/lib/components/FluidComboBox/FluidComboBox.js +5 -6
  432. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  433. package/lib/components/FluidDatePicker/FluidDatePicker.js +10 -11
  434. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  435. package/lib/components/FluidDropdown/FluidDropdown.js +5 -6
  436. package/lib/components/FluidForm/FluidForm.d.ts +3 -4
  437. package/lib/components/FluidForm/FluidForm.js +5 -6
  438. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  439. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  440. package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  441. package/lib/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  442. package/lib/components/FluidNumberInput/FluidNumberInput.js +38 -5
  443. package/lib/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  444. package/lib/components/FluidSearch/FluidSearch.js +4 -5
  445. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  446. package/lib/components/FluidSelect/FluidSelect.js +5 -6
  447. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  448. package/lib/components/FluidTextArea/FluidTextArea.js +4 -5
  449. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  450. package/lib/components/FluidTextInput/FluidTextInput.js +5 -6
  451. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  452. package/lib/components/FluidTimePicker/FluidTimePicker.js +11 -12
  453. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  454. package/lib/components/Form/Form.js +5 -6
  455. package/lib/components/FormGroup/FormGroup.d.ts +3 -4
  456. package/lib/components/FormGroup/FormGroup.js +11 -12
  457. package/lib/components/FormItem/FormItem.js +5 -6
  458. package/lib/components/FormLabel/FormLabel.js +6 -7
  459. package/lib/components/Grid/CSSGrid.js +17 -19
  460. package/lib/components/Grid/Column.js +28 -27
  461. package/lib/components/Grid/ColumnHang.js +6 -7
  462. package/lib/components/Grid/FlexGrid.js +9 -10
  463. package/lib/components/Grid/GridContext.d.ts +2 -2
  464. package/lib/components/Grid/GridContext.js +10 -29
  465. package/lib/components/Grid/Row.js +8 -9
  466. package/lib/components/Heading/index.js +5 -6
  467. package/lib/components/Icon/Icon.Skeleton.js +4 -5
  468. package/lib/components/IconButton/index.js +26 -22
  469. package/lib/components/IconIndicator/index.js +7 -8
  470. package/lib/components/IdPrefix/index.js +4 -5
  471. package/lib/components/InlineLoading/InlineLoading.js +9 -10
  472. package/lib/components/Layer/index.d.ts +4 -0
  473. package/lib/components/Layer/index.js +16 -10
  474. package/lib/components/Layout/index.js +21 -26
  475. package/lib/components/LayoutDirection/LayoutDirection.js +6 -7
  476. package/lib/components/Link/Link.d.ts +1 -1
  477. package/lib/components/Link/Link.js +15 -16
  478. package/lib/components/ListBox/ListBox.d.ts +2 -3
  479. package/lib/components/ListBox/ListBoxField.d.ts +3 -4
  480. package/lib/components/ListBox/ListBoxField.js +6 -7
  481. package/lib/components/ListBox/ListBoxMenu.d.ts +2 -3
  482. package/lib/components/ListBox/ListBoxMenu.js +5 -6
  483. package/lib/components/ListBox/ListBoxMenuIcon.js +4 -5
  484. package/lib/components/ListBox/ListBoxMenuItem.d.ts +2 -3
  485. package/lib/components/ListBox/ListBoxMenuItem.js +8 -10
  486. package/lib/components/ListBox/ListBoxSelection.js +8 -9
  487. package/lib/components/ListBox/next/ListBoxSelection.js +9 -10
  488. package/lib/components/ListBox/next/ListBoxTrigger.js +5 -6
  489. package/lib/components/ListItem/ListItem.js +5 -6
  490. package/lib/components/Loading/Loading.d.ts +3 -3
  491. package/lib/components/Loading/Loading.js +8 -9
  492. package/lib/components/Menu/Menu.js +23 -24
  493. package/lib/components/Menu/MenuItem.js +39 -44
  494. package/lib/components/MenuButton/index.js +16 -18
  495. package/lib/components/Modal/Modal.d.ts +2 -3
  496. package/lib/components/Modal/Modal.js +55 -63
  497. package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
  498. package/lib/components/MultiSelect/FilterableMultiSelect.js +46 -52
  499. package/lib/components/MultiSelect/MultiSelect.js +43 -45
  500. package/lib/components/MultiSelect/tools/sorting.js +11 -15
  501. package/lib/components/Notification/Notification.js +96 -105
  502. package/lib/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  503. package/lib/components/NumberInput/NumberFormatPropTypes.js +48 -0
  504. package/lib/components/NumberInput/NumberInput.Skeleton.js +6 -7
  505. package/lib/components/NumberInput/NumberInput.d.ts +39 -3
  506. package/lib/components/NumberInput/NumberInput.js +173 -43
  507. package/lib/components/OrderedList/OrderedList.js +7 -8
  508. package/lib/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  509. package/lib/components/OverflowMenu/OverflowMenu.js +35 -41
  510. package/lib/components/OverflowMenu/next/index.js +12 -13
  511. package/lib/components/PageHeader/PageHeader.d.ts +29 -5
  512. package/lib/components/PageHeader/PageHeader.js +119 -73
  513. package/lib/components/Pagination/Pagination.Skeleton.js +4 -5
  514. package/lib/components/Pagination/Pagination.js +24 -25
  515. package/lib/components/Pagination/experimental/PageSelector.js +8 -9
  516. package/lib/components/Pagination/experimental/Pagination.js +20 -21
  517. package/lib/components/PaginationNav/PaginationNav.js +33 -38
  518. package/lib/components/Popover/index.js +26 -28
  519. package/lib/components/ProgressBar/ProgressBar.js +11 -12
  520. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  521. package/lib/components/ProgressIndicator/ProgressIndicator.js +29 -32
  522. package/lib/components/RadioTile/RadioTile.js +17 -18
  523. package/lib/components/Search/Search.Skeleton.js +5 -6
  524. package/lib/components/Search/Search.js +26 -28
  525. package/lib/components/Select/Select.Skeleton.js +5 -6
  526. package/lib/components/Select/Select.js +24 -25
  527. package/lib/components/SelectItem/SelectItem.js +8 -9
  528. package/lib/components/SelectItemGroup/SelectItemGroup.js +7 -8
  529. package/lib/components/ShapeIndicator/index.js +7 -8
  530. package/lib/components/SkeletonIcon/SkeletonIcon.d.ts +0 -4
  531. package/lib/components/SkeletonIcon/SkeletonIcon.js +5 -10
  532. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  533. package/lib/components/SkeletonText/SkeletonText.js +8 -9
  534. package/lib/components/Slider/Slider.Skeleton.js +8 -9
  535. package/lib/components/Slider/Slider.js +69 -83
  536. package/lib/components/Slider/SliderHandles.js +6 -6
  537. package/lib/components/StructuredList/StructuredList.Skeleton.js +5 -6
  538. package/lib/components/Tabs/Tabs.Skeleton.js +5 -6
  539. package/lib/components/Tabs/Tabs.js +83 -98
  540. package/lib/components/Tabs/usePressable.js +7 -8
  541. package/lib/components/Tag/DismissibleTag.js +16 -17
  542. package/lib/components/Tag/OperationalTag.js +10 -11
  543. package/lib/components/Tag/SelectableTag.js +13 -14
  544. package/lib/components/Tag/Tag.Skeleton.js +5 -6
  545. package/lib/components/Tag/Tag.js +19 -20
  546. package/lib/components/Text/Text.js +6 -7
  547. package/lib/components/Text/TextDirection.js +5 -6
  548. package/lib/components/TextArea/TextArea.js +3 -3
  549. package/lib/components/TextInput/ControlledPasswordInput.d.ts +2 -3
  550. package/lib/components/TextInput/ControlledPasswordInput.js +24 -25
  551. package/lib/components/TextInput/PasswordInput.js +26 -27
  552. package/lib/components/TextInput/TextInput.Skeleton.js +5 -6
  553. package/lib/components/TextInput/TextInput.js +27 -28
  554. package/lib/components/TextInput/util.js +14 -17
  555. package/lib/components/Theme/index.js +10 -12
  556. package/lib/components/Tile/Tile.js +68 -74
  557. package/lib/components/TileGroup/TileGroup.d.ts +3 -4
  558. package/lib/components/TimePicker/TimePicker.d.ts +2 -3
  559. package/lib/components/Toggle/Toggle.Skeleton.js +4 -5
  560. package/lib/components/Toggle/Toggle.js +17 -18
  561. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  562. package/lib/components/Toggletip/index.js +33 -39
  563. package/lib/components/Tooltip/DefinitionTooltip.js +13 -14
  564. package/lib/components/Tooltip/Tooltip.d.ts +3 -0
  565. package/lib/components/Tooltip/Tooltip.js +33 -22
  566. package/lib/components/TreeView/TreeNode.js +40 -32
  567. package/lib/components/TreeView/TreeView.js +41 -34
  568. package/lib/components/UIShell/Content.js +6 -7
  569. package/lib/components/UIShell/Header.js +5 -6
  570. package/lib/components/UIShell/HeaderContainer.js +5 -6
  571. package/lib/components/UIShell/HeaderGlobalAction.js +12 -13
  572. package/lib/components/UIShell/HeaderGlobalBar.d.ts +1 -1
  573. package/lib/components/UIShell/HeaderMenu.d.ts +10 -112
  574. package/lib/components/UIShell/HeaderMenu.js +152 -199
  575. package/lib/components/UIShell/HeaderMenuButton.js +10 -11
  576. package/lib/components/UIShell/HeaderMenuItem.js +17 -16
  577. package/lib/components/UIShell/HeaderName.js +6 -7
  578. package/lib/components/UIShell/HeaderNavigation.js +7 -8
  579. package/lib/components/UIShell/HeaderPanel.js +9 -10
  580. package/lib/components/UIShell/HeaderSideNavItems.js +5 -6
  581. package/lib/components/UIShell/Link.js +8 -9
  582. package/lib/components/UIShell/SideNav.js +23 -25
  583. package/lib/components/UIShell/SideNavDetails.js +6 -7
  584. package/lib/components/UIShell/SideNavDivider.js +3 -4
  585. package/lib/components/UIShell/SideNavFooter.js +6 -7
  586. package/lib/components/UIShell/SideNavHeader.js +5 -6
  587. package/lib/components/UIShell/SideNavIcon.js +5 -6
  588. package/lib/components/UIShell/SideNavItem.js +5 -6
  589. package/lib/components/UIShell/SideNavItems.js +5 -6
  590. package/lib/components/UIShell/SideNavLink.js +10 -11
  591. package/lib/components/UIShell/SideNavLinkText.js +5 -6
  592. package/lib/components/UIShell/SideNavMenu.js +11 -12
  593. package/lib/components/UIShell/SkipToContent.js +7 -8
  594. package/lib/components/UIShell/Switcher.js +4 -5
  595. package/lib/components/UIShell/SwitcherDivider.js +4 -5
  596. package/lib/components/UnorderedList/UnorderedList.js +6 -7
  597. package/lib/index.js +81 -82
  598. package/lib/internal/FloatingMenu.js +26 -28
  599. package/lib/internal/Selection.js +15 -17
  600. package/{es/feature-flags.d.ts → lib/internal/__mocks__/mockHTMLElement.d.ts} +4 -2
  601. package/lib/internal/getAnnouncement.d.ts +8 -0
  602. package/lib/internal/getAnnouncement.js +26 -0
  603. package/lib/internal/keyboard/match.js +6 -7
  604. package/lib/internal/useControllableState.d.ts +1 -1
  605. package/lib/internal/useControllableState.js +8 -9
  606. package/lib/internal/useDelayedState.js +1 -2
  607. package/lib/internal/useDocumentLang.d.ts +12 -0
  608. package/lib/internal/useId.js +2 -4
  609. package/lib/internal/useMatchMedia.js +1 -2
  610. package/lib/internal/useMergedRefs.d.ts +1 -1
  611. package/lib/internal/useNoInteractiveChildren.js +2 -4
  612. package/lib/internal/useNormalizedInputProps.js +9 -10
  613. package/lib/internal/useResizeObserver.d.ts +14 -0
  614. package/lib/internal/useResizeObserver.js +77 -0
  615. package/lib/internal/useSavedCallback.js +1 -3
  616. package/lib/internal/wrapFocus.js +23 -35
  617. package/lib/prop-types/deprecate.js +1 -4
  618. package/lib/prop-types/deprecateValuesWithin.js +1 -4
  619. package/lib/prop-types/isRequiredOneOf.js +1 -4
  620. package/lib/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  621. package/lib/tools/events.js +1 -4
  622. package/lib/tools/mergeRefs.js +9 -14
  623. package/lib/tools/uniqueId.js +1 -2
  624. package/lib/tools/wrapComponent.d.ts +3 -4
  625. package/lib/tools/wrapComponent.js +9 -11
  626. package/lib/types/common.d.ts +0 -2
  627. package/package.json +21 -20
  628. package/scss/components/content-switcher/_tokens.scss +9 -0
  629. package/telemetry.yml +27 -2
  630. package/es/components/ContentSwitcher/index.js +0 -13
  631. package/es/components/DataTable/index.js +0 -76
  632. package/es/internal/useAnnouncer.js +0 -21
  633. package/lib/components/ContentSwitcher/index.js +0 -18
  634. package/lib/components/DataTable/index.js +0 -82
  635. package/lib/internal/useAnnouncer.js +0 -25
@@ -12,11 +12,21 @@ Object.defineProperty(exports, '__esModule', { value: true });
12
12
  var _rollupPluginBabelHelpers = require('../../_virtual/_rollupPluginBabelHelpers.js');
13
13
  var PropTypes = require('prop-types');
14
14
  var React = require('react');
15
+ var useIsomorphicEffect = require('../../internal/useIsomorphicEffect.js');
15
16
  var usePrefix = require('../../internal/usePrefix.js');
16
17
  var cx = require('classnames');
17
18
  var iconsReact = require('@carbon/icons-react');
18
19
  var index = require('../IconButton/index.js');
19
20
  var noopFn = require('../../internal/noopFn.js');
21
+ require('../Text/index.js');
22
+ var index$1 = require('../Layer/index.js');
23
+ var ButtonSet = require('../ButtonSet/ButtonSet.js');
24
+ var Button = require('../Button/Button.js');
25
+ require('../Button/Button.Skeleton.js');
26
+ var useId = require('../../internal/useId.js');
27
+ var InlineLoading = require('../InlineLoading/InlineLoading.js');
28
+ var debounce = require('../../node_modules/es-toolkit/dist/compat/function/debounce.mjs.js');
29
+ var Text = require('../Text/Text.js');
20
30
 
21
31
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
22
32
 
@@ -24,19 +34,33 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
24
34
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
25
35
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
26
36
 
27
- const unstable__Dialog = /*#__PURE__*/React__default["default"].forwardRef((_ref, forwardRef) => {
28
- let {
29
- children,
30
- className,
31
- modal,
32
- onCancel = noopFn.noopFn,
33
- onClick = noopFn.noopFn,
34
- onClose = noopFn.noopFn,
35
- onRequestClose = noopFn.noopFn,
36
- open = false,
37
- ...rest
38
- } = _ref;
37
+ const DialogContext = /*#__PURE__*/React.createContext({});
38
+
39
+ /**
40
+ * ----------
41
+ * Dialog
42
+ * ----------
43
+ */
44
+
45
+ const unstable__Dialog = /*#__PURE__*/React__default["default"].forwardRef(({
46
+ children,
47
+ className,
48
+ modal,
49
+ onCancel = noopFn.noopFn,
50
+ onClick = noopFn.noopFn,
51
+ onClose = noopFn.noopFn,
52
+ onRequestClose = noopFn.noopFn,
53
+ open = false,
54
+ role,
55
+ ariaLabel,
56
+ ariaLabelledBy,
57
+ ariaDescribedBy,
58
+ ...rest
59
+ }, forwardRef) => {
39
60
  const prefix = usePrefix.usePrefix();
61
+ const dialogId = useId.useId();
62
+ const titleId = `${prefix}--dialog-header__heading--${dialogId}`;
63
+ const subtitleId = `${prefix}--dialog-header__label--${dialogId}`;
40
64
 
41
65
  // This component needs access to a ref, placed on the dialog, to call the
42
66
  // various imperative dialog functions (show(), close(), etc.).
@@ -79,15 +103,40 @@ const unstable__Dialog = /*#__PURE__*/React__default["default"].forwardRef((_ref
79
103
  }
80
104
  }
81
105
  }, [modal, open]);
82
- return /*#__PURE__*/React__default["default"].createElement("dialog", _rollupPluginBabelHelpers["extends"]({}, rest, {
106
+ const containerClasses = cx__default["default"](`${prefix}--dialog-container`);
107
+ const contextValue = {
108
+ dialogId,
109
+ titleId,
110
+ subtitleId,
111
+ isOpen: open
112
+ };
113
+ React.useEffect(() => {
114
+ if (ref.current && open && !ariaLabel && !ariaLabelledBy) {
115
+ const title = ref.current.querySelector(`.${prefix}--dialog-header__heading`);
116
+
117
+ // Set aria-labelledby to the title's ID if it exists
118
+ if (title && title.id) {
119
+ ref.current.setAttribute('aria-labelledby', title.id);
120
+ }
121
+ }
122
+ }, [open, ariaLabel, ariaLabelledBy, prefix]);
123
+ return /*#__PURE__*/React__default["default"].createElement(DialogContext.Provider, {
124
+ value: contextValue
125
+ }, /*#__PURE__*/React__default["default"].createElement("dialog", _rollupPluginBabelHelpers["extends"]({}, rest, {
83
126
  className: cx__default["default"](`${prefix}--dialog`, {
84
127
  [`${prefix}--dialog--modal`]: modal
85
128
  }, className),
86
129
  ref: ref,
87
130
  onCancel: onCancel,
88
131
  onClick: handleClick,
89
- onClose: onClose
90
- }), children);
132
+ onClose: onClose,
133
+ role: role,
134
+ "aria-label": ariaLabel,
135
+ "aria-labelledby": !ariaLabel ? ariaLabelledBy || titleId : undefined,
136
+ "aria-describedby": ariaDescribedBy
137
+ }), /*#__PURE__*/React__default["default"].createElement("div", {
138
+ className: containerClasses
139
+ }, children)));
91
140
  });
92
141
  unstable__Dialog.displayName = 'Dialog';
93
142
  unstable__Dialog.propTypes = {
@@ -112,30 +161,59 @@ unstable__Dialog.propTypes = {
112
161
  /**
113
162
  * open initial state
114
163
  */
115
- open: PropTypes__default["default"].bool
164
+ open: PropTypes__default["default"].bool,
165
+ /**
166
+ * Specify the role of the dialog for accessibility
167
+ */
168
+ role: PropTypes__default["default"].oneOf(['dialog', 'alertdialog']),
169
+ /**
170
+ * Specify a label for screen readers
171
+ */
172
+ 'aria-label': PropTypes__default["default"].string,
173
+ /**
174
+ * Specify the ID of an element that labels this dialog
175
+ */
176
+ 'aria-labelledby': PropTypes__default["default"].string,
177
+ /**
178
+ * Specify the ID of an element that describes this dialog
179
+ */
180
+ ariaDescribedBy: PropTypes__default["default"].string
116
181
  };
117
- const DialogHeader = /*#__PURE__*/React__default["default"].forwardRef((_ref2, ref) => {
118
- let {
119
- children,
120
- ...rest
121
- } = _ref2;
182
+
183
+ /**
184
+ * -------------
185
+ * DialogHeader
186
+ * -------------
187
+ */
188
+
189
+ const DialogHeader = /*#__PURE__*/React__default["default"].forwardRef(({
190
+ children,
191
+ ...rest
192
+ }, ref) => {
122
193
  const prefix = usePrefix.usePrefix();
123
194
  return /*#__PURE__*/React__default["default"].createElement("div", _rollupPluginBabelHelpers["extends"]({
124
195
  className: `${prefix}--dialog__header`,
125
196
  ref: ref
126
197
  }, rest), children);
127
198
  });
199
+ DialogHeader.displayName = 'DialogHeader';
128
200
  DialogHeader.propTypes = {
129
201
  /**
130
202
  * Provide the contents to be rendered inside of this component
131
203
  */
132
204
  children: PropTypes__default["default"].node
133
205
  };
134
- const DialogControls = /*#__PURE__*/React__default["default"].forwardRef((_ref3, ref) => {
135
- let {
136
- children,
137
- ...rest
138
- } = _ref3;
206
+
207
+ /**
208
+ * ---------------
209
+ * DialogControls
210
+ * ---------------
211
+ */
212
+
213
+ const DialogControls = /*#__PURE__*/React__default["default"].forwardRef(({
214
+ children,
215
+ ...rest
216
+ }, ref) => {
139
217
  const prefix = usePrefix.usePrefix();
140
218
  return (
141
219
  /*#__PURE__*/
@@ -146,17 +224,24 @@ const DialogControls = /*#__PURE__*/React__default["default"].forwardRef((_ref3,
146
224
  }, rest), children)
147
225
  );
148
226
  });
227
+ DialogControls.displayName = 'DialogControls';
149
228
  DialogControls.propTypes = {
150
229
  /**
151
230
  * Provide children to be rendered inside of this component
152
231
  */
153
232
  children: PropTypes__default["default"].node
154
233
  };
155
- const DialogCloseButton = /*#__PURE__*/React__default["default"].forwardRef((_ref4, ref) => {
156
- let {
157
- onClick,
158
- ...rest
159
- } = _ref4;
234
+
235
+ /**
236
+ * -------------------
237
+ * DialogCloseButton
238
+ * -------------------
239
+ */
240
+
241
+ const DialogCloseButton = /*#__PURE__*/React__default["default"].forwardRef(({
242
+ onClick,
243
+ ...rest
244
+ }, ref) => {
160
245
  const prefix = usePrefix.usePrefix();
161
246
  return (
162
247
  /*#__PURE__*/
@@ -168,15 +253,17 @@ const DialogCloseButton = /*#__PURE__*/React__default["default"].forwardRef((_re
168
253
  title: "Close",
169
254
  "aria-label": "Close",
170
255
  align: "left",
171
- onClick: onClick
256
+ onClick: onClick,
257
+ ref: ref
172
258
  }, rest), /*#__PURE__*/React__default["default"].createElement(iconsReact.Close, {
173
259
  size: 20,
174
260
  "aria-hidden": "true",
175
- tabIndex: "-1",
261
+ tabIndex: -1,
176
262
  className: `${prefix}--icon__close`
177
263
  }))
178
264
  );
179
265
  });
266
+ DialogCloseButton.displayName = 'DialogCloseButton';
180
267
  DialogCloseButton.propTypes = {
181
268
  /**
182
269
  * Specify a click handler applied to the IconButton
@@ -184,7 +271,344 @@ DialogCloseButton.propTypes = {
184
271
  onClick: PropTypes__default["default"].func
185
272
  };
186
273
 
274
+ /**
275
+ * ------------
276
+ * DialogTitle
277
+ * ------------
278
+ */
279
+
280
+ const DialogTitle = /*#__PURE__*/React__default["default"].forwardRef(({
281
+ children,
282
+ className,
283
+ id,
284
+ ...rest
285
+ }, ref) => {
286
+ const prefix = usePrefix.usePrefix();
287
+ const {
288
+ titleId
289
+ } = React.useContext(DialogContext);
290
+ const headingId = id || titleId;
291
+ return /*#__PURE__*/React__default["default"].createElement(Text.Text, _rollupPluginBabelHelpers["extends"]({
292
+ as: "h2",
293
+ id: headingId,
294
+ className: cx__default["default"](`${prefix}--dialog-header__heading`, className),
295
+ ref: ref
296
+ }, rest), children);
297
+ });
298
+ DialogTitle.displayName = 'DialogTitle';
299
+ DialogTitle.propTypes = {
300
+ /**
301
+ * Provide the contents to be rendered inside of this component
302
+ */
303
+ children: PropTypes__default["default"].node,
304
+ /**
305
+ * Specify an optional className to be applied to the title node
306
+ */
307
+ className: PropTypes__default["default"].string,
308
+ /**
309
+ * Specify an optional id for the title element
310
+ */
311
+ id: PropTypes__default["default"].string
312
+ };
313
+
314
+ /**
315
+ * ---------------
316
+ * DialogSubtitle
317
+ * ---------------
318
+ */
319
+
320
+ const DialogSubtitle = /*#__PURE__*/React__default["default"].forwardRef(({
321
+ children,
322
+ className,
323
+ id,
324
+ ...rest
325
+ }, ref) => {
326
+ const prefix = usePrefix.usePrefix();
327
+ const {
328
+ subtitleId
329
+ } = React.useContext(DialogContext);
330
+ const labelId = id || subtitleId;
331
+ return /*#__PURE__*/React__default["default"].createElement(Text.Text, _rollupPluginBabelHelpers["extends"]({
332
+ as: "h2",
333
+ id: labelId,
334
+ className: cx__default["default"](`${prefix}--dialog-header__label`, className),
335
+ ref: ref
336
+ }, rest), children);
337
+ });
338
+ DialogSubtitle.displayName = 'DialogSubtitle';
339
+ DialogSubtitle.propTypes = {
340
+ /**
341
+ * Provide the contents to be rendered inside of this component
342
+ */
343
+ children: PropTypes__default["default"].node,
344
+ /**
345
+ * Specify an optional className to be applied to the subtitle node
346
+ */
347
+ className: PropTypes__default["default"].string,
348
+ /**
349
+ * Specify an optional id for the subtitle element
350
+ */
351
+ id: PropTypes__default["default"].string
352
+ };
353
+
354
+ /**
355
+ * -----------
356
+ * DialogBody
357
+ * -----------
358
+ */
359
+
360
+ const DialogBody = /*#__PURE__*/React__default["default"].forwardRef(({
361
+ children,
362
+ className,
363
+ hasScrollingContent,
364
+ ...rest
365
+ }, ref) => {
366
+ const prefix = usePrefix.usePrefix();
367
+ const contentRef = React.useRef(null);
368
+ const [isScrollable, setIsScrollable] = React.useState(false);
369
+ const dialogId = useId.useId();
370
+ const dialogBodyId = `${prefix}--dialog-body--${dialogId}`;
371
+ useIsomorphicEffect["default"](() => {
372
+ if (contentRef.current) {
373
+ setIsScrollable(contentRef.current.scrollHeight > contentRef.current.clientHeight);
374
+ }
375
+ function handler() {
376
+ if (contentRef.current) {
377
+ setIsScrollable(contentRef.current.scrollHeight > contentRef.current.clientHeight);
378
+ }
379
+ }
380
+ const debouncedHandler = debounce.debounce(handler, 200);
381
+ window.addEventListener('resize', debouncedHandler);
382
+ return () => {
383
+ debouncedHandler.cancel();
384
+ window.removeEventListener('resize', debouncedHandler);
385
+ };
386
+ }, []);
387
+ const contentClasses = cx__default["default"](`${prefix}--dialog-content`, {
388
+ [`${prefix}--dialog-scroll-content`]: hasScrollingContent || isScrollable
389
+ }, className);
390
+ const hasScrollingContentProps = hasScrollingContent || isScrollable ? {
391
+ tabIndex: 0,
392
+ role: 'region'
393
+ } : {};
394
+ const combinedRef = el => {
395
+ if (typeof ref === 'function') {
396
+ ref(el);
397
+ } else if (ref) {
398
+ ref.current = el;
399
+ }
400
+ contentRef.current = el;
401
+ };
402
+ return /*#__PURE__*/React__default["default"].createElement(index$1.Layer, _rollupPluginBabelHelpers["extends"]({
403
+ ref: combinedRef,
404
+ id: dialogBodyId,
405
+ className: contentClasses
406
+ }, hasScrollingContentProps, rest), children);
407
+ });
408
+ DialogBody.displayName = 'DialogBody';
409
+ DialogBody.propTypes = {
410
+ /**
411
+ * Provide the contents to be rendered inside of this component
412
+ */
413
+ children: PropTypes__default["default"].node,
414
+ /**
415
+ * Specify an optional className to be applied to the body node
416
+ */
417
+ className: PropTypes__default["default"].string,
418
+ /**
419
+ * Specify whether the content has overflow that should be scrollable
420
+ */
421
+ hasScrollingContent: PropTypes__default["default"].bool
422
+ };
423
+
424
+ /**
425
+ * -------------
426
+ * DialogFooter
427
+ * -------------
428
+ */
429
+
430
+ const DialogFooter = /*#__PURE__*/React__default["default"].forwardRef(({
431
+ children,
432
+ className,
433
+ onRequestClose = noopFn.noopFn,
434
+ onSecondarySubmit,
435
+ onRequestSubmit = noopFn.noopFn,
436
+ primaryButtonText = 'Save',
437
+ primaryButtonDisabled = false,
438
+ secondaryButtonText = 'Cancel',
439
+ secondaryButtons,
440
+ loadingStatus = 'inactive',
441
+ loadingDescription,
442
+ loadingIconDescription,
443
+ onLoadingSuccess = noopFn.noopFn,
444
+ danger = false,
445
+ ...rest
446
+ }, ref) => {
447
+ const prefix = usePrefix.usePrefix();
448
+ const button = React.useRef(null);
449
+ const {
450
+ isOpen
451
+ } = React.useContext(DialogContext);
452
+ const [secondaryButtonRef, setSecondaryButtonRef] = React.useState(null);
453
+ React.useEffect(() => {
454
+ if (danger && secondaryButtonRef) {
455
+ const focusFrame = requestAnimationFrame(() => {
456
+ secondaryButtonRef.focus();
457
+ });
458
+ return () => cancelAnimationFrame(focusFrame);
459
+ }
460
+ }, [danger, secondaryButtonRef, isOpen]);
461
+ const classes = cx__default["default"](`${prefix}--dialog-footer`, className, {
462
+ [`${prefix}--dialog-footer--three-button`]: Array.isArray(secondaryButtons) && secondaryButtons.length === 2
463
+ });
464
+ const loadingActive = loadingStatus !== 'inactive';
465
+ const primaryButtonClass = cx__default["default"]({
466
+ [`${prefix}--btn--loading`]: loadingStatus !== 'inactive'
467
+ });
468
+ const onSecondaryButtonClick = onSecondarySubmit ? onSecondarySubmit : onRequestClose;
469
+ if (children) {
470
+ return /*#__PURE__*/React__default["default"].createElement(ButtonSet["default"], _rollupPluginBabelHelpers["extends"]({
471
+ className: classes,
472
+ ref: ref
473
+ }, rest), children);
474
+ }
475
+ return /*#__PURE__*/React__default["default"].createElement(ButtonSet["default"], _rollupPluginBabelHelpers["extends"]({
476
+ className: classes,
477
+ "aria-busy": loadingActive,
478
+ ref: ref
479
+ }, rest), Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map(({
480
+ buttonText,
481
+ onClick: onButtonClick
482
+ }, i) => /*#__PURE__*/React__default["default"].createElement(Button["default"], {
483
+ key: `${buttonText}-${i}`,
484
+ autoFocus: danger,
485
+ kind: "secondary",
486
+ ref: i === 0 && danger ? setSecondaryButtonRef : undefined,
487
+ onClick: onButtonClick
488
+ }, buttonText)) : secondaryButtonText && /*#__PURE__*/React__default["default"].createElement(Button["default"], {
489
+ ref: danger ? setSecondaryButtonRef : undefined,
490
+ disabled: loadingActive,
491
+ kind: "secondary",
492
+ autoFocus: danger,
493
+ onClick: onSecondaryButtonClick
494
+ }, secondaryButtonText), /*#__PURE__*/React__default["default"].createElement(Button["default"], {
495
+ className: primaryButtonClass,
496
+ kind: danger ? 'danger' : 'primary',
497
+ disabled: loadingActive || primaryButtonDisabled,
498
+ onClick: onRequestSubmit,
499
+ ref: button
500
+ }, loadingStatus === 'inactive' ? primaryButtonText : /*#__PURE__*/React__default["default"].createElement(InlineLoading["default"], {
501
+ status: loadingStatus,
502
+ description: loadingDescription,
503
+ iconDescription: loadingIconDescription,
504
+ className: `${prefix}--inline-loading--btn`,
505
+ onSuccess: onLoadingSuccess
506
+ })));
507
+ });
508
+ DialogFooter.displayName = 'DialogFooter';
509
+ DialogFooter.propTypes = {
510
+ /**
511
+ * Provide the contents to be rendered inside of this component
512
+ */
513
+ children: PropTypes__default["default"].node,
514
+ /**
515
+ * Specify an optional className to be applied to the footer node
516
+ */
517
+ className: PropTypes__default["default"].string,
518
+ /**
519
+ * Specify a handler for closing dialog.
520
+ */
521
+ onRequestClose: PropTypes__default["default"].func,
522
+ /**
523
+ * Specify a handler for the secondary button.
524
+ */
525
+ onSecondarySubmit: PropTypes__default["default"].func,
526
+ /**
527
+ * Specify a handler for submitting dialog.
528
+ */
529
+ onRequestSubmit: PropTypes__default["default"].func,
530
+ /**
531
+ * Specify the text for the primary button
532
+ */
533
+ primaryButtonText: PropTypes__default["default"].node,
534
+ /**
535
+ * Specify whether the Button should be disabled, or not
536
+ */
537
+ primaryButtonDisabled: PropTypes__default["default"].bool,
538
+ /**
539
+ * Specify the text for the secondary button
540
+ */
541
+ secondaryButtonText: PropTypes__default["default"].node,
542
+ /**
543
+ * Specify an array of config objects for secondary buttons
544
+ */
545
+ secondaryButtons: (props, propName, componentName) => {
546
+ if (props.secondaryButtons) {
547
+ if (!Array.isArray(props.secondaryButtons) || props.secondaryButtons.length !== 2) {
548
+ return new Error(`${propName} needs to be an array of two button config objects`);
549
+ }
550
+ const shape = {
551
+ buttonText: PropTypes__default["default"].node,
552
+ onClick: PropTypes__default["default"].func
553
+ };
554
+ props[propName].forEach(secondaryButton => {
555
+ PropTypes__default["default"].checkPropTypes(shape, secondaryButton, propName, componentName);
556
+ });
557
+ }
558
+ return null;
559
+ },
560
+ /**
561
+ * Specify whether the Dialog is for dangerous actions
562
+ */
563
+ danger: PropTypes__default["default"].bool,
564
+ /**
565
+ * Specify loading status
566
+ */
567
+ loadingStatus: PropTypes__default["default"].oneOf(['inactive', 'active', 'finished', 'error']),
568
+ /**
569
+ * Specify the description for the loading text
570
+ */
571
+ loadingDescription: PropTypes__default["default"].string,
572
+ /**
573
+ * Specify the description for the loading icon
574
+ */
575
+ loadingIconDescription: PropTypes__default["default"].string,
576
+ /**
577
+ * Provide an optional handler to be invoked when loading is
578
+ * successful
579
+ */
580
+ onLoadingSuccess: PropTypes__default["default"].func
581
+ };
582
+ /**
583
+ * -------
584
+ * Exports
585
+ * -------
586
+ */
587
+
588
+ const Dialog = unstable__Dialog;
589
+ Dialog.Root = unstable__Dialog;
590
+ Dialog.Root.displayName = 'Dialog.Root';
591
+ Dialog.Header = DialogHeader;
592
+ Dialog.Header.displayName = 'Dialog.Header';
593
+ Dialog.Controls = DialogControls;
594
+ Dialog.Controls.displayName = 'Dialog.Controls';
595
+ Dialog.CloseButton = DialogCloseButton;
596
+ Dialog.CloseButton.displayName = 'Dialog.CloseButton';
597
+ Dialog.Title = DialogTitle;
598
+ Dialog.Title.displayName = 'Dialog.Title';
599
+ Dialog.Subtitle = DialogSubtitle;
600
+ Dialog.Subtitle.displayName = 'Dialog.Subtitle';
601
+ Dialog.Body = DialogBody;
602
+ Dialog.Body.displayName = 'Dialog.Body';
603
+ Dialog.Footer = DialogFooter;
604
+ Dialog.Footer.displayName = 'Dialog.Footer';
605
+
606
+ exports.Dialog = Dialog;
607
+ exports.DialogBody = DialogBody;
187
608
  exports.DialogCloseButton = DialogCloseButton;
188
609
  exports.DialogControls = DialogControls;
610
+ exports.DialogFooter = DialogFooter;
189
611
  exports.DialogHeader = DialogHeader;
612
+ exports.DialogSubtitle = DialogSubtitle;
613
+ exports.DialogTitle = DialogTitle;
190
614
  exports.unstable__Dialog = unstable__Dialog;
@@ -4,10 +4,9 @@
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 React from 'react';
7
+ import React, { type HTMLAttributes } from 'react';
8
8
  import { type ListBoxSize } from '../ListBox';
9
- import { ReactAttr } from '../../types/common';
10
- export interface DropdownSkeletonProps extends ReactAttr<HTMLDivElement> {
9
+ export interface DropdownSkeletonProps extends HTMLAttributes<HTMLDivElement> {
11
10
  /**
12
11
  * Specify an optional className to add.
13
12
  */
@@ -23,13 +23,12 @@ var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
23
23
  var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
24
24
  var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
25
25
 
26
- const DropdownSkeleton = _ref => {
27
- let {
28
- className,
29
- size,
30
- hideLabel,
31
- ...rest
32
- } = _ref;
26
+ const DropdownSkeleton = ({
27
+ className,
28
+ size,
29
+ hideLabel,
30
+ ...rest
31
+ }) => {
33
32
  const prefix = usePrefix.usePrefix();
34
33
  const wrapperClasses = cx__default["default"](className, `${prefix}--skeleton`, `${prefix}--form-item`, {
35
34
  [`${prefix}--list-box--${size}`]: size
@@ -4,15 +4,15 @@
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 React, { ReactNode, Ref } from 'react';
7
+ import React, { Ref, type HTMLAttributes, type ReactNode } from 'react';
8
8
  import { UseSelectProps } from 'downshift';
9
9
  import { type ListBoxMenuIconTranslationKey, type ListBoxSize, type ListBoxType } from '../ListBox';
10
- import { TranslateWithId, ReactAttr } from '../../types/common';
10
+ import { TranslateWithId } from '../../types/common';
11
11
  type ExcludedAttributes = 'id' | 'onChange';
12
12
  export interface OnChangeData<ItemType> {
13
13
  selectedItem: ItemType | null;
14
14
  }
15
- export interface DropdownProps<ItemType> extends Omit<ReactAttr<HTMLDivElement>, ExcludedAttributes>, TranslateWithId<ListBoxMenuIconTranslationKey> {
15
+ export interface DropdownProps<ItemType> extends Omit<HTMLAttributes<HTMLDivElement>, ExcludedAttributes>, TranslateWithId<ListBoxMenuIconTranslationKey> {
16
16
  /**
17
17
  * Specify a label to be read by screen readers on the container node
18
18
  * 'aria-label' of the ListBox component.