@itwin/itwinui-react 3.17.3 → 3.18.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 (641) hide show
  1. package/CHANGELOG.md +72 -0
  2. package/DEV-cjs/core/Alert/Alert.js +12 -6
  3. package/DEV-cjs/core/Avatar/Avatar.js +1 -1
  4. package/DEV-cjs/core/AvatarGroup/AvatarGroup.js +2 -1
  5. package/DEV-cjs/core/Backdrop/Backdrop.js +1 -1
  6. package/DEV-cjs/core/Badge/Badge.js +1 -1
  7. package/DEV-cjs/core/Breadcrumbs/Breadcrumbs.js +8 -5
  8. package/DEV-cjs/core/ButtonGroup/ButtonGroup.js +4 -2
  9. package/DEV-cjs/core/Buttons/Button.js +1 -1
  10. package/DEV-cjs/core/Buttons/DropdownButton.js +2 -1
  11. package/DEV-cjs/core/Buttons/IconButton.js +8 -2
  12. package/DEV-cjs/core/Buttons/IdeasButton.js +2 -1
  13. package/DEV-cjs/core/Buttons/SplitButton.js +2 -1
  14. package/DEV-cjs/core/Carousel/Carousel.js +2 -1
  15. package/DEV-cjs/core/Carousel/CarouselContext.js +2 -1
  16. package/DEV-cjs/core/Carousel/CarouselDot.js +2 -1
  17. package/DEV-cjs/core/Carousel/CarouselDotsList.js +2 -1
  18. package/DEV-cjs/core/Carousel/CarouselNavigation.js +6 -3
  19. package/DEV-cjs/core/Carousel/CarouselSlide.js +2 -1
  20. package/DEV-cjs/core/Carousel/CarouselSlider.js +2 -1
  21. package/DEV-cjs/core/Checkbox/Checkbox.js +1 -1
  22. package/DEV-cjs/core/ColorPicker/ColorBuilder.js +2 -1
  23. package/DEV-cjs/core/ColorPicker/ColorInputPanel.js +4 -2
  24. package/DEV-cjs/core/ColorPicker/ColorPalette.js +2 -1
  25. package/DEV-cjs/core/ColorPicker/ColorPicker.js +2 -1
  26. package/DEV-cjs/core/ColorPicker/ColorSwatch.js +2 -1
  27. package/DEV-cjs/core/ComboBox/ComboBox.js +75 -47
  28. package/DEV-cjs/core/ComboBox/ComboBoxEndIcon.js +2 -1
  29. package/DEV-cjs/core/ComboBox/ComboBoxInput.js +2 -3
  30. package/DEV-cjs/core/ComboBox/ComboBoxInputContainer.js +2 -1
  31. package/DEV-cjs/core/ComboBox/ComboBoxMenu.js +8 -3
  32. package/DEV-cjs/core/ComboBox/ComboBoxMenuItem.js +3 -2
  33. package/DEV-cjs/core/ComboBox/ComboBoxMultipleContainer.js +2 -1
  34. package/DEV-cjs/core/ComboBox/helpers.js +4 -2
  35. package/DEV-cjs/core/DatePicker/DatePicker.js +5 -4
  36. package/DEV-cjs/core/Dialog/Dialog.js +23 -11
  37. package/DEV-cjs/core/Dialog/DialogBackdrop.js +2 -1
  38. package/DEV-cjs/core/Dialog/DialogButtonBar.js +2 -1
  39. package/DEV-cjs/core/Dialog/DialogContent.js +2 -1
  40. package/DEV-cjs/core/Dialog/DialogMain.js +2 -1
  41. package/DEV-cjs/core/Dialog/DialogTitleBar.js +2 -1
  42. package/DEV-cjs/core/Dialog/DialogTitleBarTitle.js +2 -1
  43. package/DEV-cjs/core/Divider/Divider.js +1 -1
  44. package/DEV-cjs/core/DropdownMenu/DropdownMenu.js +32 -24
  45. package/DEV-cjs/core/ExpandableBlock/ExpandableBlock.js +38 -13
  46. package/DEV-cjs/core/Fieldset/Fieldset.js +1 -1
  47. package/DEV-cjs/core/FileUpload/FileEmptyCard.js +6 -3
  48. package/DEV-cjs/core/FileUpload/FileUpload.js +2 -1
  49. package/DEV-cjs/core/FileUpload/FileUploadCard.js +18 -9
  50. package/DEV-cjs/core/FileUpload/FileUploadTemplate.js +2 -1
  51. package/DEV-cjs/core/Flex/Flex.js +4 -3
  52. package/DEV-cjs/core/Footer/Footer.js +1 -1
  53. package/DEV-cjs/core/Footer/FooterItem.js +2 -1
  54. package/DEV-cjs/core/Footer/FooterList.js +2 -1
  55. package/DEV-cjs/core/Footer/FooterSeparator.js +2 -1
  56. package/DEV-cjs/core/Header/Header.js +1 -1
  57. package/DEV-cjs/core/Header/HeaderBreadcrumbs.js +2 -1
  58. package/DEV-cjs/core/Header/HeaderButton.js +2 -1
  59. package/DEV-cjs/core/Header/HeaderLogo.js +3 -2
  60. package/DEV-cjs/core/Icon/Icon.js +1 -1
  61. package/DEV-cjs/core/InformationPanel/InformationPanel.js +2 -1
  62. package/DEV-cjs/core/InformationPanel/InformationPanelBody.js +2 -1
  63. package/DEV-cjs/core/InformationPanel/InformationPanelContent.js +2 -1
  64. package/DEV-cjs/core/InformationPanel/InformationPanelHeader.js +2 -1
  65. package/DEV-cjs/core/InformationPanel/InformationPanelWrapper.js +2 -1
  66. package/DEV-cjs/core/Input/Input.js +1 -1
  67. package/DEV-cjs/core/InputGrid/InputGrid.js +1 -1
  68. package/DEV-cjs/core/InputGroup/InputGroup.js +2 -1
  69. package/DEV-cjs/core/InputWithDecorations/InputWithDecorations.js +10 -5
  70. package/DEV-cjs/core/Label/Label.js +1 -1
  71. package/DEV-cjs/core/LabeledInput/LabeledInput.js +2 -1
  72. package/DEV-cjs/core/LabeledSelect/LabeledSelect.js +5 -2
  73. package/DEV-cjs/core/LabeledTextarea/LabeledTextarea.js +2 -1
  74. package/DEV-cjs/core/LinkAction/LinkAction.js +4 -3
  75. package/DEV-cjs/core/List/List.js +1 -1
  76. package/DEV-cjs/core/List/ListItem.js +10 -5
  77. package/DEV-cjs/core/Menu/Menu.js +3 -1
  78. package/DEV-cjs/core/Menu/MenuDivider.js +2 -1
  79. package/DEV-cjs/core/Menu/MenuExtraContent.js +3 -4
  80. package/DEV-cjs/core/Menu/MenuItem.js +7 -3
  81. package/DEV-cjs/core/Menu/MenuItemSkeleton.js +2 -1
  82. package/DEV-cjs/core/Modal/Modal.js +1 -1
  83. package/DEV-cjs/core/Modal/ModalButtonBar.js +2 -1
  84. package/DEV-cjs/core/Modal/ModalContent.js +2 -1
  85. package/DEV-cjs/core/NonIdealState/ErrorPage.js +1 -1
  86. package/DEV-cjs/core/NonIdealState/NonIdealState.js +2 -1
  87. package/DEV-cjs/core/NotificationMarker/NotificationMarker.js +2 -1
  88. package/DEV-cjs/core/Overlay/Overlay.js +8 -4
  89. package/DEV-cjs/core/Panels/Panels.js +13 -7
  90. package/DEV-cjs/core/Panels/helpers.js +2 -1
  91. package/DEV-cjs/core/Popover/Popover.js +35 -28
  92. package/DEV-cjs/core/ProgressIndicators/ProgressLinear.js +2 -1
  93. package/DEV-cjs/core/ProgressIndicators/ProgressRadial.js +2 -1
  94. package/DEV-cjs/core/Radio/Radio.js +1 -1
  95. package/DEV-cjs/core/RadioTiles/RadioTile.js +1 -1
  96. package/DEV-cjs/core/RadioTiles/RadioTileGroup.js +2 -1
  97. package/DEV-cjs/core/SearchBox/SearchBox.js +15 -8
  98. package/DEV-cjs/core/Select/Select.js +61 -48
  99. package/DEV-cjs/core/Select/SelectTag.js +1 -0
  100. package/DEV-cjs/core/SideNavigation/SideNavigation.js +3 -2
  101. package/DEV-cjs/core/SideNavigation/SidenavButton.js +2 -1
  102. package/DEV-cjs/core/SideNavigation/SidenavSubmenu.js +2 -1
  103. package/DEV-cjs/core/SideNavigation/SidenavSubmenuHeader.js +2 -1
  104. package/DEV-cjs/core/SkipToContentLink/SkipToContentLink.js +2 -1
  105. package/DEV-cjs/core/Slider/Slider.js +1 -1
  106. package/DEV-cjs/core/StatusMessage/StatusMessage.js +2 -1
  107. package/DEV-cjs/core/Stepper/Stepper.js +1 -1
  108. package/DEV-cjs/core/Stepper/WorkflowDiagram.js +2 -1
  109. package/DEV-cjs/core/Surface/Surface.js +7 -4
  110. package/DEV-cjs/core/Table/ColumnHeader.js +17 -17
  111. package/DEV-cjs/core/Table/Table.js +147 -57
  112. package/DEV-cjs/core/Table/TableCell.js +6 -4
  113. package/DEV-cjs/core/Table/actionHandlers/expandHandler.js +2 -4
  114. package/DEV-cjs/core/Table/actionHandlers/selectHandler.js +1 -4
  115. package/DEV-cjs/core/Table/cells/DefaultCell.js +31 -15
  116. package/DEV-cjs/core/Table/cells/EditableCell.js +2 -1
  117. package/DEV-cjs/core/Table/columns/expanderColumn.js +16 -17
  118. package/DEV-cjs/core/Table/columns/selectionColumn.js +4 -2
  119. package/DEV-cjs/core/Tabs/Tabs.js +89 -29
  120. package/DEV-cjs/core/Tag/Tag.js +1 -1
  121. package/DEV-cjs/core/Tag/TagContainer.js +2 -1
  122. package/DEV-cjs/core/Textarea/Textarea.js +1 -1
  123. package/DEV-cjs/core/ThemeProvider/ThemeProvider.js +34 -22
  124. package/DEV-cjs/core/Tile/Tile.js +56 -44
  125. package/DEV-cjs/core/TimePicker/TimePicker.js +2 -1
  126. package/DEV-cjs/core/Toast/Toaster.js +4 -2
  127. package/DEV-cjs/core/ToggleSwitch/ToggleSwitch.js +2 -1
  128. package/DEV-cjs/core/Tooltip/Tooltip.js +1 -1
  129. package/DEV-cjs/core/TransferList/TransferList.js +15 -11
  130. package/DEV-cjs/core/Tree/Tree.js +26 -18
  131. package/DEV-cjs/core/Tree/TreeNode.js +1 -1
  132. package/DEV-cjs/core/Tree/TreeNodeExpander.js +2 -1
  133. package/DEV-cjs/core/Typography/Anchor.js +1 -1
  134. package/DEV-cjs/core/Typography/Blockquote.js +2 -1
  135. package/DEV-cjs/core/Typography/Code.js +1 -1
  136. package/DEV-cjs/core/Typography/Kbd.js +1 -1
  137. package/DEV-cjs/core/Typography/Text.js +1 -1
  138. package/DEV-cjs/core/VisuallyHidden/VisuallyHidden.js +2 -1
  139. package/DEV-cjs/index.js +3 -0
  140. package/DEV-cjs/styles.js +1 -1
  141. package/DEV-cjs/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
  142. package/DEV-cjs/utils/components/ButtonBase.js +2 -1
  143. package/DEV-cjs/utils/components/InputWithIcon.js +2 -1
  144. package/DEV-cjs/utils/components/LineClamp.js +6 -0
  145. package/DEV-cjs/utils/components/MiddleTextTruncation.js +2 -1
  146. package/DEV-cjs/utils/components/OverflowContainer.js +6 -9
  147. package/DEV-cjs/utils/components/Portal.js +4 -8
  148. package/DEV-cjs/utils/components/ShadowRoot.js +10 -8
  149. package/DEV-cjs/utils/functions/polymorphic.js +2 -1
  150. package/DEV-cjs/utils/hooks/useGlobals.js +11 -2
  151. package/DEV-cjs/utils/hooks/useWarningLogger.js +29 -28
  152. package/DEV-cjs/utils/providers/index.js +0 -1
  153. package/DEV-esm/core/Alert/Alert.js +12 -6
  154. package/DEV-esm/core/Avatar/Avatar.js +1 -1
  155. package/DEV-esm/core/AvatarGroup/AvatarGroup.js +2 -1
  156. package/DEV-esm/core/Backdrop/Backdrop.js +1 -1
  157. package/DEV-esm/core/Badge/Badge.js +1 -1
  158. package/DEV-esm/core/Breadcrumbs/Breadcrumbs.js +8 -5
  159. package/DEV-esm/core/ButtonGroup/ButtonGroup.js +4 -2
  160. package/DEV-esm/core/Buttons/Button.js +1 -1
  161. package/DEV-esm/core/Buttons/DropdownButton.js +2 -1
  162. package/DEV-esm/core/Buttons/IconButton.js +8 -2
  163. package/DEV-esm/core/Buttons/IdeasButton.js +2 -1
  164. package/DEV-esm/core/Buttons/SplitButton.js +2 -1
  165. package/DEV-esm/core/Carousel/Carousel.js +2 -1
  166. package/DEV-esm/core/Carousel/CarouselContext.js +2 -1
  167. package/DEV-esm/core/Carousel/CarouselDot.js +2 -1
  168. package/DEV-esm/core/Carousel/CarouselDotsList.js +2 -1
  169. package/DEV-esm/core/Carousel/CarouselNavigation.js +6 -3
  170. package/DEV-esm/core/Carousel/CarouselSlide.js +2 -1
  171. package/DEV-esm/core/Carousel/CarouselSlider.js +2 -1
  172. package/DEV-esm/core/Checkbox/Checkbox.js +1 -1
  173. package/DEV-esm/core/ColorPicker/ColorBuilder.js +2 -1
  174. package/DEV-esm/core/ColorPicker/ColorInputPanel.js +4 -2
  175. package/DEV-esm/core/ColorPicker/ColorPalette.js +2 -1
  176. package/DEV-esm/core/ColorPicker/ColorPicker.js +2 -1
  177. package/DEV-esm/core/ColorPicker/ColorSwatch.js +2 -1
  178. package/DEV-esm/core/ComboBox/ComboBox.js +75 -47
  179. package/DEV-esm/core/ComboBox/ComboBoxEndIcon.js +2 -1
  180. package/DEV-esm/core/ComboBox/ComboBoxInput.js +2 -3
  181. package/DEV-esm/core/ComboBox/ComboBoxInputContainer.js +2 -1
  182. package/DEV-esm/core/ComboBox/ComboBoxMenu.js +8 -3
  183. package/DEV-esm/core/ComboBox/ComboBoxMenuItem.js +3 -2
  184. package/DEV-esm/core/ComboBox/ComboBoxMultipleContainer.js +2 -1
  185. package/DEV-esm/core/ComboBox/helpers.js +4 -2
  186. package/DEV-esm/core/DatePicker/DatePicker.js +5 -4
  187. package/DEV-esm/core/Dialog/Dialog.js +22 -9
  188. package/DEV-esm/core/Dialog/DialogBackdrop.js +2 -1
  189. package/DEV-esm/core/Dialog/DialogButtonBar.js +2 -1
  190. package/DEV-esm/core/Dialog/DialogContent.js +2 -1
  191. package/DEV-esm/core/Dialog/DialogMain.js +2 -1
  192. package/DEV-esm/core/Dialog/DialogTitleBar.js +2 -1
  193. package/DEV-esm/core/Dialog/DialogTitleBarTitle.js +2 -1
  194. package/DEV-esm/core/Divider/Divider.js +1 -1
  195. package/DEV-esm/core/DropdownMenu/DropdownMenu.js +32 -24
  196. package/DEV-esm/core/ExpandableBlock/ExpandableBlock.js +107 -91
  197. package/DEV-esm/core/Fieldset/Fieldset.js +1 -1
  198. package/DEV-esm/core/FileUpload/FileEmptyCard.js +6 -3
  199. package/DEV-esm/core/FileUpload/FileUpload.js +2 -1
  200. package/DEV-esm/core/FileUpload/FileUploadCard.js +18 -9
  201. package/DEV-esm/core/FileUpload/FileUploadTemplate.js +2 -1
  202. package/DEV-esm/core/Flex/Flex.js +4 -3
  203. package/DEV-esm/core/Footer/Footer.js +1 -1
  204. package/DEV-esm/core/Footer/FooterItem.js +2 -1
  205. package/DEV-esm/core/Footer/FooterList.js +2 -1
  206. package/DEV-esm/core/Footer/FooterSeparator.js +2 -1
  207. package/DEV-esm/core/Header/Header.js +1 -1
  208. package/DEV-esm/core/Header/HeaderBreadcrumbs.js +2 -1
  209. package/DEV-esm/core/Header/HeaderButton.js +2 -1
  210. package/DEV-esm/core/Header/HeaderLogo.js +3 -2
  211. package/DEV-esm/core/Icon/Icon.js +1 -1
  212. package/DEV-esm/core/InformationPanel/InformationPanel.js +2 -1
  213. package/DEV-esm/core/InformationPanel/InformationPanelBody.js +2 -1
  214. package/DEV-esm/core/InformationPanel/InformationPanelContent.js +2 -1
  215. package/DEV-esm/core/InformationPanel/InformationPanelHeader.js +2 -1
  216. package/DEV-esm/core/InformationPanel/InformationPanelWrapper.js +2 -1
  217. package/DEV-esm/core/Input/Input.js +1 -1
  218. package/DEV-esm/core/InputGrid/InputGrid.js +1 -1
  219. package/DEV-esm/core/InputGroup/InputGroup.js +2 -1
  220. package/DEV-esm/core/InputWithDecorations/InputWithDecorations.js +10 -5
  221. package/DEV-esm/core/Label/Label.js +1 -1
  222. package/DEV-esm/core/LabeledInput/LabeledInput.js +2 -1
  223. package/DEV-esm/core/LabeledSelect/LabeledSelect.js +5 -2
  224. package/DEV-esm/core/LabeledTextarea/LabeledTextarea.js +2 -1
  225. package/DEV-esm/core/LinkAction/LinkAction.js +4 -3
  226. package/DEV-esm/core/List/List.js +1 -1
  227. package/DEV-esm/core/List/ListItem.js +10 -5
  228. package/DEV-esm/core/Menu/Menu.js +4 -1
  229. package/DEV-esm/core/Menu/MenuDivider.js +2 -1
  230. package/DEV-esm/core/Menu/MenuExtraContent.js +3 -4
  231. package/DEV-esm/core/Menu/MenuItem.js +7 -3
  232. package/DEV-esm/core/Menu/MenuItemSkeleton.js +2 -1
  233. package/DEV-esm/core/Modal/Modal.js +1 -1
  234. package/DEV-esm/core/Modal/ModalButtonBar.js +2 -1
  235. package/DEV-esm/core/Modal/ModalContent.js +2 -1
  236. package/DEV-esm/core/NonIdealState/ErrorPage.js +1 -1
  237. package/DEV-esm/core/NonIdealState/NonIdealState.js +2 -1
  238. package/DEV-esm/core/NotificationMarker/NotificationMarker.js +2 -1
  239. package/DEV-esm/core/Overlay/Overlay.js +8 -4
  240. package/DEV-esm/core/Panels/Panels.js +13 -7
  241. package/DEV-esm/core/Panels/helpers.js +2 -1
  242. package/DEV-esm/core/Popover/Popover.js +39 -29
  243. package/DEV-esm/core/ProgressIndicators/ProgressLinear.js +2 -1
  244. package/DEV-esm/core/ProgressIndicators/ProgressRadial.js +2 -1
  245. package/DEV-esm/core/Radio/Radio.js +1 -1
  246. package/DEV-esm/core/RadioTiles/RadioTile.js +1 -1
  247. package/DEV-esm/core/RadioTiles/RadioTileGroup.js +2 -1
  248. package/DEV-esm/core/SearchBox/SearchBox.js +15 -8
  249. package/DEV-esm/core/Select/Select.js +61 -48
  250. package/DEV-esm/core/Select/SelectTag.js +1 -0
  251. package/DEV-esm/core/SideNavigation/SideNavigation.js +3 -2
  252. package/DEV-esm/core/SideNavigation/SidenavButton.js +2 -1
  253. package/DEV-esm/core/SideNavigation/SidenavSubmenu.js +2 -1
  254. package/DEV-esm/core/SideNavigation/SidenavSubmenuHeader.js +2 -1
  255. package/DEV-esm/core/SkipToContentLink/SkipToContentLink.js +2 -1
  256. package/DEV-esm/core/Slider/Slider.js +1 -1
  257. package/DEV-esm/core/StatusMessage/StatusMessage.js +2 -1
  258. package/DEV-esm/core/Stepper/Stepper.js +1 -1
  259. package/DEV-esm/core/Stepper/WorkflowDiagram.js +2 -1
  260. package/DEV-esm/core/Surface/Surface.js +7 -4
  261. package/DEV-esm/core/Table/ColumnHeader.js +17 -17
  262. package/DEV-esm/core/Table/Table.js +144 -57
  263. package/DEV-esm/core/Table/TableCell.js +6 -4
  264. package/DEV-esm/core/Table/actionHandlers/expandHandler.js +2 -4
  265. package/DEV-esm/core/Table/actionHandlers/selectHandler.js +1 -4
  266. package/DEV-esm/core/Table/cells/DefaultCell.js +31 -15
  267. package/DEV-esm/core/Table/cells/EditableCell.js +2 -1
  268. package/DEV-esm/core/Table/columns/expanderColumn.js +16 -17
  269. package/DEV-esm/core/Table/columns/selectionColumn.js +4 -2
  270. package/DEV-esm/core/Tabs/Tabs.js +80 -25
  271. package/DEV-esm/core/Tag/Tag.js +1 -1
  272. package/DEV-esm/core/Tag/TagContainer.js +2 -1
  273. package/DEV-esm/core/Textarea/Textarea.js +1 -1
  274. package/DEV-esm/core/ThemeProvider/ThemeProvider.js +34 -21
  275. package/DEV-esm/core/Tile/Tile.js +57 -48
  276. package/DEV-esm/core/TimePicker/TimePicker.js +2 -1
  277. package/DEV-esm/core/Toast/Toaster.js +4 -2
  278. package/DEV-esm/core/ToggleSwitch/ToggleSwitch.js +2 -1
  279. package/DEV-esm/core/Tooltip/Tooltip.js +1 -1
  280. package/DEV-esm/core/TransferList/TransferList.js +15 -11
  281. package/DEV-esm/core/Tree/Tree.js +26 -18
  282. package/DEV-esm/core/Tree/TreeNode.js +1 -1
  283. package/DEV-esm/core/Tree/TreeNodeExpander.js +2 -1
  284. package/DEV-esm/core/Typography/Anchor.js +1 -1
  285. package/DEV-esm/core/Typography/Blockquote.js +2 -1
  286. package/DEV-esm/core/Typography/Code.js +1 -1
  287. package/DEV-esm/core/Typography/Kbd.js +1 -1
  288. package/DEV-esm/core/Typography/Text.js +1 -1
  289. package/DEV-esm/core/VisuallyHidden/VisuallyHidden.js +2 -1
  290. package/DEV-esm/index.js +1 -1
  291. package/DEV-esm/styles.js +1 -1
  292. package/DEV-esm/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
  293. package/DEV-esm/utils/components/ButtonBase.js +2 -1
  294. package/DEV-esm/utils/components/InputWithIcon.js +2 -1
  295. package/DEV-esm/utils/components/LineClamp.js +3 -0
  296. package/DEV-esm/utils/components/MiddleTextTruncation.js +2 -1
  297. package/DEV-esm/utils/components/OverflowContainer.js +6 -9
  298. package/DEV-esm/utils/components/Portal.js +2 -4
  299. package/DEV-esm/utils/components/ShadowRoot.js +10 -8
  300. package/DEV-esm/utils/functions/polymorphic.js +2 -1
  301. package/DEV-esm/utils/hooks/useGlobals.js +11 -2
  302. package/DEV-esm/utils/hooks/useWarningLogger.js +29 -27
  303. package/DEV-esm/utils/providers/index.js +0 -1
  304. package/cjs/core/Alert/Alert.js +12 -0
  305. package/cjs/core/Avatar/Avatar.js +1 -0
  306. package/cjs/core/AvatarGroup/AvatarGroup.js +2 -0
  307. package/cjs/core/Backdrop/Backdrop.js +1 -0
  308. package/cjs/core/Badge/Badge.js +1 -0
  309. package/cjs/core/Breadcrumbs/Breadcrumbs.js +10 -1
  310. package/cjs/core/ButtonGroup/ButtonGroup.js +4 -0
  311. package/cjs/core/Buttons/Button.js +1 -0
  312. package/cjs/core/Buttons/DropdownButton.js +2 -0
  313. package/cjs/core/Buttons/IconButton.js +9 -0
  314. package/cjs/core/Buttons/IdeasButton.js +2 -0
  315. package/cjs/core/Buttons/SplitButton.js +2 -0
  316. package/cjs/core/Carousel/Carousel.js +2 -0
  317. package/cjs/core/Carousel/CarouselContext.js +2 -0
  318. package/cjs/core/Carousel/CarouselDot.js +2 -0
  319. package/cjs/core/Carousel/CarouselDotsList.js +2 -0
  320. package/cjs/core/Carousel/CarouselNavigation.js +6 -0
  321. package/cjs/core/Carousel/CarouselSlide.js +2 -0
  322. package/cjs/core/Carousel/CarouselSlider.js +2 -0
  323. package/cjs/core/Checkbox/Checkbox.js +1 -0
  324. package/cjs/core/ColorPicker/ColorBuilder.js +2 -0
  325. package/cjs/core/ColorPicker/ColorInputPanel.js +4 -1
  326. package/cjs/core/ColorPicker/ColorPalette.js +2 -0
  327. package/cjs/core/ColorPicker/ColorPicker.js +2 -0
  328. package/cjs/core/ColorPicker/ColorSwatch.js +2 -0
  329. package/cjs/core/ComboBox/ComboBox.js +75 -46
  330. package/cjs/core/ComboBox/ComboBoxEndIcon.js +2 -0
  331. package/cjs/core/ComboBox/ComboBoxInput.js +2 -2
  332. package/cjs/core/ComboBox/ComboBoxInputContainer.js +2 -0
  333. package/cjs/core/ComboBox/ComboBoxMenu.js +8 -2
  334. package/cjs/core/ComboBox/ComboBoxMenuItem.js +3 -1
  335. package/cjs/core/ComboBox/ComboBoxMultipleContainer.js +2 -0
  336. package/cjs/core/ComboBox/helpers.js +4 -0
  337. package/cjs/core/DatePicker/DatePicker.js +11 -2
  338. package/cjs/core/Dialog/Dialog.js +23 -10
  339. package/cjs/core/Dialog/DialogBackdrop.js +2 -0
  340. package/cjs/core/Dialog/DialogButtonBar.js +2 -0
  341. package/cjs/core/Dialog/DialogContent.js +2 -0
  342. package/cjs/core/Dialog/DialogContext.d.ts +1 -1
  343. package/cjs/core/Dialog/DialogMain.js +2 -0
  344. package/cjs/core/Dialog/DialogTitleBar.js +2 -0
  345. package/cjs/core/Dialog/DialogTitleBarTitle.js +2 -0
  346. package/cjs/core/Divider/Divider.js +1 -0
  347. package/cjs/core/DropdownMenu/DropdownMenu.d.ts +7 -1
  348. package/cjs/core/DropdownMenu/DropdownMenu.js +32 -23
  349. package/cjs/core/ExpandableBlock/ExpandableBlock.d.ts +3 -0
  350. package/cjs/core/ExpandableBlock/ExpandableBlock.js +38 -3
  351. package/cjs/core/Fieldset/Fieldset.js +1 -0
  352. package/cjs/core/FileUpload/FileEmptyCard.js +6 -0
  353. package/cjs/core/FileUpload/FileUpload.js +2 -0
  354. package/cjs/core/FileUpload/FileUploadCard.js +18 -0
  355. package/cjs/core/FileUpload/FileUploadTemplate.js +2 -0
  356. package/cjs/core/Flex/Flex.js +4 -0
  357. package/cjs/core/Footer/Footer.js +1 -0
  358. package/cjs/core/Footer/FooterItem.js +2 -0
  359. package/cjs/core/Footer/FooterList.js +2 -0
  360. package/cjs/core/Footer/FooterSeparator.js +2 -0
  361. package/cjs/core/Header/Header.js +1 -0
  362. package/cjs/core/Header/HeaderBreadcrumbs.js +2 -0
  363. package/cjs/core/Header/HeaderButton.js +2 -0
  364. package/cjs/core/Header/HeaderLogo.js +3 -1
  365. package/cjs/core/Icon/Icon.js +1 -0
  366. package/cjs/core/InformationPanel/InformationPanel.js +2 -0
  367. package/cjs/core/InformationPanel/InformationPanelBody.js +2 -0
  368. package/cjs/core/InformationPanel/InformationPanelContent.js +2 -0
  369. package/cjs/core/InformationPanel/InformationPanelHeader.js +2 -0
  370. package/cjs/core/InformationPanel/InformationPanelWrapper.js +2 -0
  371. package/cjs/core/Input/Input.js +1 -0
  372. package/cjs/core/InputGrid/InputGrid.js +1 -0
  373. package/cjs/core/InputGroup/InputGroup.js +2 -0
  374. package/cjs/core/InputWithDecorations/InputWithDecorations.js +10 -0
  375. package/cjs/core/Label/Label.js +1 -0
  376. package/cjs/core/LabeledInput/LabeledInput.js +2 -0
  377. package/cjs/core/LabeledSelect/LabeledSelect.js +5 -1
  378. package/cjs/core/LabeledTextarea/LabeledTextarea.js +2 -0
  379. package/cjs/core/LinkAction/LinkAction.js +4 -1
  380. package/cjs/core/List/List.js +1 -0
  381. package/cjs/core/List/ListItem.js +10 -0
  382. package/cjs/core/Menu/Menu.d.ts +3 -1
  383. package/cjs/core/Menu/Menu.js +3 -1
  384. package/cjs/core/Menu/MenuDivider.js +2 -0
  385. package/cjs/core/Menu/MenuExtraContent.d.ts +1 -1
  386. package/cjs/core/Menu/MenuExtraContent.js +3 -3
  387. package/cjs/core/Menu/MenuItem.js +10 -1
  388. package/cjs/core/Menu/MenuItemSkeleton.js +2 -0
  389. package/cjs/core/Modal/Modal.d.ts +1 -1
  390. package/cjs/core/Modal/Modal.js +1 -0
  391. package/cjs/core/Modal/ModalButtonBar.js +2 -0
  392. package/cjs/core/Modal/ModalContent.js +2 -0
  393. package/cjs/core/NonIdealState/ErrorPage.js +1 -0
  394. package/cjs/core/NonIdealState/NonIdealState.js +2 -0
  395. package/cjs/core/NotificationMarker/NotificationMarker.js +2 -0
  396. package/cjs/core/Overlay/Overlay.js +8 -0
  397. package/cjs/core/Panels/Panels.js +13 -0
  398. package/cjs/core/Panels/helpers.js +2 -0
  399. package/cjs/core/Popover/Popover.js +35 -27
  400. package/cjs/core/ProgressIndicators/ProgressLinear.js +2 -0
  401. package/cjs/core/ProgressIndicators/ProgressRadial.js +2 -0
  402. package/cjs/core/Radio/Radio.js +1 -0
  403. package/cjs/core/RadioTiles/RadioTile.js +1 -0
  404. package/cjs/core/RadioTiles/RadioTileGroup.js +2 -0
  405. package/cjs/core/SearchBox/SearchBox.js +15 -0
  406. package/cjs/core/Select/Select.js +61 -47
  407. package/cjs/core/Select/SelectTag.js +1 -0
  408. package/cjs/core/SideNavigation/SideNavigation.d.ts +5 -1
  409. package/cjs/core/SideNavigation/SideNavigation.js +3 -1
  410. package/cjs/core/SideNavigation/SidenavButton.js +2 -0
  411. package/cjs/core/SideNavigation/SidenavSubmenu.js +2 -0
  412. package/cjs/core/SideNavigation/SidenavSubmenuHeader.js +2 -0
  413. package/cjs/core/SkipToContentLink/SkipToContentLink.js +2 -0
  414. package/cjs/core/Slider/Slider.js +1 -0
  415. package/cjs/core/StatusMessage/StatusMessage.js +2 -0
  416. package/cjs/core/Stepper/Stepper.js +1 -0
  417. package/cjs/core/Stepper/WorkflowDiagram.js +2 -0
  418. package/cjs/core/Surface/Surface.js +7 -0
  419. package/cjs/core/Table/ColumnHeader.js +17 -17
  420. package/cjs/core/Table/Table.d.ts +27 -1
  421. package/cjs/core/Table/Table.js +152 -53
  422. package/cjs/core/Table/TableCell.js +6 -4
  423. package/cjs/core/Table/actionHandlers/expandHandler.js +2 -4
  424. package/cjs/core/Table/actionHandlers/selectHandler.js +1 -4
  425. package/cjs/core/Table/cells/DefaultCell.js +31 -14
  426. package/cjs/core/Table/cells/EditableCell.js +2 -0
  427. package/cjs/core/Table/columns/expanderColumn.js +16 -17
  428. package/cjs/core/Table/columns/selectionColumn.js +4 -2
  429. package/cjs/core/Tabs/Tabs.d.ts +37 -0
  430. package/cjs/core/Tabs/Tabs.js +89 -18
  431. package/cjs/core/Tag/Tag.js +1 -0
  432. package/cjs/core/Tag/TagContainer.js +2 -0
  433. package/cjs/core/Textarea/Textarea.js +1 -0
  434. package/cjs/core/ThemeProvider/ThemeProvider.js +57 -21
  435. package/cjs/core/Tile/Tile.js +56 -26
  436. package/cjs/core/TimePicker/TimePicker.js +2 -0
  437. package/cjs/core/Toast/Toaster.js +4 -0
  438. package/cjs/core/ToggleSwitch/ToggleSwitch.js +2 -0
  439. package/cjs/core/Tooltip/Tooltip.js +1 -0
  440. package/cjs/core/TransferList/TransferList.js +15 -4
  441. package/cjs/core/Tree/Tree.js +26 -17
  442. package/cjs/core/Tree/TreeNode.js +1 -0
  443. package/cjs/core/Tree/TreeNodeExpander.js +2 -0
  444. package/cjs/core/Typography/Anchor.js +1 -0
  445. package/cjs/core/Typography/Blockquote.js +2 -0
  446. package/cjs/core/Typography/Code.js +1 -0
  447. package/cjs/core/Typography/Kbd.js +1 -0
  448. package/cjs/core/Typography/Text.js +1 -0
  449. package/cjs/core/VisuallyHidden/VisuallyHidden.js +2 -0
  450. package/cjs/index.d.ts +1 -1
  451. package/cjs/index.js +3 -0
  452. package/cjs/styles.js +1 -1
  453. package/cjs/utils/components/AutoclearingHiddenLiveRegion.d.ts +2 -2
  454. package/cjs/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
  455. package/cjs/utils/components/ButtonBase.js +2 -0
  456. package/cjs/utils/components/InputWithIcon.js +2 -0
  457. package/cjs/utils/components/LineClamp.js +6 -0
  458. package/cjs/utils/components/MiddleTextTruncation.js +2 -0
  459. package/cjs/utils/components/OverflowContainer.js +6 -8
  460. package/cjs/utils/components/Portal.d.ts +3 -5
  461. package/cjs/utils/components/Portal.js +4 -8
  462. package/cjs/utils/components/ShadowRoot.d.ts +11 -2
  463. package/cjs/utils/components/ShadowRoot.js +10 -8
  464. package/cjs/utils/functions/polymorphic.js +2 -0
  465. package/cjs/utils/hooks/useGlobals.js +29 -2
  466. package/cjs/utils/hooks/useWarningLogger.js +29 -1
  467. package/cjs/utils/providers/index.d.ts +0 -1
  468. package/cjs/utils/providers/index.js +0 -1
  469. package/esm/core/Alert/Alert.js +12 -0
  470. package/esm/core/Avatar/Avatar.js +1 -0
  471. package/esm/core/AvatarGroup/AvatarGroup.js +2 -0
  472. package/esm/core/Backdrop/Backdrop.js +1 -0
  473. package/esm/core/Badge/Badge.js +1 -0
  474. package/esm/core/Breadcrumbs/Breadcrumbs.js +10 -1
  475. package/esm/core/ButtonGroup/ButtonGroup.js +4 -0
  476. package/esm/core/Buttons/Button.js +1 -0
  477. package/esm/core/Buttons/DropdownButton.js +2 -0
  478. package/esm/core/Buttons/IconButton.js +9 -0
  479. package/esm/core/Buttons/IdeasButton.js +2 -0
  480. package/esm/core/Buttons/SplitButton.js +2 -0
  481. package/esm/core/Carousel/Carousel.js +2 -0
  482. package/esm/core/Carousel/CarouselContext.js +2 -0
  483. package/esm/core/Carousel/CarouselDot.js +2 -0
  484. package/esm/core/Carousel/CarouselDotsList.js +2 -0
  485. package/esm/core/Carousel/CarouselNavigation.js +6 -0
  486. package/esm/core/Carousel/CarouselSlide.js +2 -0
  487. package/esm/core/Carousel/CarouselSlider.js +2 -0
  488. package/esm/core/Checkbox/Checkbox.js +1 -0
  489. package/esm/core/ColorPicker/ColorBuilder.js +2 -0
  490. package/esm/core/ColorPicker/ColorInputPanel.js +4 -1
  491. package/esm/core/ColorPicker/ColorPalette.js +2 -0
  492. package/esm/core/ColorPicker/ColorPicker.js +2 -0
  493. package/esm/core/ColorPicker/ColorSwatch.js +2 -0
  494. package/esm/core/ComboBox/ComboBox.js +75 -46
  495. package/esm/core/ComboBox/ComboBoxEndIcon.js +2 -0
  496. package/esm/core/ComboBox/ComboBoxInput.js +2 -2
  497. package/esm/core/ComboBox/ComboBoxInputContainer.js +2 -0
  498. package/esm/core/ComboBox/ComboBoxMenu.js +8 -2
  499. package/esm/core/ComboBox/ComboBoxMenuItem.js +3 -1
  500. package/esm/core/ComboBox/ComboBoxMultipleContainer.js +2 -0
  501. package/esm/core/ComboBox/helpers.js +4 -0
  502. package/esm/core/DatePicker/DatePicker.js +11 -2
  503. package/esm/core/Dialog/Dialog.js +22 -8
  504. package/esm/core/Dialog/DialogBackdrop.js +2 -0
  505. package/esm/core/Dialog/DialogButtonBar.js +2 -0
  506. package/esm/core/Dialog/DialogContent.js +2 -0
  507. package/esm/core/Dialog/DialogContext.d.ts +1 -1
  508. package/esm/core/Dialog/DialogMain.js +2 -0
  509. package/esm/core/Dialog/DialogTitleBar.js +2 -0
  510. package/esm/core/Dialog/DialogTitleBarTitle.js +2 -0
  511. package/esm/core/Divider/Divider.js +1 -0
  512. package/esm/core/DropdownMenu/DropdownMenu.d.ts +7 -1
  513. package/esm/core/DropdownMenu/DropdownMenu.js +32 -23
  514. package/esm/core/ExpandableBlock/ExpandableBlock.d.ts +3 -0
  515. package/esm/core/ExpandableBlock/ExpandableBlock.js +107 -81
  516. package/esm/core/Fieldset/Fieldset.js +1 -0
  517. package/esm/core/FileUpload/FileEmptyCard.js +6 -0
  518. package/esm/core/FileUpload/FileUpload.js +2 -0
  519. package/esm/core/FileUpload/FileUploadCard.js +18 -0
  520. package/esm/core/FileUpload/FileUploadTemplate.js +2 -0
  521. package/esm/core/Flex/Flex.js +4 -0
  522. package/esm/core/Footer/Footer.js +1 -0
  523. package/esm/core/Footer/FooterItem.js +2 -0
  524. package/esm/core/Footer/FooterList.js +2 -0
  525. package/esm/core/Footer/FooterSeparator.js +2 -0
  526. package/esm/core/Header/Header.js +1 -0
  527. package/esm/core/Header/HeaderBreadcrumbs.js +2 -0
  528. package/esm/core/Header/HeaderButton.js +2 -0
  529. package/esm/core/Header/HeaderLogo.js +3 -1
  530. package/esm/core/Icon/Icon.js +1 -0
  531. package/esm/core/InformationPanel/InformationPanel.js +2 -0
  532. package/esm/core/InformationPanel/InformationPanelBody.js +2 -0
  533. package/esm/core/InformationPanel/InformationPanelContent.js +2 -0
  534. package/esm/core/InformationPanel/InformationPanelHeader.js +2 -0
  535. package/esm/core/InformationPanel/InformationPanelWrapper.js +2 -0
  536. package/esm/core/Input/Input.js +1 -0
  537. package/esm/core/InputGrid/InputGrid.js +1 -0
  538. package/esm/core/InputGroup/InputGroup.js +2 -0
  539. package/esm/core/InputWithDecorations/InputWithDecorations.js +10 -0
  540. package/esm/core/Label/Label.js +1 -0
  541. package/esm/core/LabeledInput/LabeledInput.js +2 -0
  542. package/esm/core/LabeledSelect/LabeledSelect.js +5 -1
  543. package/esm/core/LabeledTextarea/LabeledTextarea.js +2 -0
  544. package/esm/core/LinkAction/LinkAction.js +4 -1
  545. package/esm/core/List/List.js +1 -0
  546. package/esm/core/List/ListItem.js +10 -0
  547. package/esm/core/Menu/Menu.d.ts +3 -1
  548. package/esm/core/Menu/Menu.js +4 -1
  549. package/esm/core/Menu/MenuDivider.js +2 -0
  550. package/esm/core/Menu/MenuExtraContent.d.ts +1 -1
  551. package/esm/core/Menu/MenuExtraContent.js +3 -3
  552. package/esm/core/Menu/MenuItem.js +10 -1
  553. package/esm/core/Menu/MenuItemSkeleton.js +2 -0
  554. package/esm/core/Modal/Modal.d.ts +1 -1
  555. package/esm/core/Modal/Modal.js +1 -0
  556. package/esm/core/Modal/ModalButtonBar.js +2 -0
  557. package/esm/core/Modal/ModalContent.js +2 -0
  558. package/esm/core/NonIdealState/ErrorPage.js +1 -0
  559. package/esm/core/NonIdealState/NonIdealState.js +2 -0
  560. package/esm/core/NotificationMarker/NotificationMarker.js +2 -0
  561. package/esm/core/Overlay/Overlay.js +8 -0
  562. package/esm/core/Panels/Panels.js +13 -0
  563. package/esm/core/Panels/helpers.js +2 -0
  564. package/esm/core/Popover/Popover.js +39 -28
  565. package/esm/core/ProgressIndicators/ProgressLinear.js +2 -0
  566. package/esm/core/ProgressIndicators/ProgressRadial.js +2 -0
  567. package/esm/core/Radio/Radio.js +1 -0
  568. package/esm/core/RadioTiles/RadioTile.js +1 -0
  569. package/esm/core/RadioTiles/RadioTileGroup.js +2 -0
  570. package/esm/core/SearchBox/SearchBox.js +15 -0
  571. package/esm/core/Select/Select.js +61 -47
  572. package/esm/core/Select/SelectTag.js +1 -0
  573. package/esm/core/SideNavigation/SideNavigation.d.ts +5 -1
  574. package/esm/core/SideNavigation/SideNavigation.js +3 -1
  575. package/esm/core/SideNavigation/SidenavButton.js +2 -0
  576. package/esm/core/SideNavigation/SidenavSubmenu.js +2 -0
  577. package/esm/core/SideNavigation/SidenavSubmenuHeader.js +2 -0
  578. package/esm/core/SkipToContentLink/SkipToContentLink.js +2 -0
  579. package/esm/core/Slider/Slider.js +1 -0
  580. package/esm/core/StatusMessage/StatusMessage.js +2 -0
  581. package/esm/core/Stepper/Stepper.js +1 -0
  582. package/esm/core/Stepper/WorkflowDiagram.js +2 -0
  583. package/esm/core/Surface/Surface.js +7 -0
  584. package/esm/core/Table/ColumnHeader.js +17 -17
  585. package/esm/core/Table/Table.d.ts +27 -1
  586. package/esm/core/Table/Table.js +149 -53
  587. package/esm/core/Table/TableCell.js +6 -4
  588. package/esm/core/Table/actionHandlers/expandHandler.js +2 -4
  589. package/esm/core/Table/actionHandlers/selectHandler.js +1 -4
  590. package/esm/core/Table/cells/DefaultCell.js +31 -14
  591. package/esm/core/Table/cells/EditableCell.js +2 -0
  592. package/esm/core/Table/columns/expanderColumn.js +16 -17
  593. package/esm/core/Table/columns/selectionColumn.js +4 -2
  594. package/esm/core/Tabs/Tabs.d.ts +37 -0
  595. package/esm/core/Tabs/Tabs.js +80 -14
  596. package/esm/core/Tag/Tag.js +1 -0
  597. package/esm/core/Tag/TagContainer.js +2 -0
  598. package/esm/core/Textarea/Textarea.js +1 -0
  599. package/esm/core/ThemeProvider/ThemeProvider.js +57 -20
  600. package/esm/core/Tile/Tile.js +57 -30
  601. package/esm/core/TimePicker/TimePicker.js +2 -0
  602. package/esm/core/Toast/Toaster.js +4 -0
  603. package/esm/core/ToggleSwitch/ToggleSwitch.js +2 -0
  604. package/esm/core/Tooltip/Tooltip.js +1 -0
  605. package/esm/core/TransferList/TransferList.js +15 -4
  606. package/esm/core/Tree/Tree.js +26 -17
  607. package/esm/core/Tree/TreeNode.js +1 -0
  608. package/esm/core/Tree/TreeNodeExpander.js +2 -0
  609. package/esm/core/Typography/Anchor.js +1 -0
  610. package/esm/core/Typography/Blockquote.js +2 -0
  611. package/esm/core/Typography/Code.js +1 -0
  612. package/esm/core/Typography/Kbd.js +1 -0
  613. package/esm/core/Typography/Text.js +1 -0
  614. package/esm/core/VisuallyHidden/VisuallyHidden.js +2 -0
  615. package/esm/index.d.ts +1 -1
  616. package/esm/index.js +1 -1
  617. package/esm/styles.js +1 -1
  618. package/esm/utils/components/AutoclearingHiddenLiveRegion.d.ts +2 -2
  619. package/esm/utils/components/AutoclearingHiddenLiveRegion.js +2 -1
  620. package/esm/utils/components/ButtonBase.js +2 -0
  621. package/esm/utils/components/InputWithIcon.js +2 -0
  622. package/esm/utils/components/LineClamp.js +3 -0
  623. package/esm/utils/components/MiddleTextTruncation.js +2 -0
  624. package/esm/utils/components/OverflowContainer.js +6 -8
  625. package/esm/utils/components/Portal.d.ts +3 -5
  626. package/esm/utils/components/Portal.js +2 -4
  627. package/esm/utils/components/ShadowRoot.d.ts +11 -2
  628. package/esm/utils/components/ShadowRoot.js +10 -8
  629. package/esm/utils/functions/polymorphic.js +2 -0
  630. package/esm/utils/hooks/useGlobals.js +29 -2
  631. package/esm/utils/hooks/useWarningLogger.js +29 -1
  632. package/esm/utils/providers/index.d.ts +0 -1
  633. package/esm/utils/providers/index.js +0 -1
  634. package/package.json +11 -12
  635. package/styles.css +10 -10
  636. package/DEV-cjs/utils/providers/ScopeProvider.js +0 -66
  637. package/DEV-esm/utils/providers/ScopeProvider.js +0 -43
  638. package/cjs/utils/providers/ScopeProvider.d.ts +0 -26
  639. package/cjs/utils/providers/ScopeProvider.js +0 -66
  640. package/esm/utils/providers/ScopeProvider.d.ts +0 -26
  641. package/esm/utils/providers/ScopeProvider.js +0 -43
@@ -44,3 +44,5 @@ const WorkflowDiagram = _react.forwardRef((props, ref) => {
44
44
  ),
45
45
  );
46
46
  });
47
+ if ('development' === process.env.NODE_ENV)
48
+ WorkflowDiagram.displayName = 'WorkflowDiagram';
@@ -53,6 +53,8 @@ const SurfaceHeader = _react.forwardRef((props, ref) => {
53
53
  children,
54
54
  );
55
55
  });
56
+ if ('development' === process.env.NODE_ENV)
57
+ SurfaceHeader.displayName = 'Surface.Header';
56
58
  const SurfaceBody = _react.forwardRef((props, ref) => {
57
59
  let { children, className, isPadded = false, ...rest } = props;
58
60
  let { setHasLayout } = (0, _index.useSafeContext)(SurfaceContext);
@@ -70,6 +72,8 @@ const SurfaceBody = _react.forwardRef((props, ref) => {
70
72
  children,
71
73
  );
72
74
  });
75
+ if ('development' === process.env.NODE_ENV)
76
+ SurfaceBody.displayName = 'Surface.Body';
73
77
  const Surface = Object.assign(
74
78
  _react.forwardRef((props, ref) => {
75
79
  let {
@@ -111,4 +115,7 @@ const Surface = Object.assign(
111
115
  Body: SurfaceBody,
112
116
  },
113
117
  );
118
+ if ('development' === process.env.NODE_ENV) Surface.displayName = 'Surface';
114
119
  const SurfaceContext = _react.createContext(void 0);
120
+ if ('development' === process.env.NODE_ENV)
121
+ SurfaceContext.displayName = 'SurfaceContext';
@@ -102,26 +102,26 @@ const ColumnHeader = _react.forwardRef((props, forwardedRef) => {
102
102
  _react.createElement(
103
103
  _react.Fragment,
104
104
  null,
105
- _react.createElement(
106
- _index.ShadowRoot,
107
- null,
108
- 'string' == typeof column.Header
109
- ? _react.createElement(
105
+ 'string' == typeof column.Header
106
+ ? _react.createElement(
107
+ _index.ShadowRoot,
108
+ null,
109
+ _react.createElement(
110
110
  _index.LineClamp,
111
111
  null,
112
112
  _react.createElement('slot', null),
113
- )
114
- : _react.createElement('slot', null),
115
- _react.createElement('slot', {
116
- name: 'actions',
117
- }),
118
- _react.createElement('slot', {
119
- name: 'resizers',
120
- }),
121
- _react.createElement('slot', {
122
- name: 'shadows',
123
- }),
124
- ),
113
+ ),
114
+ _react.createElement('slot', {
115
+ name: 'actions',
116
+ }),
117
+ _react.createElement('slot', {
118
+ name: 'resizers',
119
+ }),
120
+ _react.createElement('slot', {
121
+ name: 'shadows',
122
+ }),
123
+ )
124
+ : null,
125
125
  column.render('Header'),
126
126
  (showFilterButton(column) || showSortButton(column)) &&
127
127
  _react.createElement(
@@ -44,7 +44,7 @@ export type TablePaginatorRendererProps = {
44
44
  * Table props.
45
45
  * columns and data must be memoized.
46
46
  */
47
- export type TableProps<T extends Record<string, unknown> = Record<string, unknown>> = Omit<TableOptions<T>, 'disableSortBy'> & {
47
+ export type TableProps<T extends Record<string, unknown> = Record<string, unknown>> = Omit<TableOptions<T>, 'disableSortBy'> & Omit<React.ComponentPropsWithoutRef<'div'>, 'role' | 'onSelect'> & {
48
48
  /**
49
49
  * Flag whether data is loading.
50
50
  * @default false
@@ -203,6 +203,13 @@ export type TableProps<T extends Record<string, unknown> = Record<string, unknow
203
203
  * Passes custom props to Table body.
204
204
  */
205
205
  bodyProps?: React.ComponentProps<'div'>;
206
+ /**
207
+ * Passes props to the `role="table"` element within the wrapper.
208
+ *
209
+ * If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
210
+ * Else, all ARIA attributes will be passed to the inner element with `role="table"`.
211
+ */
212
+ tableProps?: React.ComponentProps<'div'>;
206
213
  /**
207
214
  * Passes custom props to empty table.
208
215
  */
@@ -231,9 +238,28 @@ export type TableProps<T extends Record<string, unknown> = Record<string, unknow
231
238
  * />
232
239
  */
233
240
  scrollToRow?: (rows: Row<T>[], data: T[]) => number;
241
+ /**
242
+ * Caption for the table.
243
+ *
244
+ * Although optional for backward compatibility, it is **recommended** to use it for accessibility purposes.
245
+ *
246
+ * @default "Table"
247
+ */
248
+ caption?: string;
249
+ /**
250
+ * If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
251
+ * Else, all ARIA attributes will be passed to the inner element with `role="table"`.
252
+ */
253
+ role?: React.AriaRole;
234
254
  } & Omit<CommonProps, 'title'>;
235
255
  /**
236
256
  * Table based on [react-table](https://react-table.tanstack.com/docs/api/overview).
257
+ *
258
+ * **Note**: If `tableProps` or `role` is passed to `Table`, all ARIA attributes passed to `Table` will be passed to the wrapper.
259
+ * Else, all ARIA attributes will be passed to the inner element with `role="table"`.
260
+ *
261
+ * ---
262
+ *
237
263
  * @example
238
264
  * const columns = React.useMemo(() => [
239
265
  * {
@@ -37,6 +37,7 @@ const _index2 = require('./actionHandlers/index.js');
37
37
  const _index3 = require('./columns/index.js');
38
38
  const _ColumnHeader = require('./ColumnHeader.js');
39
39
  const _TableExpandableContentMemoized = require('./TableExpandableContentMemoized.js');
40
+ const _VisuallyHidden = require('../VisuallyHidden/VisuallyHidden.js');
40
41
  const singleRowSelectedAction = 'singleRowSelected';
41
42
  const shiftRowSelectedAction = 'shiftRowSelected';
42
43
  const tableResizeStartAction = 'tableResizeStart';
@@ -93,10 +94,44 @@ const Table = (props) => {
93
94
  headerWrapperProps,
94
95
  headerProps,
95
96
  bodyProps,
97
+ tableProps,
96
98
  emptyTableContentProps,
97
99
  getRowId,
98
- ...rest
100
+ caption = 'Table',
101
+ role,
102
+ ..._rest
99
103
  } = props;
104
+ let { ariaRestAttributes, nonAriaRestAttributes } = _react.useMemo(
105
+ () =>
106
+ Object.entries(_rest).reduce(
107
+ (result, [key, value]) => {
108
+ if (key.startsWith('aria-')) result.ariaRestAttributes[key] = value;
109
+ else result.nonAriaRestAttributes[key] = value;
110
+ return result;
111
+ },
112
+ {
113
+ ariaRestAttributes: {},
114
+ nonAriaRestAttributes: {},
115
+ },
116
+ ),
117
+ [_rest],
118
+ );
119
+ let { outerAriaRestAttributes, innerAriaRestAttributes } =
120
+ _react.useMemo(() => {
121
+ if (tableProps || role)
122
+ return {
123
+ outerAriaRestAttributes: {
124
+ ...ariaRestAttributes,
125
+ },
126
+ innerAriaRestAttributes: {},
127
+ };
128
+ return {
129
+ outerAriaRestAttributes: {},
130
+ innerAriaRestAttributes: {
131
+ ...ariaRestAttributes,
132
+ },
133
+ };
134
+ }, [ariaRestAttributes, role, tableProps]);
100
135
  (0, _index.useGlobals)();
101
136
  let ownerDocument = _react.useRef(void 0);
102
137
  let defaultColumn = _react.useMemo(
@@ -315,16 +350,21 @@ const Table = (props) => {
315
350
  } = instance;
316
351
  let headerGroups = _headerGroups;
317
352
  let logWarning = (0, _index.useWarningLogger)();
318
- if (1 === columns.length && 'columns' in columns[0])
353
+ if (1 === columns.length && 'columns' in columns[0]) {
319
354
  headerGroups = _headerGroups.slice(1);
320
- let ariaDataAttributes = Object.entries(rest).reduce(
321
- (result, [key, value]) => {
322
- if (key.startsWith('data-') || key.startsWith('aria-'))
323
- result[key] = value;
324
- return result;
325
- },
326
- {},
327
- );
355
+ if ('development' === process.env.NODE_ENV)
356
+ logWarning(
357
+ "Table's `columns` prop should not have a top-level `Header` or sub-columns. They are only allowed to be passed for backwards compatibility.\n See https://github.com/iTwin/iTwinUI/wiki/iTwinUI-react-v2-migration-guide#breaking-changes",
358
+ );
359
+ }
360
+ if (
361
+ 'development' === process.env.NODE_ENV &&
362
+ subComponent &&
363
+ data.some((item) => !!item.subRows?.length)
364
+ )
365
+ logWarning(
366
+ 'Passing both `subComponent` and `data` with `subRows` is not supported. There are features designed for `subRows` that are not compatible with `subComponent` and vice versa.',
367
+ );
328
368
  let areFiltersSet =
329
369
  allColumns.some(
330
370
  (column) => null != column.filterValue && '' !== column.filterValue,
@@ -339,7 +379,7 @@ const Table = (props) => {
339
379
  !isDisabled &&
340
380
  selectRowOnClick &&
341
381
  !event.isDefaultPrevented()
342
- ) {
382
+ )
343
383
  if ('multi' === selectionMode && event.shiftKey)
344
384
  dispatch({
345
385
  type: shiftRowSelectedAction,
@@ -353,7 +393,6 @@ const Table = (props) => {
353
393
  type: singleRowSelectedAction,
354
394
  id: row.id,
355
395
  });
356
- }
357
396
  },
358
397
  [
359
398
  isRowDisabled,
@@ -554,6 +593,7 @@ const Table = (props) => {
554
593
  _react.useEffect(() => {
555
594
  updateStickyState();
556
595
  }, []);
596
+ let captionId = _react.useId();
557
597
  return _react.createElement(
558
598
  _utils.TableInstanceContext.Provider,
559
599
  {
@@ -577,10 +617,46 @@ const Table = (props) => {
577
617
  ...style,
578
618
  },
579
619
  }),
620
+ role: role,
621
+ 'aria-labelledby': captionId,
580
622
  onScroll: () => updateStickyState(),
581
623
  'data-iui-size': 'default' === density ? void 0 : density,
582
- ...ariaDataAttributes,
624
+ ...outerAriaRestAttributes,
625
+ ...nonAriaRestAttributes,
583
626
  },
627
+ _react.createElement(
628
+ _index.ShadowRoot,
629
+ null,
630
+ _react.createElement(
631
+ 'div',
632
+ {
633
+ role: 'table',
634
+ ...innerAriaRestAttributes,
635
+ ...tableProps,
636
+ },
637
+ _react.createElement('slot', {
638
+ name: 'caption',
639
+ }),
640
+ _react.createElement('slot', {
641
+ name: 'iui-table-header-wrapper',
642
+ }),
643
+ _react.createElement('slot', {
644
+ name: 'iui-table-body',
645
+ }),
646
+ ),
647
+ _react.createElement('slot', {
648
+ name: 'iui-table-body-extra',
649
+ }),
650
+ _react.createElement('slot', null),
651
+ ),
652
+ _react.createElement(
653
+ _VisuallyHidden.VisuallyHidden,
654
+ {
655
+ slot: 'caption',
656
+ id: captionId,
657
+ },
658
+ caption,
659
+ ),
584
660
  headerGroups.map((headerGroup) => {
585
661
  headerGroup.headers = headerGroup.headers.filter(
586
662
  (header) =>
@@ -593,6 +669,7 @@ const Table = (props) => {
593
669
  return _react.createElement(
594
670
  _index.Box,
595
671
  {
672
+ slot: 'iui-table-header-wrapper',
596
673
  as: 'div',
597
674
  key: headerGroupProps.key,
598
675
  ...headerWrapperProps,
@@ -648,6 +725,7 @@ const Table = (props) => {
648
725
  _react.createElement(
649
726
  _index.Box,
650
727
  {
728
+ slot: 'iui-table-body',
651
729
  as: 'div',
652
730
  ...bodyProps,
653
731
  ...getTableBodyProps({
@@ -659,13 +737,13 @@ const Table = (props) => {
659
737
  bodyProps?.className,
660
738
  ),
661
739
  }),
662
- 'aria-multiselectable':
663
- (isSelectable && 'multi' === selectionMode) || void 0,
740
+ role: void 0,
664
741
  },
665
742
  _react.createElement(
666
743
  _index.ShadowRoot,
667
744
  {
668
745
  css: virtualizerCss,
746
+ flush: false,
669
747
  },
670
748
  enableVirtualization && 0 !== data.length
671
749
  ? _react.createElement(
@@ -692,59 +770,49 @@ const Table = (props) => {
692
770
  )
693
771
  : page.map((_, index) => getPreparedRow(index)),
694
772
  ),
695
- isLoading &&
696
- 0 === data.length &&
773
+ ),
774
+ isLoading &&
775
+ 0 === data.length &&
776
+ _react.createElement(
777
+ TableBodyExtraWrapper,
778
+ null,
697
779
  _react.createElement(
698
- _index.Box,
699
- {
700
- as: 'div',
701
- ...emptyTableContentProps,
702
- className: (0, _classnames.default)(
703
- 'iui-table-empty',
704
- emptyTableContentProps?.className,
705
- ),
706
- },
780
+ TableEmptyWrapper,
781
+ emptyTableContentProps,
707
782
  _react.createElement(_ProgressRadial.ProgressRadial, {
708
783
  indeterminate: true,
709
784
  }),
710
785
  ),
711
- !isLoading &&
712
- 0 === data.length &&
713
- !areFiltersSet &&
786
+ ),
787
+ !isLoading &&
788
+ 0 === data.length &&
789
+ !areFiltersSet &&
790
+ _react.createElement(
791
+ TableBodyExtraWrapper,
792
+ null,
714
793
  _react.createElement(
715
- _index.Box,
716
- {
717
- as: 'div',
718
- ...emptyTableContentProps,
719
- className: (0, _classnames.default)(
720
- 'iui-table-empty',
721
- emptyTableContentProps?.className,
722
- ),
723
- },
794
+ TableEmptyWrapper,
795
+ emptyTableContentProps,
724
796
  _react.createElement('div', null, emptyTableContent),
725
797
  ),
726
- !isLoading &&
727
- (0 === data.length || 0 === rows.length) &&
728
- areFiltersSet &&
798
+ ),
799
+ !isLoading &&
800
+ (0 === data.length || 0 === rows.length) &&
801
+ areFiltersSet &&
802
+ _react.createElement(
803
+ TableBodyExtraWrapper,
804
+ null,
729
805
  _react.createElement(
730
- _index.Box,
731
- {
732
- as: 'div',
733
- ...emptyTableContentProps,
734
- className: (0, _classnames.default)(
735
- 'iui-table-empty',
736
- emptyTableContentProps?.className,
737
- ),
738
- },
806
+ TableEmptyWrapper,
807
+ emptyTableContentProps,
739
808
  _react.createElement('div', null, emptyFilteredTableContent),
740
809
  ),
741
- ),
810
+ ),
742
811
  isLoading &&
743
812
  0 !== data.length &&
744
813
  _react.createElement(
745
- _index.Box,
814
+ TableBodyExtraWrapper,
746
815
  {
747
- className: 'iui-table-body-extra',
748
816
  'data-iui-loading': 'true',
749
817
  },
750
818
  _react.createElement(_ProgressRadial.ProgressRadial, {
@@ -756,3 +824,34 @@ const Table = (props) => {
756
824
  ),
757
825
  );
758
826
  };
827
+ if ('development' === process.env.NODE_ENV) Table.displayName = 'Table';
828
+ const TableBodyExtraWrapper = _react.forwardRef((props, ref) => {
829
+ let { children, ...rest } = props;
830
+ return _react.createElement(
831
+ _index.Box,
832
+ {
833
+ as: 'div',
834
+ ref: ref,
835
+ slot: 'iui-table-body-extra',
836
+ ...rest,
837
+ className: (0, _classnames.default)(
838
+ 'iui-table-body-extra',
839
+ rest.className,
840
+ ),
841
+ },
842
+ children,
843
+ );
844
+ });
845
+ const TableEmptyWrapper = _react.forwardRef((props, ref) => {
846
+ let { children, ...rest } = props;
847
+ return _react.createElement(
848
+ _index.Box,
849
+ {
850
+ as: 'div',
851
+ ref: ref,
852
+ ...rest,
853
+ className: (0, _classnames.default)('iui-table-empty', rest.className),
854
+ },
855
+ children,
856
+ );
857
+ });
@@ -56,10 +56,12 @@ const TableCell = (props) => {
56
56
  });
57
57
  let cellProps = {
58
58
  ...tableInstance,
59
- cell,
60
- row: cell.row,
61
- value: cell.value,
62
- column: cell.column,
59
+ ...{
60
+ cell,
61
+ row: cell.row,
62
+ value: cell.value,
63
+ column: cell.column,
64
+ },
63
65
  };
64
66
  let cellContent = _react.createElement(
65
67
  _react.Fragment,
@@ -9,10 +9,8 @@ Object.defineProperty(exports, 'onExpandHandler', {
9
9
  },
10
10
  });
11
11
  const onExpandHandler = (newState, instance, onExpand) => {
12
- if (!instance?.preFilteredFlatRows.length) {
13
- onExpand?.([], newState);
14
- return;
15
- }
12
+ if (!instance?.preFilteredFlatRows.length)
13
+ return void onExpand?.([], newState);
16
14
  let expandedData = [];
17
15
  instance.preFilteredFlatRows.forEach((row) => {
18
16
  if (newState.expanded[row.id]) expandedData.push(row.original);
@@ -22,10 +22,7 @@ _export(exports, {
22
22
  });
23
23
  const _Table = require('../Table.js');
24
24
  const onSelectHandler = (newState, instance, onSelect, isRowDisabled) => {
25
- if (!instance?.rows.length) {
26
- onSelect?.([], newState);
27
- return;
28
- }
25
+ if (!instance?.rows.length) return void onSelect?.([], newState);
29
26
  let newSelectedRowIds = {};
30
27
  let handleRow = (row) => {
31
28
  if (isRowDisabled?.(row.original)) return false;
@@ -61,29 +61,31 @@ const DefaultCell = (props) => {
61
61
  _index.ShadowRoot,
62
62
  {
63
63
  key: `${cellElementKey}-shadow-root`,
64
+ flush: false,
65
+ css: css,
64
66
  },
65
67
  _react.createElement('slot', {
66
68
  name: 'start',
67
- key: `${cellElementKey}-shadow-root-start`,
68
69
  }),
69
- clamp
70
- ? _react.createElement(
71
- _index.LineClamp,
72
- {
73
- key: `${cellElementKey}-shadow-root-slot`,
74
- },
75
- _react.createElement('slot', null),
76
- )
77
- : _react.createElement('slot', {
78
- key: `${cellElementKey}-shadow-root-slot`,
79
- }),
70
+ _react.createElement(
71
+ 'div',
72
+ {
73
+ className: '_iui-table-cell-main-content',
74
+ onClick: (e) => e.stopPropagation(),
75
+ },
76
+ clamp
77
+ ? _react.createElement(
78
+ _index.LineClamp,
79
+ null,
80
+ _react.createElement('slot', null),
81
+ )
82
+ : _react.createElement('slot', null),
83
+ ),
80
84
  _react.createElement('slot', {
81
85
  name: 'end',
82
- key: `${cellElementKey}-shadow-root-end`,
83
86
  }),
84
87
  _react.createElement('slot', {
85
88
  name: 'shadows',
86
- key: `${cellElementKey}-shadow-root-shadows`,
87
89
  }),
88
90
  ),
89
91
  startIcon &&
@@ -109,3 +111,18 @@ const DefaultCell = (props) => {
109
111
  ),
110
112
  );
111
113
  };
114
+ if ('development' === process.env.NODE_ENV)
115
+ DefaultCell.displayName = 'DefaultCell';
116
+ const css = `
117
+ ._iui-table-cell-main-content {
118
+ position: relative;
119
+ isolation: isolate;
120
+ }
121
+ ._iui-table-cell-main-content::before {
122
+ content: '';
123
+ display: block;
124
+ position: absolute;
125
+ inset: -6px;
126
+ z-index: -1;
127
+ }
128
+ `;
@@ -88,3 +88,5 @@ const EditableCell = (props) => {
88
88
  children,
89
89
  );
90
90
  };
91
+ if ('development' === process.env.NODE_ENV)
92
+ EditableCell.displayName = 'EditableCell';
@@ -37,24 +37,23 @@ const ExpanderColumn = (props = {}) => {
37
37
  cellClassName: 'iui-slot',
38
38
  Cell: (props) => {
39
39
  let { row } = props;
40
- if (subComponent?.(row))
41
- return _react.createElement(
42
- _IconButton.IconButton,
43
- {
44
- 'aria-label': 'Toggle expandable content',
45
- className: 'iui-table-row-expander',
46
- styleType: 'borderless',
47
- size: 'small',
48
- onClick: (e) => {
49
- e.stopPropagation();
50
- row.toggleRowExpanded();
51
- },
52
- disabled: isDisabled?.(props.row.original),
53
- 'aria-expanded': row.isExpanded,
40
+ if (!subComponent?.(row)) return null;
41
+ return _react.createElement(
42
+ _IconButton.IconButton,
43
+ {
44
+ 'aria-label': 'Toggle expandable content',
45
+ className: 'iui-table-row-expander',
46
+ styleType: 'borderless',
47
+ size: 'small',
48
+ onClick: (e) => {
49
+ e.stopPropagation();
50
+ row.toggleRowExpanded();
54
51
  },
55
- _react.createElement(_index.SvgChevronRight, null),
56
- );
57
- return null;
52
+ disabled: isDisabled?.(props.row.original),
53
+ 'aria-expanded': row.isExpanded,
54
+ },
55
+ _react.createElement(_index.SvgChevronRight, null),
56
+ );
58
57
  },
59
58
  cellRenderer: (props) =>
60
59
  _react.createElement(_index1.DefaultCell, {
@@ -52,6 +52,7 @@ const SelectionColumn = (props = {}) => {
52
52
  );
53
53
  let indeterminate =
54
54
  !checked && Object.keys(state.selectedRowIds).length > 0;
55
+ let nextToggleState = !rows.some((row) => row.isSelected);
55
56
  return _react.createElement(_Checkbox.Checkbox, {
56
57
  ...getToggleAllRowsSelectedProps(),
57
58
  style: {},
@@ -59,8 +60,8 @@ const SelectionColumn = (props = {}) => {
59
60
  checked: checked && !disabled,
60
61
  indeterminate: indeterminate,
61
62
  disabled: disabled,
62
- onChange: () =>
63
- toggleAllRowsSelected(!rows.some((row) => row.isSelected)),
63
+ 'aria-label': `${nextToggleState ? 'Select' : 'Deselect'} all rows`,
64
+ onChange: () => toggleAllRowsSelected(nextToggleState),
64
65
  });
65
66
  },
66
67
  Cell: ({ row, selectSubRows = true }) =>
@@ -70,6 +71,7 @@ const SelectionColumn = (props = {}) => {
70
71
  title: '',
71
72
  disabled: isDisabled?.(row.original),
72
73
  onClick: (e) => e.stopPropagation(),
74
+ 'aria-label': `${row.isSelected ? 'Deselect' : 'Select'} row`,
73
75
  onChange: () => {
74
76
  if (
75
77
  row.subRows.length > 0 &&
@@ -52,12 +52,21 @@ type TabsWrapperOwnProps = {
52
52
  */
53
53
  defaultChecked?: never;
54
54
  } & TabsOrientationProps;
55
+ type TabsWrapperPresentationOwnProps = {
56
+ orientation?: 'horizontal' | 'vertical';
57
+ };
55
58
  type TabListOwnProps = {
56
59
  /**
57
60
  * Tab items.
58
61
  */
59
62
  children: React.ReactNode[];
60
63
  };
64
+ type TabListPresentationOwnProps = {
65
+ type?: 'default' | 'borderless' | 'pill';
66
+ color?: 'blue' | 'green';
67
+ orientation?: 'horizontal' | 'vertical';
68
+ size?: 'default' | 'large';
69
+ };
61
70
  type TabOwnProps = {
62
71
  /**
63
72
  * Value used to associate the tab with a given panel.
@@ -293,3 +302,31 @@ export declare const Tabs: PolymorphicForwardRefComponent<"div", TabsLegacyProps
293
302
  */
294
303
  Panel: PolymorphicForwardRefComponent<"div", TabsPanelOwnProps>;
295
304
  };
305
+ /**
306
+ * Presentational version of `Tabs`. It renders purely static elements, without any associated behaviors.
307
+ */
308
+ export declare const unstable_TabsPresentation: {
309
+ Wrapper: PolymorphicForwardRefComponent<"div", TabsWrapperPresentationOwnProps>;
310
+ /**
311
+ * This could be used with `role="list"` or `role="tablist"`.
312
+ */
313
+ TabList: PolymorphicForwardRefComponent<"div", TabListPresentationOwnProps>;
314
+ /**
315
+ * This renders a button without any role by default. The rendered element can be changed using the `as` prop
316
+ * (e.g. `as="a"` or `as="div"`)
317
+ *
318
+ * When _not_ using `role="tab"`, the selected state can be set using `aria-current="true"` (or `aria-current="page"`).
319
+ *
320
+ * When using `role="tab"`, the selected state can be set using `aria-selected="true"`.
321
+ *
322
+ * Example:
323
+ * ```jsx
324
+ * <TabsPresentation.Tab
325
+ * as="a"
326
+ * href=""
327
+ * aria-current="true"
328
+ * />
329
+ * ```
330
+ */
331
+ Tab: PolymorphicForwardRefComponent<"button", {}>;
332
+ };