@carbon/react 1.110.0 → 1.111.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (505) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +927 -927
  2. package/es/components/AILabel/index.js +48 -1
  3. package/es/components/AISkeleton/AISkeletonIcon.js +7 -1
  4. package/es/components/AISkeleton/AISkeletonPlaceholder.js +7 -2
  5. package/es/components/AISkeleton/AISkeletonText.js +16 -1
  6. package/es/components/Accordion/Accordion.Skeleton.js +16 -1
  7. package/es/components/Accordion/Accordion.js +23 -1
  8. package/es/components/Accordion/AccordionItem.js +34 -1
  9. package/es/components/AspectRatio/AspectRatio.js +20 -1
  10. package/es/components/BadgeIndicator/index.js +10 -1
  11. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +13 -1
  12. package/es/components/Breadcrumb/Breadcrumb.js +17 -1
  13. package/es/components/Breadcrumb/BreadcrumbItem.js +13 -1
  14. package/es/components/Button/Button.Skeleton.js +18 -1
  15. package/es/components/Button/Button.js +96 -0
  16. package/es/components/Button/ButtonBase.js +1 -1
  17. package/es/components/ButtonSet/ButtonSet.js +15 -1
  18. package/es/components/ChatButton/ChatButton.Skeleton.js +7 -1
  19. package/es/components/ChatButton/ChatButton.js +25 -1
  20. package/es/components/Checkbox/Checkbox.Skeleton.js +6 -2
  21. package/es/components/Checkbox/Checkbox.js +59 -2
  22. package/es/components/CheckboxGroup/CheckboxGroup.js +41 -1
  23. package/es/components/ClassPrefix/index.js +3 -0
  24. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +7 -1
  25. package/es/components/CodeSnippet/CodeSnippet.js +77 -1
  26. package/es/components/ComboBox/ComboBox.js +141 -1
  27. package/es/components/ComboButton/index.js +28 -1
  28. package/es/components/ComposedModal/ComposedModal.js +70 -2
  29. package/es/components/ComposedModal/ModalFooter.js +65 -2
  30. package/es/components/ComposedModal/ModalHeader.js +36 -1
  31. package/es/components/ContainedList/ContainedList.js +22 -1
  32. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +19 -1
  33. package/es/components/ContentSwitcher/ContentSwitcher.js +26 -1
  34. package/es/components/Copy/Copy.js +31 -2
  35. package/es/components/CopyButton/CopyButton.js +28 -2
  36. package/es/components/DataTable/DataTable.js +59 -0
  37. package/es/components/DataTable/Table.js +28 -1
  38. package/es/components/DataTable/TableBatchAction.js +10 -0
  39. package/es/components/DataTable/TableBatchActions.js +25 -1
  40. package/es/components/DataTable/TableBody.js +3 -0
  41. package/es/components/DataTable/TableCell.js +16 -1
  42. package/es/components/DataTable/TableContainer.js +19 -1
  43. package/es/components/DataTable/TableDecoratorRow.js +7 -1
  44. package/es/components/DataTable/TableExpandHeader.js +32 -1
  45. package/es/components/DataTable/TableExpandRow.js +30 -1
  46. package/es/components/DataTable/TableExpandedRow.js +10 -1
  47. package/es/components/DataTable/TableHeader.js +36 -1
  48. package/es/components/DataTable/TableRow.js +22 -1
  49. package/es/components/DataTable/TableSelectAll.js +29 -1
  50. package/es/components/DataTable/TableSelectRow.js +32 -1
  51. package/es/components/DataTable/TableSlugRow.js +7 -1
  52. package/es/components/DataTable/TableToolbar.js +16 -1
  53. package/es/components/DataTable/TableToolbarMenu.js +16 -1
  54. package/es/components/DataTable/TableToolbarSearch.js +60 -2
  55. package/es/components/DataTableSkeleton/DataTableSkeleton.js +25 -1
  56. package/es/components/DatePicker/DatePicker.Skeleton.js +13 -1
  57. package/es/components/DatePicker/DatePicker.js +89 -1
  58. package/es/components/DatePickerInput/DatePickerInput.js +81 -2
  59. package/es/components/Dialog/Dialog.js +132 -5
  60. package/es/components/Dropdown/Dropdown.Skeleton.js +10 -1
  61. package/es/components/Dropdown/Dropdown.js +110 -1
  62. package/es/components/ExpandableSearch/ExpandableSearch.js +1 -1
  63. package/es/components/FeatureFlags/index.js +3 -0
  64. package/es/components/FileUploader/FileUploader.Skeleton.js +6 -2
  65. package/es/components/FileUploader/FileUploader.js +58 -1
  66. package/es/components/FileUploader/FileUploaderButton.js +49 -2
  67. package/es/components/FileUploader/FileUploaderDropContainer.js +44 -2
  68. package/es/components/FileUploader/FileUploaderItem.js +31 -2
  69. package/es/components/FileUploader/Filename.js +18 -0
  70. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +6 -2
  71. package/es/components/FluidComboBox/FluidComboBox.js +62 -1
  72. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +7 -1
  73. package/es/components/FluidDatePicker/FluidDatePicker.js +22 -1
  74. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +6 -2
  75. package/es/components/FluidDropdown/FluidDropdown.js +66 -1
  76. package/es/components/FluidForm/FluidForm.js +7 -1
  77. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +6 -2
  78. package/es/components/FluidMultiSelect/FluidMultiSelect.js +129 -1
  79. package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +6 -2
  80. package/es/components/FluidNumberInput/FluidNumberInput.js +96 -1
  81. package/es/components/FluidSearch/FluidSearch.Skeleton.js +6 -2
  82. package/es/components/FluidSearch/FluidSearch.js +46 -1
  83. package/es/components/FluidSelect/FluidSelect.Skeleton.js +6 -2
  84. package/es/components/FluidSelect/FluidSelect.js +39 -1
  85. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +6 -2
  86. package/es/components/FluidTextArea/FluidTextArea.js +68 -1
  87. package/es/components/FluidTextInput/FluidPasswordInput.js +59 -1
  88. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +6 -2
  89. package/es/components/FluidTextInput/FluidTextInput.js +55 -1
  90. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +7 -1
  91. package/es/components/FluidTimePicker/FluidTimePicker.js +29 -1
  92. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +26 -0
  93. package/es/components/Form/Form.js +7 -1
  94. package/es/components/FormGroup/FormGroup.js +26 -1
  95. package/es/components/FormItem/FormItem.js +7 -1
  96. package/es/components/FormLabel/FormLabel.js +10 -1
  97. package/es/components/Grid/CSSGrid.js +44 -1
  98. package/es/components/Grid/Column.js +87 -1
  99. package/es/components/Grid/ColumnHang.js +10 -1
  100. package/es/components/Grid/FlexGrid.js +25 -1
  101. package/es/components/Grid/Grid.js +27 -0
  102. package/es/components/Grid/GridContext.js +10 -0
  103. package/es/components/Grid/Row.js +18 -1
  104. package/es/components/Heading/index.js +19 -0
  105. package/es/components/Icon/Icon.Skeleton.js +6 -2
  106. package/es/components/IconButton/index.js +69 -1
  107. package/es/components/IconIndicator/index.js +13 -1
  108. package/es/components/IdPrefix/index.js +3 -0
  109. package/es/components/InlineCheckbox/InlineCheckbox.js +34 -0
  110. package/es/components/InlineLoading/InlineLoading.js +20 -1
  111. package/es/components/Layer/index.js +18 -1
  112. package/es/components/Layout/index.js +35 -1
  113. package/es/components/LayoutDirection/LayoutDirection.js +10 -0
  114. package/es/components/Link/Link.d.ts +1 -1
  115. package/es/components/Link/Link.js +29 -1
  116. package/es/components/ListBox/ListBox.js +42 -1
  117. package/es/components/ListBox/ListBoxField.js +17 -0
  118. package/es/components/ListBox/ListBoxMenu.js +6 -0
  119. package/es/components/ListBox/ListBoxMenuIcon.js +8 -1
  120. package/es/components/ListBox/ListBoxMenuItem.js +17 -1
  121. package/es/components/ListBox/ListBoxSelection.d.ts +1 -1
  122. package/es/components/ListBox/ListBoxSelection.js +33 -10
  123. package/es/components/ListBox/next/ListBoxSelection.d.ts +1 -1
  124. package/es/components/ListBox/next/ListBoxSelection.js +42 -7
  125. package/es/components/ListBox/next/ListBoxTrigger.js +8 -1
  126. package/es/components/ListItem/ListItem.js +7 -1
  127. package/es/components/Loading/Loading.js +19 -1
  128. package/es/components/Menu/Menu.js +53 -1
  129. package/es/components/Menu/MenuItem.js +78 -2
  130. package/es/components/MenuButton/index.js +34 -1
  131. package/es/components/Modal/Modal.js +118 -4
  132. package/es/components/ModalWrapper/ModalWrapper.js +2 -2
  133. package/es/components/MultiSelect/FilterableMultiSelect.js +129 -1
  134. package/es/components/MultiSelect/MultiSelect.js +151 -3
  135. package/es/components/MultiSelect/MultiSelectPropTypes.js +25 -0
  136. package/es/components/Notification/Notification.js +210 -3
  137. package/es/components/NumberInput/NumberInput.Skeleton.js +10 -1
  138. package/es/components/NumberInput/NumberInput.js +139 -1
  139. package/es/components/OrderedList/OrderedList.js +16 -1
  140. package/es/components/OverflowMenu/OverflowMenu.js +78 -2
  141. package/es/components/OverflowMenu/next/index.js +31 -1
  142. package/es/components/OverflowMenuItem/OverflowMenuItem.js +38 -2
  143. package/es/components/PageHeader/PageHeader.js +49 -1
  144. package/es/components/Pagination/Pagination.Skeleton.js +6 -2
  145. package/es/components/Pagination/Pagination.d.ts +8 -0
  146. package/es/components/Pagination/Pagination.js +86 -4
  147. package/es/components/Pagination/experimental/PageSelector.js +9 -1
  148. package/es/components/Pagination/experimental/Pagination.js +55 -1
  149. package/es/components/PaginationNav/PaginationNav.js +81 -1
  150. package/es/components/Popover/index.js +59 -1
  151. package/es/components/ProgressBar/ProgressBar.js +28 -1
  152. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +7 -1
  153. package/es/components/ProgressIndicator/ProgressIndicator.js +59 -1
  154. package/es/components/RadioButton/RadioButton.Skeleton.js +6 -2
  155. package/es/components/RadioButton/RadioButton.js +64 -1
  156. package/es/components/RadioButtonGroup/RadioButtonGroup.js +60 -1
  157. package/es/components/RadioTile/RadioTile.js +47 -2
  158. package/es/components/Search/Search.Skeleton.js +10 -1
  159. package/es/components/Search/Search.js +68 -3
  160. package/es/components/Select/Select.Skeleton.js +7 -1
  161. package/es/components/Select/Select.js +83 -20
  162. package/es/components/SelectItem/SelectItem.js +16 -1
  163. package/es/components/SelectItemGroup/SelectItemGroup.js +13 -1
  164. package/es/components/ShapeIndicator/index.js +13 -1
  165. package/es/components/SkeletonIcon/SkeletonIcon.js +6 -2
  166. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +6 -2
  167. package/es/components/SkeletonText/SkeletonText.js +16 -1
  168. package/es/components/Slider/Slider.Skeleton.js +16 -1
  169. package/es/components/Slider/Slider.js +105 -1
  170. package/es/components/Stack/Stack.js +21 -1
  171. package/es/components/StructuredList/StructuredList.Skeleton.js +7 -1
  172. package/es/components/StructuredList/StructuredList.js +98 -1
  173. package/es/components/Switch/IconSwitch.js +49 -2
  174. package/es/components/Switch/Switch.js +32 -2
  175. package/es/components/TabContent/TabContent.js +10 -1
  176. package/es/components/Tabs/Tabs.Skeleton.js +7 -1
  177. package/es/components/Tabs/Tabs.js +175 -2
  178. package/es/components/Tag/DismissibleTag.js +44 -1
  179. package/es/components/Tag/OperationalTag.js +23 -1
  180. package/es/components/Tag/SelectableTag.js +32 -1
  181. package/es/components/Tag/Tag.Skeleton.js +8 -1
  182. package/es/components/Tag/Tag.js +42 -1
  183. package/es/components/Text/Text.js +10 -0
  184. package/es/components/Text/TextDirection.js +11 -0
  185. package/es/components/TextArea/TextArea.Skeleton.js +7 -1
  186. package/es/components/TextArea/TextArea.js +82 -2
  187. package/es/components/TextInput/ControlledPasswordInput.js +66 -2
  188. package/es/components/TextInput/PasswordInput.js +84 -1
  189. package/es/components/TextInput/TextInput.Skeleton.js +10 -1
  190. package/es/components/TextInput/TextInput.js +77 -1
  191. package/es/components/Theme/index.js +22 -1
  192. package/es/components/Tile/Tile.js +158 -3
  193. package/es/components/TileGroup/TileGroup.js +29 -1
  194. package/es/components/TimePicker/TimePicker.js +68 -1
  195. package/es/components/TimePickerSelect/TimePickerSelect.js +16 -1
  196. package/es/components/Toggle/Toggle.Skeleton.js +1 -1
  197. package/es/components/Toggle/Toggle.js +47 -1
  198. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +12 -1
  199. package/es/components/Toggletip/index.js +39 -1
  200. package/es/components/Tooltip/DefinitionTooltip.js +37 -1
  201. package/es/components/Tooltip/Tooltip.js +47 -1
  202. package/es/components/TreeView/TreeNode.js +65 -1
  203. package/es/components/TreeView/TreeView.js +33 -1
  204. package/es/components/UIShell/Content.js +10 -1
  205. package/es/components/UIShell/Header.js +10 -1
  206. package/es/components/UIShell/HeaderContainer.js +9 -0
  207. package/es/components/UIShell/HeaderGlobalAction.js +29 -1
  208. package/es/components/UIShell/HeaderMenu.js +38 -1
  209. package/es/components/UIShell/HeaderMenuButton.js +18 -1
  210. package/es/components/UIShell/HeaderMenuItem.js +26 -1
  211. package/es/components/UIShell/HeaderName.js +19 -1
  212. package/es/components/UIShell/HeaderNavigation.js +11 -1
  213. package/es/components/UIShell/HeaderPanel.js +21 -2
  214. package/es/components/UIShell/HeaderSideNavItems.js +12 -1
  215. package/es/components/UIShell/Link.js +14 -0
  216. package/es/components/UIShell/SideNav.js +54 -1
  217. package/es/components/UIShell/SideNavDetails.js +11 -1
  218. package/es/components/UIShell/SideNavDivider.js +6 -2
  219. package/es/components/UIShell/SideNavFooter.js +12 -1
  220. package/es/components/UIShell/SideNavHeader.js +14 -1
  221. package/es/components/UIShell/SideNavIcon.js +11 -1
  222. package/es/components/UIShell/SideNavItem.js +11 -1
  223. package/es/components/UIShell/SideNavItems.js +12 -1
  224. package/es/components/UIShell/SideNavLink.js +23 -1
  225. package/es/components/UIShell/SideNavLinkText.js +7 -1
  226. package/es/components/UIShell/SideNavMenu.js +32 -1
  227. package/es/components/UIShell/SideNavMenuItem.js +18 -1
  228. package/es/components/UIShell/SideNavSwitcher.js +17 -1
  229. package/es/components/UIShell/SkipToContent.js +12 -1
  230. package/es/components/UIShell/Switcher.js +13 -1
  231. package/es/components/UIShell/SwitcherDivider.js +6 -2
  232. package/es/components/UIShell/SwitcherItem.js +31 -1
  233. package/es/components/UnorderedList/UnorderedList.js +13 -1
  234. package/es/internal/FloatingMenu.js +1 -1
  235. package/es/internal/OptimizedResize.js +6 -2
  236. package/es/internal/usePresence.js +6 -0
  237. package/es/tools/wrapComponent.js +1 -1
  238. package/lib/components/AILabel/index.js +49 -2
  239. package/lib/components/AISkeleton/AISkeletonIcon.js +8 -2
  240. package/lib/components/AISkeleton/AISkeletonPlaceholder.js +8 -3
  241. package/lib/components/AISkeleton/AISkeletonText.js +17 -2
  242. package/lib/components/Accordion/Accordion.Skeleton.js +17 -2
  243. package/lib/components/Accordion/Accordion.js +24 -2
  244. package/lib/components/Accordion/AccordionItem.js +35 -2
  245. package/lib/components/AspectRatio/AspectRatio.js +21 -2
  246. package/lib/components/BadgeIndicator/index.js +11 -2
  247. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +14 -2
  248. package/lib/components/Breadcrumb/Breadcrumb.js +18 -2
  249. package/lib/components/Breadcrumb/BreadcrumbItem.js +14 -2
  250. package/lib/components/Button/Button.Skeleton.js +19 -2
  251. package/lib/components/Button/Button.js +96 -0
  252. package/lib/components/Button/ButtonBase.js +2 -2
  253. package/lib/components/ButtonSet/ButtonSet.js +16 -2
  254. package/lib/components/ChatButton/ChatButton.Skeleton.js +8 -2
  255. package/lib/components/ChatButton/ChatButton.js +26 -2
  256. package/lib/components/Checkbox/Checkbox.Skeleton.js +7 -3
  257. package/lib/components/Checkbox/Checkbox.js +60 -3
  258. package/lib/components/CheckboxGroup/CheckboxGroup.js +42 -2
  259. package/lib/components/ClassPrefix/index.js +3 -0
  260. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +8 -2
  261. package/lib/components/CodeSnippet/CodeSnippet.js +78 -2
  262. package/lib/components/ComboBox/ComboBox.js +142 -2
  263. package/lib/components/ComboButton/index.js +29 -2
  264. package/lib/components/ComposedModal/ComposedModal.js +71 -3
  265. package/lib/components/ComposedModal/ComposedModalContext.js +0 -1
  266. package/lib/components/ComposedModal/ModalFooter.js +66 -3
  267. package/lib/components/ComposedModal/ModalHeader.js +37 -2
  268. package/lib/components/ComposedModal/useComposedModalState.js +0 -1
  269. package/lib/components/ContainedList/ContainedList.js +23 -2
  270. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +20 -2
  271. package/lib/components/ContainedList/index.js +2 -2
  272. package/lib/components/ContentSwitcher/ContentSwitcher.js +27 -2
  273. package/lib/components/ContextMenu/useContextMenu.js +0 -1
  274. package/lib/components/Copy/Copy.js +32 -3
  275. package/lib/components/CopyButton/CopyButton.js +29 -3
  276. package/lib/components/DataTable/DataTable.js +59 -0
  277. package/lib/components/DataTable/Table.js +29 -2
  278. package/lib/components/DataTable/TableBatchAction.js +10 -0
  279. package/lib/components/DataTable/TableBatchActions.js +26 -2
  280. package/lib/components/DataTable/TableBody.js +3 -0
  281. package/lib/components/DataTable/TableCell.js +17 -2
  282. package/lib/components/DataTable/TableContainer.js +20 -2
  283. package/lib/components/DataTable/TableContext.js +0 -1
  284. package/lib/components/DataTable/TableDecoratorRow.js +8 -2
  285. package/lib/components/DataTable/TableExpandHeader.js +33 -2
  286. package/lib/components/DataTable/TableExpandRow.js +31 -2
  287. package/lib/components/DataTable/TableExpandedRow.js +11 -2
  288. package/lib/components/DataTable/TableHeader.js +37 -2
  289. package/lib/components/DataTable/TableRow.js +23 -2
  290. package/lib/components/DataTable/TableSelectAll.js +30 -2
  291. package/lib/components/DataTable/TableSelectRow.js +33 -2
  292. package/lib/components/DataTable/TableSlugRow.js +8 -2
  293. package/lib/components/DataTable/TableToolbar.js +17 -2
  294. package/lib/components/DataTable/TableToolbarMenu.js +17 -2
  295. package/lib/components/DataTable/TableToolbarSearch.js +61 -3
  296. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +26 -2
  297. package/lib/components/DatePicker/DatePicker.Skeleton.js +14 -2
  298. package/lib/components/DatePicker/DatePicker.js +90 -2
  299. package/lib/components/DatePickerInput/DatePickerInput.js +82 -3
  300. package/lib/components/Dialog/Dialog.js +133 -6
  301. package/lib/components/Dropdown/Dropdown.Skeleton.js +11 -2
  302. package/lib/components/Dropdown/Dropdown.js +111 -2
  303. package/lib/components/ErrorBoundary/ErrorBoundaryContext.js +0 -1
  304. package/lib/components/ExpandableSearch/ExpandableSearch.js +2 -2
  305. package/lib/components/FeatureFlags/index.js +3 -0
  306. package/lib/components/FileUploader/FileUploader.Skeleton.js +7 -3
  307. package/lib/components/FileUploader/FileUploader.js +59 -2
  308. package/lib/components/FileUploader/FileUploaderButton.js +50 -3
  309. package/lib/components/FileUploader/FileUploaderDropContainer.js +45 -3
  310. package/lib/components/FileUploader/FileUploaderItem.js +32 -3
  311. package/lib/components/FileUploader/Filename.js +18 -0
  312. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +7 -3
  313. package/lib/components/FluidComboBox/FluidComboBox.js +63 -2
  314. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +8 -2
  315. package/lib/components/FluidDatePicker/FluidDatePicker.js +23 -2
  316. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +7 -3
  317. package/lib/components/FluidDropdown/FluidDropdown.js +67 -2
  318. package/lib/components/FluidForm/FluidForm.js +8 -2
  319. package/lib/components/FluidForm/FormContext.js +0 -1
  320. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +7 -3
  321. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +130 -2
  322. package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +7 -3
  323. package/lib/components/FluidNumberInput/FluidNumberInput.js +97 -2
  324. package/lib/components/FluidSearch/FluidSearch.Skeleton.js +7 -3
  325. package/lib/components/FluidSearch/FluidSearch.js +47 -2
  326. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +7 -3
  327. package/lib/components/FluidSelect/FluidSelect.js +40 -2
  328. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +7 -3
  329. package/lib/components/FluidTextArea/FluidTextArea.js +69 -2
  330. package/lib/components/FluidTextInput/FluidPasswordInput.js +60 -2
  331. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +7 -3
  332. package/lib/components/FluidTextInput/FluidTextInput.js +56 -2
  333. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +8 -2
  334. package/lib/components/FluidTimePicker/FluidTimePicker.js +30 -2
  335. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +26 -0
  336. package/lib/components/Form/Form.js +8 -2
  337. package/lib/components/FormGroup/FormGroup.js +27 -2
  338. package/lib/components/FormItem/FormItem.js +8 -2
  339. package/lib/components/FormLabel/FormLabel.js +11 -2
  340. package/lib/components/Grid/CSSGrid.js +45 -2
  341. package/lib/components/Grid/Column.js +88 -2
  342. package/lib/components/Grid/ColumnHang.js +11 -2
  343. package/lib/components/Grid/FlexGrid.js +26 -2
  344. package/lib/components/Grid/Grid.js +27 -0
  345. package/lib/components/Grid/GridContext.js +10 -0
  346. package/lib/components/Grid/Row.js +19 -2
  347. package/lib/components/Heading/index.js +19 -0
  348. package/lib/components/Icon/Icon.Skeleton.js +7 -3
  349. package/lib/components/IconButton/index.js +70 -2
  350. package/lib/components/IconIndicator/index.js +14 -2
  351. package/lib/components/IdPrefix/index.js +3 -0
  352. package/lib/components/InlineCheckbox/InlineCheckbox.js +34 -0
  353. package/lib/components/InlineLoading/InlineLoading.js +21 -2
  354. package/lib/components/Layer/index.js +19 -2
  355. package/lib/components/Layout/index.js +36 -2
  356. package/lib/components/LayoutDirection/LayoutDirection.js +10 -0
  357. package/lib/components/LayoutDirection/useLayoutDirection.js +0 -1
  358. package/lib/components/Link/Link.d.ts +1 -1
  359. package/lib/components/Link/Link.js +30 -2
  360. package/lib/components/ListBox/ListBox.js +43 -2
  361. package/lib/components/ListBox/ListBoxField.js +17 -0
  362. package/lib/components/ListBox/ListBoxMenu.js +6 -0
  363. package/lib/components/ListBox/ListBoxMenuIcon.js +9 -2
  364. package/lib/components/ListBox/ListBoxMenuItem.js +18 -2
  365. package/lib/components/ListBox/ListBoxSelection.d.ts +1 -1
  366. package/lib/components/ListBox/ListBoxSelection.js +34 -11
  367. package/lib/components/ListBox/next/ListBoxSelection.d.ts +1 -1
  368. package/lib/components/ListBox/next/ListBoxSelection.js +43 -8
  369. package/lib/components/ListBox/next/ListBoxTrigger.js +9 -2
  370. package/lib/components/ListItem/ListItem.js +8 -2
  371. package/lib/components/Loading/Loading.js +20 -2
  372. package/lib/components/Menu/Menu.js +54 -2
  373. package/lib/components/Menu/MenuContext.js +0 -1
  374. package/lib/components/Menu/MenuItem.js +79 -3
  375. package/lib/components/MenuButton/index.js +35 -2
  376. package/lib/components/Modal/Modal.js +119 -5
  377. package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
  378. package/lib/components/MultiSelect/FilterableMultiSelect.js +130 -2
  379. package/lib/components/MultiSelect/MultiSelect.js +151 -3
  380. package/lib/components/MultiSelect/MultiSelectPropTypes.js +25 -0
  381. package/lib/components/Notification/Notification.js +211 -4
  382. package/lib/components/NumberInput/NumberInput.Skeleton.js +11 -2
  383. package/lib/components/NumberInput/NumberInput.js +140 -2
  384. package/lib/components/OrderedList/OrderedList.js +17 -2
  385. package/lib/components/OverflowMenu/OverflowMenu.js +79 -3
  386. package/lib/components/OverflowMenu/next/index.js +32 -2
  387. package/lib/components/OverflowMenuItem/OverflowMenuItem.js +39 -3
  388. package/lib/components/PageHeader/PageHeader.js +50 -2
  389. package/lib/components/Pagination/Pagination.Skeleton.js +7 -3
  390. package/lib/components/Pagination/Pagination.d.ts +8 -0
  391. package/lib/components/Pagination/Pagination.js +87 -5
  392. package/lib/components/Pagination/experimental/PageSelector.js +10 -2
  393. package/lib/components/Pagination/experimental/Pagination.js +56 -2
  394. package/lib/components/PaginationNav/PaginationNav.js +82 -2
  395. package/lib/components/Popover/index.js +60 -2
  396. package/lib/components/ProgressBar/ProgressBar.js +29 -2
  397. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +8 -2
  398. package/lib/components/ProgressIndicator/ProgressIndicator.js +60 -2
  399. package/lib/components/RadioButton/RadioButton.Skeleton.js +7 -3
  400. package/lib/components/RadioButton/RadioButton.js +65 -2
  401. package/lib/components/RadioButtonGroup/RadioButtonGroup.js +61 -2
  402. package/lib/components/RadioTile/RadioTile.js +48 -3
  403. package/lib/components/Search/Search.Skeleton.js +11 -2
  404. package/lib/components/Search/Search.js +69 -4
  405. package/lib/components/Select/Select.Skeleton.js +8 -2
  406. package/lib/components/Select/Select.js +84 -21
  407. package/lib/components/SelectItem/SelectItem.js +17 -2
  408. package/lib/components/SelectItemGroup/SelectItemGroup.js +14 -2
  409. package/lib/components/ShapeIndicator/index.js +14 -2
  410. package/lib/components/SkeletonIcon/SkeletonIcon.js +7 -3
  411. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +7 -3
  412. package/lib/components/SkeletonText/SkeletonText.js +17 -2
  413. package/lib/components/Slider/Slider.Skeleton.js +17 -2
  414. package/lib/components/Slider/Slider.js +106 -2
  415. package/lib/components/Stack/Stack.js +22 -2
  416. package/lib/components/StructuredList/StructuredList.Skeleton.js +8 -2
  417. package/lib/components/StructuredList/StructuredList.js +99 -2
  418. package/lib/components/Switch/IconSwitch.js +50 -3
  419. package/lib/components/Switch/Switch.js +33 -3
  420. package/lib/components/TabContent/TabContent.js +11 -2
  421. package/lib/components/Tabs/Tabs.Skeleton.js +8 -2
  422. package/lib/components/Tabs/Tabs.js +176 -3
  423. package/lib/components/Tabs/usePressable.js +0 -1
  424. package/lib/components/Tag/DismissibleTag.js +45 -2
  425. package/lib/components/Tag/OperationalTag.js +24 -2
  426. package/lib/components/Tag/SelectableTag.js +33 -2
  427. package/lib/components/Tag/Tag.Skeleton.js +9 -2
  428. package/lib/components/Tag/Tag.js +43 -2
  429. package/lib/components/Text/Text.js +10 -0
  430. package/lib/components/Text/TextDirection.js +11 -0
  431. package/lib/components/Text/TextDirectionContext.js +0 -1
  432. package/lib/components/TextArea/TextArea.Skeleton.js +8 -2
  433. package/lib/components/TextArea/TextArea.js +83 -3
  434. package/lib/components/TextInput/ControlledPasswordInput.js +67 -3
  435. package/lib/components/TextInput/PasswordInput.js +85 -2
  436. package/lib/components/TextInput/TextInput.Skeleton.js +11 -2
  437. package/lib/components/TextInput/TextInput.js +78 -2
  438. package/lib/components/Theme/index.js +23 -2
  439. package/lib/components/Tile/Tile.js +159 -4
  440. package/lib/components/TileGroup/TileGroup.js +29 -1
  441. package/lib/components/TimePicker/TimePicker.js +69 -2
  442. package/lib/components/TimePickerSelect/TimePickerSelect.js +17 -2
  443. package/lib/components/Toggle/Toggle.Skeleton.js +2 -2
  444. package/lib/components/Toggle/Toggle.js +48 -2
  445. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +13 -2
  446. package/lib/components/Toggletip/index.js +40 -2
  447. package/lib/components/Tooltip/DefinitionTooltip.js +38 -2
  448. package/lib/components/Tooltip/Tooltip.js +48 -2
  449. package/lib/components/TreeView/TreeContext.js +0 -1
  450. package/lib/components/TreeView/TreeNode.js +66 -2
  451. package/lib/components/TreeView/TreeView.js +34 -2
  452. package/lib/components/UIShell/Content.js +11 -2
  453. package/lib/components/UIShell/Header.js +11 -2
  454. package/lib/components/UIShell/HeaderContainer.js +9 -0
  455. package/lib/components/UIShell/HeaderGlobalAction.js +30 -2
  456. package/lib/components/UIShell/HeaderMenu.js +39 -2
  457. package/lib/components/UIShell/HeaderMenuButton.js +19 -2
  458. package/lib/components/UIShell/HeaderMenuItem.js +27 -2
  459. package/lib/components/UIShell/HeaderName.js +20 -2
  460. package/lib/components/UIShell/HeaderNavigation.js +12 -2
  461. package/lib/components/UIShell/HeaderPanel.js +22 -3
  462. package/lib/components/UIShell/HeaderSideNavItems.js +13 -2
  463. package/lib/components/UIShell/Link.js +14 -0
  464. package/lib/components/UIShell/SideNav.js +55 -2
  465. package/lib/components/UIShell/SideNavDetails.js +12 -2
  466. package/lib/components/UIShell/SideNavDivider.js +7 -3
  467. package/lib/components/UIShell/SideNavFooter.js +13 -2
  468. package/lib/components/UIShell/SideNavHeader.js +15 -2
  469. package/lib/components/UIShell/SideNavIcon.js +12 -2
  470. package/lib/components/UIShell/SideNavItem.js +12 -2
  471. package/lib/components/UIShell/SideNavItems.js +13 -2
  472. package/lib/components/UIShell/SideNavLink.js +24 -2
  473. package/lib/components/UIShell/SideNavLinkText.js +8 -2
  474. package/lib/components/UIShell/SideNavMenu.js +33 -2
  475. package/lib/components/UIShell/SideNavMenuItem.js +19 -2
  476. package/lib/components/UIShell/SideNavSwitcher.js +18 -2
  477. package/lib/components/UIShell/SkipToContent.js +13 -2
  478. package/lib/components/UIShell/Switcher.js +14 -2
  479. package/lib/components/UIShell/SwitcherDivider.js +7 -3
  480. package/lib/components/UIShell/SwitcherItem.js +32 -2
  481. package/lib/components/UnorderedList/UnorderedList.js +14 -2
  482. package/lib/feature-flags.js +0 -1
  483. package/lib/index.js +241 -242
  484. package/lib/internal/FloatingMenu.js +1 -1
  485. package/lib/internal/OptimizedResize.js +6 -2
  486. package/lib/internal/useAttachedMenu.js +0 -1
  487. package/lib/internal/useControllableState.js +0 -1
  488. package/lib/internal/useDelayedState.js +0 -1
  489. package/lib/internal/useEvent.js +0 -1
  490. package/lib/internal/useIsomorphicEffect.js +0 -1
  491. package/lib/internal/useMatchMedia.js +0 -1
  492. package/lib/internal/useMergedRefs.js +0 -1
  493. package/lib/internal/useNoInteractiveChildren.js +0 -1
  494. package/lib/internal/useOutsideClick.js +0 -1
  495. package/lib/internal/useOverflowItems.js +0 -1
  496. package/lib/internal/usePresence.js +6 -1
  497. package/lib/internal/usePresenceContext.js +0 -1
  498. package/lib/internal/usePreviousValue.js +0 -1
  499. package/lib/internal/useResizeObserver.js +0 -1
  500. package/lib/internal/useSavedCallback.js +0 -1
  501. package/lib/internal/utils.js +0 -1
  502. package/lib/internal/wrapFocus.js +0 -1
  503. package/lib/tools/wrapComponent.js +2 -2
  504. package/package.json +9 -9
  505. package/telemetry.yml +12 -0
@@ -452,25 +452,68 @@ DataTable.TableToolbarContent = TableToolbarContent;
452
452
  DataTable.TableToolbarSearch = TableToolbarSearch;
453
453
  DataTable.TableToolbarMenu = TableToolbarMenu;
454
454
  DataTable.propTypes = {
455
+ /**
456
+ * Pass in the children that will be rendered within the Table
457
+ */
455
458
  children: PropTypes.func,
459
+ /**
460
+ * Experimental property. Allows table to align cell contents to the top if there is text wrapping in the content. Might have performance issues, intended for smaller tables
461
+ */
456
462
  experimentalAutoAlign: PropTypes.bool,
463
+ /**
464
+ * Optional hook to manually control filtering of the rows from the
465
+ * TableToolbarSearch component
466
+ */
457
467
  filterRows: PropTypes.func,
468
+ /**
469
+ * The `headers` prop represents the order in which the headers should
470
+ * appear in the table. We expect an array of objects to be passed in, where
471
+ * `key` is the name of the key in a row object, and `header` is the name of
472
+ * the header.
473
+ */
458
474
  headers: PropTypes.arrayOf(PropTypes.shape({
459
475
  key: PropTypes.string.isRequired,
460
476
  header: PropTypes.node.isRequired,
461
477
  isSortable: PropTypes.bool
462
478
  })).isRequired,
479
+ /**
480
+ * Specify whether the table should be able to be sorted by its headers
481
+ */
463
482
  isSortable: PropTypes.bool,
483
+ /**
484
+ * Provide a string for the current locale
485
+ */
464
486
  locale: PropTypes.string,
487
+ /**
488
+ * Specify whether the overflow menu (if it exists) should be shown always, or only on hover
489
+ */
465
490
  overflowMenuOnHover: PropTypes.bool,
491
+ /**
492
+ * Specify whether the control should be a radio button or inline checkbox
493
+ */
466
494
  radio: PropTypes.bool,
495
+ /**
496
+ * @deprecated Use `children` instead. This prop will be removed in
497
+ * the next major version.
498
+ *
499
+ * https://www.patterns.dev/react/render-props-pattern/#children-as-a-function
500
+ */
467
501
  render: deprecate(PropTypes.func),
502
+ /**
503
+ * The `rows` prop is where you provide us with a list of all the rows that
504
+ * you want to render in the table. The only hard requirement is that this
505
+ * is an array of objects, and that each object has a unique `id` field
506
+ * available on it.
507
+ */
468
508
  rows: PropTypes.arrayOf(PropTypes.shape({
469
509
  id: PropTypes.string.isRequired,
470
510
  disabled: PropTypes.bool,
471
511
  isSelected: PropTypes.bool,
472
512
  isExpanded: PropTypes.bool
473
513
  })).isRequired,
514
+ /**
515
+ * Change the row height of table. Currently supports `xs`, `sm`, `md`, `lg`, and `xl`.
516
+ */
474
517
  size: PropTypes.oneOf([
475
518
  "xs",
476
519
  "sm",
@@ -478,10 +521,26 @@ DataTable.propTypes = {
478
521
  "lg",
479
522
  "xl"
480
523
  ]),
524
+ /**
525
+ * Optional hook to manually control sorting of the rows.
526
+ */
481
527
  sortRow: PropTypes.func,
528
+ /**
529
+ * Specify whether the header should be sticky.
530
+ * Still experimental: may not work with every combination of table props
531
+ */
482
532
  stickyHeader: PropTypes.bool,
533
+ /**
534
+ * Translates component strings using your i18n tool.
535
+ */
483
536
  translateWithId: PropTypes.func,
537
+ /**
538
+ * If `true`, sets the table width to `auto` instead of `100%`.
539
+ */
484
540
  useStaticWidth: PropTypes.bool,
541
+ /**
542
+ * `true` to add useZebraStyles striping.
543
+ */
485
544
  useZebraStyles: PropTypes.bool
486
545
  };
487
546
  //#endregion
@@ -9,8 +9,8 @@ import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import useIsomorphicEffect from "../../internal/useIsomorphicEffect.js";
10
10
  import { useWindowEvent } from "../../internal/useEvent.js";
11
11
  import { TableContext } from "./TableContext.js";
12
- import { useCallback, useContext, useRef } from "react";
13
12
  import classNames from "classnames";
13
+ import { useCallback, useContext, useRef } from "react";
14
14
  import PropTypes from "prop-types";
15
15
  import { jsx } from "react/jsx-runtime";
16
16
  import { debounce } from "es-toolkit/compat";
@@ -101,11 +101,26 @@ const Table = ({ className, children, useZebraStyles, size = "lg", isSortable =
101
101
  }) : table;
102
102
  };
103
103
  Table.propTypes = {
104
+ /**
105
+ * Pass in the children that will be rendered within the Table
106
+ */
104
107
  children: PropTypes.node,
105
108
  className: PropTypes.string,
109
+ /**
110
+ * Experimental property. Allows table to align cell contents to the top if there is text wrapping in the content. Might have performance issues, intended for smaller tables
111
+ */
106
112
  experimentalAutoAlign: PropTypes.bool,
113
+ /**
114
+ * `false` If true, will apply sorting styles
115
+ */
107
116
  isSortable: PropTypes.bool,
117
+ /**
118
+ * Specify whether the overflow menu (if it exists) should be shown always, or only on hover
119
+ */
108
120
  overflowMenuOnHover: PropTypes.bool,
121
+ /**
122
+ * Change the row height of table. Currently supports `xs`, `sm`, `md`, `lg`, and `xl`.
123
+ */
109
124
  size: PropTypes.oneOf([
110
125
  "xs",
111
126
  "sm",
@@ -113,9 +128,21 @@ Table.propTypes = {
113
128
  "lg",
114
129
  "xl"
115
130
  ]),
131
+ /**
132
+ * `false` If true, will keep the header sticky (only data rows will scroll)
133
+ */
116
134
  stickyHeader: PropTypes.bool,
135
+ /**
136
+ * If `true`, sets the table width to `auto` instead of `100%`.
137
+ */
117
138
  useStaticWidth: PropTypes.bool,
139
+ /**
140
+ * `true` to add useZebraStyles striping.
141
+ */
118
142
  useZebraStyles: PropTypes.bool,
143
+ /**
144
+ * Specify the table tabIndex
145
+ */
119
146
  tabIndex: PropTypes.number
120
147
  };
121
148
  //#endregion
@@ -23,10 +23,20 @@ const TableBatchAction = ({ renderIcon = AddFilled, iconDescription = "Add", ...
23
23
  ...props
24
24
  });
25
25
  TableBatchAction.propTypes = {
26
+ /**
27
+ * Specify if the button is an icon-only button
28
+ */
26
29
  hasIconOnly: PropTypes.bool,
30
+ /**
31
+ * If specifying the `renderIcon` prop, provide a description for that icon that can
32
+ * be read by screen readers
33
+ */
27
34
  iconDescription: (props) => {
28
35
  if (props.renderIcon && !props.children && !props.iconDescription) return /* @__PURE__ */ new Error("renderIcon property specified without also providing an iconDescription property.");
29
36
  },
37
+ /**
38
+ * A component used to render an icon.
39
+ */
30
40
  renderIcon: PropTypes.oneOfType([PropTypes.func, PropTypes.object])
31
41
  };
32
42
  //#endregion
@@ -9,8 +9,8 @@ import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import { Text } from "../Text/Text.js";
10
10
  import Button_default from "../Button/index.js";
11
11
  import TableActionList from "./TableActionList.js";
12
- import React from "react";
13
12
  import classNames from "classnames";
13
+ import React from "react";
14
14
  import PropTypes from "prop-types";
15
15
  import { Fragment, jsx, jsxs } from "react/jsx-runtime";
16
16
  //#region src/components/DataTable/TableBatchActions.tsx
@@ -83,11 +83,35 @@ const TableBatchActions = ({ className, children, shouldShowBatchActions, totalS
83
83
  TableBatchActions.propTypes = {
84
84
  children: PropTypes.node,
85
85
  className: PropTypes.string,
86
+ /**
87
+ * Hook required to listen for when the user initiates a cancel request
88
+ * through this component
89
+ */
86
90
  onCancel: PropTypes.func.isRequired,
91
+ /**
92
+ * Hook to listen for when the user initiates a select all
93
+ * request through this component. This _only_ controls the rendering
94
+ * of the `Select All` button and does not include built in functionality
95
+ */
87
96
  onSelectAll: PropTypes.func,
97
+ /**
98
+ * Boolean specifier for whether or not the batch action bar should be
99
+ * displayed
100
+ */
88
101
  shouldShowBatchActions: PropTypes.bool,
102
+ /**
103
+ * Numeric representation of the total number of items in a table.
104
+ * This number is used in the select all button text
105
+ */
89
106
  totalCount: PropTypes.number,
107
+ /**
108
+ * Numeric representation of the total number of items selected in a table.
109
+ * This number is used to derive the selection message
110
+ */
90
111
  totalSelected: PropTypes.number.isRequired,
112
+ /**
113
+ * Translates component strings using your i18n tool.
114
+ */
91
115
  translateWithId: PropTypes.func
92
116
  };
93
117
  //#endregion
@@ -22,6 +22,9 @@ const TableBody = ({ children, className, ...rest }) => /* @__PURE__ */ jsx("tbo
22
22
  children
23
23
  });
24
24
  TableBody.propTypes = {
25
+ /**
26
+ * `polite` Adjust the notification behavior of screen readers
27
+ */
25
28
  "aria-live": PropTypes.oneOf([
26
29
  "polite",
27
30
  "assertive",
@@ -6,8 +6,8 @@
6
6
  */
7
7
 
8
8
  import { usePrefix } from "../../internal/usePrefix.js";
9
- import { forwardRef } from "react";
10
9
  import classNames from "classnames";
10
+ import { forwardRef } from "react";
11
11
  import PropTypes from "prop-types";
12
12
  import { jsx } from "react/jsx-runtime";
13
13
  //#region src/components/DataTable/TableCell.tsx
@@ -30,10 +30,25 @@ const TableCell = forwardRef((props, ref) => {
30
30
  });
31
31
  TableCell.displayName = "TableCell";
32
32
  TableCell.propTypes = {
33
+ /**
34
+ * Pass in children that will be embedded in the table header label
35
+ */
33
36
  children: PropTypes.node,
37
+ /**
38
+ * Specify an optional className to be applied to the container node
39
+ */
34
40
  className: PropTypes.string,
41
+ /**
42
+ * The width of the expanded row's internal cell
43
+ */
35
44
  colSpan: PropTypes.number,
45
+ /**
46
+ * Specify if the table cell is in an AI column
47
+ */
36
48
  hasAILabelHeader: PropTypes.bool,
49
+ /**
50
+ * The id of the matching th node in the table head. Addresses a11y concerns outlined here: https://www.ibm.com/able/guidelines/ci162/info_and_relationships.html and https://www.w3.org/TR/WCAG20-TECHS/H43
51
+ */
37
52
  headers: PropTypes.string
38
53
  };
39
54
  //#endregion
@@ -9,8 +9,8 @@ import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import { useId } from "../../internal/useId.js";
10
10
  import { TableContext } from "./TableContext.js";
11
11
  import { Heading, Section } from "../Heading/index.js";
12
- import { useMemo } from "react";
13
12
  import classNames from "classnames";
13
+ import { useMemo } from "react";
14
14
  import PropTypes from "prop-types";
15
15
  import { jsx, jsxs } from "react/jsx-runtime";
16
16
  //#region src/components/DataTable/TableContainer.tsx
@@ -71,13 +71,31 @@ const TableContainer = ({ aiEnabled, className, children, decorator, title, desc
71
71
  });
72
72
  };
73
73
  TableContainer.propTypes = {
74
+ /**
75
+ * Specify if the entire table has AI generated contents
76
+ */
74
77
  aiEnabled: PropTypes.bool,
75
78
  children: PropTypes.node,
76
79
  className: PropTypes.string,
80
+ /**
81
+ * **Experimental**: Provide a `decorator` component to be rendered inside the `TableContainer` component
82
+ */
77
83
  decorator: PropTypes.node,
84
+ /**
85
+ * Optional description text for the Table
86
+ */
78
87
  description: PropTypes.node,
88
+ /**
89
+ * Specify whether the table should have a sticky header
90
+ */
79
91
  stickyHeader: PropTypes.bool,
92
+ /**
93
+ * Provide a title for the Table
94
+ */
80
95
  title: PropTypes.node,
96
+ /**
97
+ * If true, will use a width of 'fit-content' to match the inner table width
98
+ */
81
99
  useStaticWidth: PropTypes.bool
82
100
  };
83
101
  //#endregion
@@ -8,8 +8,8 @@
8
8
  import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import { isComponentElement } from "../../internal/utils.js";
10
10
  import { AILabel } from "../AILabel/index.js";
11
- import { cloneElement } from "react";
12
11
  import classNames from "classnames";
12
+ import { cloneElement } from "react";
13
13
  import PropTypes from "prop-types";
14
14
  import { jsx } from "react/jsx-runtime";
15
15
  //#region src/components/DataTable/TableDecoratorRow.tsx
@@ -32,7 +32,13 @@ const TableDecoratorRow = ({ className, decorator }) => {
32
32
  };
33
33
  TableDecoratorRow.displayName = "TableDecoratorRow";
34
34
  TableDecoratorRow.propTypes = {
35
+ /**
36
+ * The CSS class names of the cell that wraps the underlying input control
37
+ */
35
38
  className: PropTypes.string,
39
+ /**
40
+ * **Experimental**: Provide a `decorator` component to be rendered inside the `TableDecoratorRow` component
41
+ */
36
42
  decorator: PropTypes.node
37
43
  };
38
44
  //#endregion
@@ -8,8 +8,8 @@
8
8
  import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import { deprecate } from "../../prop-types/deprecate.js";
10
10
  import { requiredIfGivenPropIsTruthy } from "../../prop-types/requiredIfGivenPropIsTruthy.js";
11
- import "react";
12
11
  import classNames from "classnames";
12
+ import "react";
13
13
  import PropTypes from "prop-types";
14
14
  import { jsx, jsxs } from "react/jsx-runtime";
15
15
  import { ChevronRight } from "@carbon/icons-react";
@@ -44,16 +44,47 @@ const TableExpandHeader = ({ ["aria-controls"]: ariaControls, ["aria-label"]: ar
44
44
  });
45
45
  };
46
46
  TableExpandHeader.propTypes = {
47
+ /**
48
+ * Space separated list of one or more ID values referencing the TableExpandedRow(s) being controlled by the TableExpandHeader
49
+ */
47
50
  ["aria-controls"]: PropTypes.string,
51
+ /**
52
+ * Specify the string read by a voice reader when the expand trigger is
53
+ * focused
54
+ */
48
55
  ["aria-label"]: PropTypes.string,
56
+ /**
57
+ * Deprecated, please use `aria-label` instead.
58
+ * Specify the string read by a voice reader when the expand trigger is
59
+ * focused
60
+ */
49
61
  ariaLabel: PropTypes.string,
50
62
  children: PropTypes.node,
51
63
  className: PropTypes.string,
64
+ /**
65
+ * The enableExpando prop is being replaced by TableExpandHeader
66
+ */
52
67
  enableExpando: deprecate(PropTypes.bool, "The `enableExpando` prop has been deprecated in favor of `enableToggle`. This prop will be removed in the next major release."),
68
+ /**
69
+ * Specify whether an expand all button should be displayed
70
+ */
53
71
  enableToggle: PropTypes.bool,
72
+ /**
73
+ * The description of the chevron right icon, to be put in its SVG `<title>` element.
74
+ */
54
75
  expandIconDescription: PropTypes.string,
76
+ /**
77
+ * Supply an id to the th element.
78
+ */
55
79
  id: PropTypes.string,
80
+ /**
81
+ * Specify whether this row is expanded or not. This helps coordinate data
82
+ * attributes so that `TableExpandRow` and `TableExpandedRow` work together
83
+ */
56
84
  isExpanded: requiredIfGivenPropIsTruthy("enableToggle", PropTypes.bool),
85
+ /**
86
+ * Hook for when a listener initiates a request to expand the given row
87
+ */
57
88
  onExpand: PropTypes.oneOfType([requiredIfGivenPropIsTruthy("enableExpando", PropTypes.func), requiredIfGivenPropIsTruthy("enableToggle", PropTypes.func)])
58
89
  };
59
90
  //#endregion
@@ -11,8 +11,8 @@ import { AILabel } from "../AILabel/index.js";
11
11
  import TableCell from "./TableCell.js";
12
12
  import TableDecoratorRow from "./TableDecoratorRow.js";
13
13
  import TableSlugRow from "./TableSlugRow.js";
14
- import { Children, forwardRef } from "react";
15
14
  import classNames from "classnames";
15
+ import { Children, forwardRef } from "react";
16
16
  import PropTypes from "prop-types";
17
17
  import { jsx, jsxs } from "react/jsx-runtime";
18
18
  import { ChevronRight } from "@carbon/icons-react";
@@ -75,15 +75,44 @@ const TableExpandRow = forwardRef(({ ["aria-controls"]: ariaControls, ["aria-lab
75
75
  });
76
76
  });
77
77
  TableExpandRow.propTypes = {
78
+ /**
79
+ * Space separated list of one or more ID values referencing the TableExpandedRow(s) being controlled by the TableExpandRow
80
+ * TODO: make this required in v12
81
+ */
78
82
  "aria-controls": PropTypes.string,
83
+ /**
84
+ * Specify the string read by a voice reader when the expand trigger is
85
+ * focused
86
+ */
79
87
  "aria-label": PropTypes.string,
88
+ /**
89
+ * Deprecated, please use `aria-label` instead.
90
+ * Specify the string read by a voice reader when the expand trigger is
91
+ * focused
92
+ */
80
93
  ariaLabel: PropTypes.string,
81
94
  children: PropTypes.node,
82
95
  className: PropTypes.string,
96
+ /**
97
+ * The id of the matching th node in the table head. Addresses a11y concerns outlined here: https://www.ibm.com/able/guidelines/ci162/info_and_relationships.html and https://www.w3.org/TR/WCAG20-TECHS/H43
98
+ */
83
99
  expandHeader: PropTypes.string,
100
+ /**
101
+ * The description of the chevron right icon, to be put in its SVG `<title>` element.
102
+ */
84
103
  expandIconDescription: PropTypes.string,
104
+ /**
105
+ * Specify whether this row is expanded or not. This helps coordinate data
106
+ * attributes so that `TableExpandRow` and `TableExpandedRow` work together
107
+ */
85
108
  isExpanded: PropTypes.bool,
109
+ /**
110
+ * Specify if the row is selected
111
+ */
86
112
  isSelected: PropTypes.bool,
113
+ /**
114
+ * Hook for when a listener initiates a request to expand the given row
115
+ */
87
116
  onExpand: PropTypes.func.isRequired
88
117
  };
89
118
  TableExpandRow.displayName = "TableExpandRow";
@@ -7,8 +7,8 @@
7
7
 
8
8
  import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import TableCell from "./TableCell.js";
10
- import { useRef } from "react";
11
10
  import classNames from "classnames";
11
+ import { useRef } from "react";
12
12
  import PropTypes from "prop-types";
13
13
  import { jsx } from "react/jsx-runtime";
14
14
  //#region src/components/DataTable/TableExpandedRow.tsx
@@ -46,8 +46,17 @@ const TableExpandedRow = ({ className: customClassName, children, colSpan, ...re
46
46
  });
47
47
  };
48
48
  TableExpandedRow.propTypes = {
49
+ /**
50
+ * Pass in the contents for your TableExpandedRow
51
+ */
49
52
  children: PropTypes.node,
53
+ /**
54
+ * Specify an optional className to be applied to the container node
55
+ */
50
56
  className: PropTypes.string,
57
+ /**
58
+ * The width of the expanded row's internal cell
59
+ */
51
60
  colSpan: PropTypes.number.isRequired
52
61
  };
53
62
  //#endregion
@@ -10,8 +10,8 @@ import { useId } from "../../internal/useId.js";
10
10
  import { isComponentElement } from "../../internal/utils.js";
11
11
  import { AILabel } from "../AILabel/index.js";
12
12
  import { sortStates } from "./state/sortStates.js";
13
- import { cloneElement, forwardRef, useRef } from "react";
14
13
  import classNames from "classnames";
14
+ import { cloneElement, forwardRef, useRef } from "react";
15
15
  import PropTypes from "prop-types";
16
16
  import { jsx, jsxs } from "react/jsx-runtime";
17
17
  import { ArrowUp, ArrowsVertical } from "@carbon/icons-react";
@@ -135,15 +135,50 @@ const TableHeader = forwardRef((props, ref) => {
135
135
  });
136
136
  });
137
137
  TableHeader.propTypes = {
138
+ /**
139
+ * Pass in children that will be embedded in the table header label
140
+ */
138
141
  children: PropTypes.node,
142
+ /**
143
+ * Specify an optional className to be applied to the container node
144
+ */
139
145
  className: PropTypes.string,
146
+ /**
147
+ * Specify `colSpan` as a non-negative integer value to indicate how
148
+ * many columns the TableHeader cell extends in a table
149
+ */
140
150
  colSpan: PropTypes.number,
151
+ /**
152
+ * Supply an id to the th element.
153
+ */
141
154
  id: PropTypes.string,
155
+ /**
156
+ * Specify whether this header is the header by which a table is being sorted
157
+ * by
158
+ */
142
159
  isSortHeader: PropTypes.bool,
160
+ /**
161
+ * Specify whether this header is one through which a user can sort the table
162
+ */
143
163
  isSortable: PropTypes.bool,
164
+ /**
165
+ * Hook that is invoked when the header is clicked
166
+ */
144
167
  onClick: PropTypes.func,
168
+ /**
169
+ * Specify the scope of this table header. You can find more info about this
170
+ * attribute at the following URL:
171
+ * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/th#attr-scope
172
+ */
145
173
  scope: PropTypes.string,
174
+ /**
175
+ * Specify which direction we are currently sorting by, should be one of DESC,
176
+ * NONE, or ASC.
177
+ */
146
178
  sortDirection: PropTypes.oneOf(Object.values(sortStates)),
179
+ /**
180
+ * Translates component strings using your i18n tool.
181
+ */
147
182
  translateWithId: PropTypes.func
148
183
  };
149
184
  TableHeader.displayName = "TableHeader";
@@ -10,8 +10,8 @@ import { isComponentElement } from "../../internal/utils.js";
10
10
  import { AILabel } from "../AILabel/index.js";
11
11
  import TableDecoratorRow from "./TableDecoratorRow.js";
12
12
  import TableSlugRow from "./TableSlugRow.js";
13
- import { Children, forwardRef } from "react";
14
13
  import classNames from "classnames";
14
+ import { Children, forwardRef } from "react";
15
15
  import PropTypes from "prop-types";
16
16
  import { jsx } from "react/jsx-runtime";
17
17
  //#region src/components/DataTable/TableRow.tsx
@@ -39,12 +39,33 @@ const TableRow = forwardRef((props, ref) => {
39
39
  });
40
40
  });
41
41
  TableRow.propTypes = {
42
+ /**
43
+ * Specify an optional className to be applied to the container node
44
+ */
42
45
  className: PropTypes.string,
46
+ /**
47
+ * Specify if the row is selected
48
+ */
43
49
  isSelected: PropTypes.bool,
50
+ /**
51
+ * Non-standard alias for `aria-label`.
52
+ */
44
53
  ariaLabel: PropTypes.string,
54
+ /**
55
+ * Accessible label for the row element.
56
+ */
45
57
  "aria-label": PropTypes.string,
58
+ /**
59
+ * Associates this row with the id of the corresponding expanded row content.
60
+ */
46
61
  "aria-controls": PropTypes.string,
62
+ /**
63
+ * Handler called when the row’s expand toggle is clicked.
64
+ */
47
65
  onExpand: PropTypes.func,
66
+ /**
67
+ * Flag indicating whether the row is currently expanded.
68
+ */
48
69
  isExpanded: PropTypes.bool
49
70
  };
50
71
  //#endregion
@@ -8,8 +8,8 @@
8
8
  import { usePrefix } from "../../internal/usePrefix.js";
9
9
  import { deprecate } from "../../prop-types/deprecate.js";
10
10
  import InlineCheckbox_default from "../InlineCheckbox/index.js";
11
- import "react";
12
11
  import classNames from "classnames";
12
+ import "react";
13
13
  import PropTypes from "prop-types";
14
14
  import { jsx } from "react/jsx-runtime";
15
15
  //#region src/components/DataTable/TableSelectAll.tsx
@@ -36,14 +36,42 @@ const TableSelectAll = ({ ariaLabel: deprecatedAriaLabel = "Select all rows in t
36
36
  });
37
37
  };
38
38
  TableSelectAll.propTypes = {
39
+ /**
40
+ * Specify the aria label for the underlying input control
41
+ */
39
42
  ["aria-label"]: PropTypes.string,
43
+ /**
44
+ * Deprecated, please use `aria-label` instead.
45
+ * Specify the aria label for the underlying input control
46
+ */
40
47
  ariaLabel: deprecate(PropTypes.string, "This prop syntax has been deprecated. Please use the new `aria-label`."),
48
+ /**
49
+ * Specify whether all items are selected, or not
50
+ */
41
51
  checked: PropTypes.bool,
52
+ /**
53
+ * The CSS class names of the cell that wraps the underlying input control
54
+ */
42
55
  className: PropTypes.string,
56
+ /**
57
+ * Specify whether the checkbox input should be disabled
58
+ */
43
59
  disabled: PropTypes.bool,
60
+ /**
61
+ * Provide an `id` for the underlying input control
62
+ */
44
63
  id: PropTypes.string.isRequired,
64
+ /**
65
+ * Specify whether the selection only has a subset of all items
66
+ */
45
67
  indeterminate: PropTypes.bool,
68
+ /**
69
+ * Provide a `name` for the underlying input control
70
+ */
46
71
  name: PropTypes.string.isRequired,
72
+ /**
73
+ * Provide a handler to listen to when a user initiates a selection request
74
+ */
47
75
  onSelect: PropTypes.func.isRequired
48
76
  };
49
77
  //#endregion