@itwin/itwinui-react 3.11.3 → 3.12.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 (779) hide show
  1. package/CHANGELOG.md +41 -0
  2. package/cjs/core/Alert/Alert.d.ts +3 -7
  3. package/cjs/core/Alert/Alert.js +118 -121
  4. package/cjs/core/Avatar/Avatar.js +75 -70
  5. package/cjs/core/AvatarGroup/AvatarGroup.js +70 -82
  6. package/cjs/core/Backdrop/Backdrop.js +28 -38
  7. package/cjs/core/Badge/Badge.js +47 -65
  8. package/cjs/core/Breadcrumbs/Breadcrumbs.js +161 -129
  9. package/cjs/core/ButtonGroup/ButtonGroup.js +143 -108
  10. package/cjs/core/Buttons/Button.js +88 -55
  11. package/cjs/core/Buttons/DropdownButton.js +53 -54
  12. package/cjs/core/Buttons/IconButton.js +71 -52
  13. package/cjs/core/Buttons/IdeasButton.js +29 -44
  14. package/cjs/core/Buttons/SplitButton.js +96 -87
  15. package/cjs/core/Carousel/Carousel.d.ts +13 -119
  16. package/cjs/core/Carousel/Carousel.js +75 -103
  17. package/cjs/core/Carousel/CarouselContext.js +12 -31
  18. package/cjs/core/Carousel/CarouselDot.js +33 -46
  19. package/cjs/core/Carousel/CarouselDotsList.js +161 -144
  20. package/cjs/core/Carousel/CarouselNavigation.d.ts +6 -112
  21. package/cjs/core/Carousel/CarouselNavigation.js +89 -83
  22. package/cjs/core/Carousel/CarouselSlide.js +50 -62
  23. package/cjs/core/Carousel/CarouselSlider.d.ts +1 -1
  24. package/cjs/core/Carousel/CarouselSlider.js +72 -80
  25. package/cjs/core/Checkbox/Checkbox.js +92 -72
  26. package/cjs/core/ColorPicker/ColorBuilder.d.ts +1 -1
  27. package/cjs/core/ColorPicker/ColorBuilder.js +297 -209
  28. package/cjs/core/ColorPicker/ColorInputPanel.js +442 -287
  29. package/cjs/core/ColorPicker/ColorPalette.js +56 -64
  30. package/cjs/core/ColorPicker/ColorPicker.js +99 -97
  31. package/cjs/core/ColorPicker/ColorPickerContext.d.ts +2 -2
  32. package/cjs/core/ColorPicker/ColorPickerContext.js +28 -37
  33. package/cjs/core/ColorPicker/ColorSwatch.js +48 -51
  34. package/cjs/core/ComboBox/ComboBox.d.ts +13 -3
  35. package/cjs/core/ComboBox/ComboBox.js +408 -321
  36. package/cjs/core/ComboBox/ComboBox.test-types.js +91 -0
  37. package/cjs/core/ComboBox/ComboBoxEndIcon.js +37 -43
  38. package/cjs/core/ComboBox/ComboBoxInput.js +215 -172
  39. package/cjs/core/ComboBox/ComboBoxInputContainer.js +39 -40
  40. package/cjs/core/ComboBox/ComboBoxMenu.d.ts +1 -1
  41. package/cjs/core/ComboBox/ComboBoxMenu.js +93 -76
  42. package/cjs/core/ComboBox/ComboBoxMenuItem.js +82 -47
  43. package/cjs/core/ComboBox/ComboBoxMultipleContainer.js +21 -35
  44. package/cjs/core/ComboBox/helpers.d.ts +4 -27
  45. package/cjs/core/ComboBox/helpers.js +24 -78
  46. package/cjs/core/DatePicker/DatePicker.js +582 -375
  47. package/cjs/core/Dialog/Dialog.js +81 -91
  48. package/cjs/core/Dialog/DialogBackdrop.js +58 -63
  49. package/cjs/core/Dialog/DialogButtonBar.js +12 -17
  50. package/cjs/core/Dialog/DialogContent.js +12 -16
  51. package/cjs/core/Dialog/DialogContext.js +22 -33
  52. package/cjs/core/Dialog/DialogDragContext.d.ts +1 -1
  53. package/cjs/core/Dialog/DialogDragContext.js +25 -36
  54. package/cjs/core/Dialog/DialogMain.js +195 -162
  55. package/cjs/core/Dialog/DialogTitleBar.js +66 -68
  56. package/cjs/core/Dialog/DialogTitleBarTitle.js +12 -14
  57. package/cjs/core/Divider/Divider.js +24 -41
  58. package/cjs/core/DropdownMenu/DropdownMenu.d.ts +1 -1
  59. package/cjs/core/DropdownMenu/DropdownMenu.js +66 -111
  60. package/cjs/core/ExpandableBlock/ExpandableBlock.d.ts +3 -3
  61. package/cjs/core/ExpandableBlock/ExpandableBlock.js +196 -177
  62. package/cjs/core/Fieldset/Fieldset.js +39 -55
  63. package/cjs/core/FileUpload/FileEmptyCard.js +46 -71
  64. package/cjs/core/FileUpload/FileUpload.js +91 -76
  65. package/cjs/core/FileUpload/FileUploadCard.d.ts +2 -2
  66. package/cjs/core/FileUpload/FileUploadCard.js +179 -163
  67. package/cjs/core/FileUpload/FileUploadTemplate.js +61 -54
  68. package/cjs/core/Flex/Flex.js +82 -146
  69. package/cjs/core/Footer/Footer.d.ts +1 -1
  70. package/cjs/core/Footer/Footer.js +125 -113
  71. package/cjs/core/Footer/FooterItem.js +12 -12
  72. package/cjs/core/Footer/FooterList.js +12 -12
  73. package/cjs/core/Footer/FooterSeparator.js +13 -13
  74. package/cjs/core/Header/Header.js +76 -79
  75. package/cjs/core/Header/HeaderBasicButton.js +29 -43
  76. package/cjs/core/Header/HeaderBreadcrumbs.js +59 -54
  77. package/cjs/core/Header/HeaderButton.js +80 -59
  78. package/cjs/core/Header/HeaderDropdownButton.js +54 -50
  79. package/cjs/core/Header/HeaderLogo.js +48 -48
  80. package/cjs/core/Header/HeaderSplitButton.js +72 -51
  81. package/cjs/core/Icon/Icon.js +42 -62
  82. package/cjs/core/InformationPanel/InformationPanel.js +105 -98
  83. package/cjs/core/InformationPanel/InformationPanelBody.js +12 -12
  84. package/cjs/core/InformationPanel/InformationPanelContent.js +29 -61
  85. package/cjs/core/InformationPanel/InformationPanelHeader.js +45 -60
  86. package/cjs/core/InformationPanel/InformationPanelWrapper.js +14 -18
  87. package/cjs/core/Input/Input.js +28 -46
  88. package/cjs/core/InputGrid/InputGrid.js +170 -206
  89. package/cjs/core/InputGroup/InputGroup.js +84 -75
  90. package/cjs/core/InputWithDecorations/InputWithDecorations.d.ts +2 -2
  91. package/cjs/core/InputWithDecorations/InputWithDecorations.js +59 -82
  92. package/cjs/core/Label/Label.js +39 -48
  93. package/cjs/core/LabeledInput/LabeledInput.js +82 -58
  94. package/cjs/core/LabeledSelect/LabeledSelect.d.ts +3 -389
  95. package/cjs/core/LabeledSelect/LabeledSelect.js +68 -73
  96. package/cjs/core/LabeledSelect/LabeledSelect.types-test.js +99 -0
  97. package/cjs/core/LabeledTextarea/LabeledTextarea.js +20 -58
  98. package/cjs/core/LinkAction/LinkAction.d.ts +1 -1
  99. package/cjs/core/LinkAction/LinkAction.js +36 -63
  100. package/cjs/core/List/List.js +15 -10
  101. package/cjs/core/List/ListItem.d.ts +3 -3
  102. package/cjs/core/List/ListItem.js +48 -99
  103. package/cjs/core/Menu/Menu.d.ts +80 -6
  104. package/cjs/core/Menu/Menu.js +209 -94
  105. package/cjs/core/Menu/MenuDivider.d.ts +1 -1
  106. package/cjs/core/Menu/MenuDivider.js +13 -25
  107. package/cjs/core/Menu/MenuExtraContent.js +13 -30
  108. package/cjs/core/Menu/MenuItem.d.ts +0 -8
  109. package/cjs/core/Menu/MenuItem.js +133 -173
  110. package/cjs/core/Menu/MenuItemSkeleton.js +65 -52
  111. package/cjs/core/Modal/Modal.js +57 -59
  112. package/cjs/core/Modal/ModalButtonBar.js +12 -12
  113. package/cjs/core/Modal/ModalContent.js +12 -12
  114. package/cjs/core/NonIdealState/ErrorPage.js +221 -164
  115. package/cjs/core/NonIdealState/NonIdealState.js +74 -49
  116. package/cjs/core/NotificationMarker/NotificationMarker.js +38 -50
  117. package/cjs/core/Overlay/Overlay.d.ts +3 -3
  118. package/cjs/core/Overlay/Overlay.js +56 -75
  119. package/cjs/core/Popover/Popover.d.ts +23 -30
  120. package/cjs/core/Popover/Popover.js +262 -191
  121. package/cjs/core/ProgressIndicators/ProgressLinear.js +71 -69
  122. package/cjs/core/ProgressIndicators/ProgressRadial.js +72 -70
  123. package/cjs/core/Radio/Radio.js +64 -53
  124. package/cjs/core/RadioTiles/RadioTile.js +80 -49
  125. package/cjs/core/RadioTiles/RadioTileGroup.js +25 -44
  126. package/cjs/core/SearchBox/SearchBox.d.ts +2 -2
  127. package/cjs/core/SearchBox/SearchBox.js +204 -167
  128. package/cjs/core/Select/Select.d.ts +1 -1
  129. package/cjs/core/Select/Select.js +461 -303
  130. package/cjs/core/Select/Select.types-test.js +112 -0
  131. package/cjs/core/Select/SelectTag.js +28 -43
  132. package/cjs/core/Select/SelectTagContainer.js +34 -46
  133. package/cjs/core/SideNavigation/SideNavigation.js +122 -72
  134. package/cjs/core/SideNavigation/SidenavButton.js +51 -46
  135. package/cjs/core/SideNavigation/SidenavSubmenu.d.ts +1 -1
  136. package/cjs/core/SideNavigation/SidenavSubmenu.js +29 -47
  137. package/cjs/core/SideNavigation/SidenavSubmenuHeader.js +36 -54
  138. package/cjs/core/SkipToContentLink/SkipToContentLink.js +24 -46
  139. package/cjs/core/Slider/Slider.js +373 -236
  140. package/cjs/core/Slider/Thumb.d.ts +1 -1
  141. package/cjs/core/Slider/Thumb.js +118 -92
  142. package/cjs/core/Slider/Track.d.ts +1 -1
  143. package/cjs/core/Slider/Track.js +96 -86
  144. package/cjs/core/StatusMessage/StatusMessage.js +47 -50
  145. package/cjs/core/Stepper/Stepper.js +93 -51
  146. package/cjs/core/Stepper/StepperStep.js +111 -66
  147. package/cjs/core/Stepper/WorkflowDiagram.js +40 -45
  148. package/cjs/core/Stepper/WorkflowDiagramStep.d.ts +1 -1
  149. package/cjs/core/Stepper/WorkflowDiagramStep.js +38 -41
  150. package/cjs/core/Surface/Surface.js +99 -109
  151. package/cjs/core/Table/SubRowExpander.d.ts +1 -1
  152. package/cjs/core/Table/SubRowExpander.js +39 -40
  153. package/cjs/core/Table/Table.js +807 -502
  154. package/cjs/core/Table/TableCell.d.ts +1 -1
  155. package/cjs/core/Table/TableCell.js +109 -79
  156. package/cjs/core/Table/TablePaginator.d.ts +1 -2
  157. package/cjs/core/Table/TablePaginator.js +295 -171
  158. package/cjs/core/Table/TableRowMemoized.d.ts +10 -30
  159. package/cjs/core/Table/TableRowMemoized.js +155 -102
  160. package/cjs/core/Table/actionHandlers/expandHandler.d.ts +1 -1
  161. package/cjs/core/Table/actionHandlers/expandHandler.js +20 -14
  162. package/cjs/core/Table/actionHandlers/filterHandler.d.ts +1 -1
  163. package/cjs/core/Table/actionHandlers/filterHandler.js +33 -19
  164. package/cjs/core/Table/actionHandlers/index.js +38 -18
  165. package/cjs/core/Table/actionHandlers/resizeHandler.d.ts +18 -18
  166. package/cjs/core/Table/actionHandlers/resizeHandler.js +33 -16
  167. package/cjs/core/Table/actionHandlers/selectHandler.d.ts +12 -12
  168. package/cjs/core/Table/actionHandlers/selectHandler.js +136 -116
  169. package/cjs/core/Table/cells/DefaultCell.d.ts +1 -1
  170. package/cjs/core/Table/cells/DefaultCell.js +84 -62
  171. package/cjs/core/Table/cells/EditableCell.d.ts +1 -1
  172. package/cjs/core/Table/cells/EditableCell.js +91 -87
  173. package/cjs/core/Table/cells/index.js +21 -11
  174. package/cjs/core/Table/columns/actionColumn.d.ts +3 -3
  175. package/cjs/core/Table/columns/actionColumn.js +100 -113
  176. package/cjs/core/Table/columns/expanderColumn.d.ts +4 -4
  177. package/cjs/core/Table/columns/expanderColumn.js +61 -83
  178. package/cjs/core/Table/columns/index.js +31 -15
  179. package/cjs/core/Table/columns/selectionColumn.d.ts +5 -6
  180. package/cjs/core/Table/columns/selectionColumn.js +85 -77
  181. package/cjs/core/Table/filters/BaseFilter.d.ts +1 -1
  182. package/cjs/core/Table/filters/BaseFilter.js +26 -57
  183. package/cjs/core/Table/filters/DateRangeFilter/DatePickerInput.js +132 -79
  184. package/cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.d.ts +1 -1
  185. package/cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.js +131 -87
  186. package/cjs/core/Table/filters/FilterButtonBar.d.ts +1 -1
  187. package/cjs/core/Table/filters/FilterButtonBar.js +49 -51
  188. package/cjs/core/Table/filters/FilterToggle.d.ts +1 -2
  189. package/cjs/core/Table/filters/FilterToggle.js +68 -59
  190. package/cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.d.ts +1 -2
  191. package/cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +70 -63
  192. package/cjs/core/Table/filters/TextFilter/TextFilter.d.ts +1 -2
  193. package/cjs/core/Table/filters/TextFilter/TextFilter.js +48 -55
  194. package/cjs/core/Table/filters/customFilterFunctions.js +25 -26
  195. package/cjs/core/Table/filters/defaultFilterFunctions.d.ts +7 -7
  196. package/cjs/core/Table/filters/defaultFilterFunctions.js +94 -83
  197. package/cjs/core/Table/filters/index.js +29 -15
  198. package/cjs/core/Table/filters/tableFilters.d.ts +3 -3
  199. package/cjs/core/Table/filters/tableFilters.js +31 -59
  200. package/cjs/core/Table/filters/types.js +4 -2
  201. package/cjs/core/Table/hooks/index.js +45 -23
  202. package/cjs/core/Table/hooks/useColumnDragAndDrop.js +108 -90
  203. package/cjs/core/Table/hooks/useExpanderCell.d.ts +1 -1
  204. package/cjs/core/Table/hooks/useExpanderCell.js +39 -52
  205. package/cjs/core/Table/hooks/useResizeColumns.js +362 -299
  206. package/cjs/core/Table/hooks/useScrollToRow.js +50 -65
  207. package/cjs/core/Table/hooks/useSelectionCell.d.ts +1 -1
  208. package/cjs/core/Table/hooks/useSelectionCell.js +25 -12
  209. package/cjs/core/Table/hooks/useStickyColumns.js +71 -70
  210. package/cjs/core/Table/hooks/useSubRowFiltering.js +99 -115
  211. package/cjs/core/Table/hooks/useSubRowSelection.js +39 -58
  212. package/cjs/core/Table/index.js +48 -22
  213. package/cjs/core/Table/utils.d.ts +1 -1
  214. package/cjs/core/Table/utils.js +79 -86
  215. package/cjs/core/Tabs/Tabs.d.ts +3 -3
  216. package/cjs/core/Tabs/Tabs.js +403 -358
  217. package/cjs/core/Tag/Tag.js +75 -56
  218. package/cjs/core/Tag/TagContainer.js +30 -47
  219. package/cjs/core/Textarea/Textarea.js +20 -39
  220. package/cjs/core/ThemeProvider/ThemeContext.d.ts +3 -3
  221. package/cjs/core/ThemeProvider/ThemeContext.js +12 -31
  222. package/cjs/core/ThemeProvider/ThemeProvider.js +217 -215
  223. package/cjs/core/Tile/Tile.d.ts +11 -80
  224. package/cjs/core/Tile/Tile.js +312 -336
  225. package/cjs/core/TimePicker/TimePicker.js +479 -269
  226. package/cjs/core/Toast/Toast.d.ts +1 -1
  227. package/cjs/core/Toast/Toast.js +220 -151
  228. package/cjs/core/Toast/Toaster.d.ts +2 -2
  229. package/cjs/core/Toast/Toaster.js +145 -117
  230. package/cjs/core/ToggleSwitch/ToggleSwitch.js +71 -65
  231. package/cjs/core/Tooltip/Tooltip.d.ts +12 -11
  232. package/cjs/core/Tooltip/Tooltip.js +211 -175
  233. package/cjs/core/TransferList/TransferList.d.ts +4 -4
  234. package/cjs/core/TransferList/TransferList.js +174 -136
  235. package/cjs/core/Tree/Tree.d.ts +1 -2
  236. package/cjs/core/Tree/Tree.js +204 -213
  237. package/cjs/core/Tree/TreeContext.js +26 -37
  238. package/cjs/core/Tree/TreeNode.d.ts +11 -4
  239. package/cjs/core/Tree/TreeNode.js +258 -153
  240. package/cjs/core/Tree/TreeNodeExpander.js +39 -45
  241. package/cjs/core/Typography/Anchor.js +40 -58
  242. package/cjs/core/Typography/Blockquote.js +30 -48
  243. package/cjs/core/Typography/Code.js +12 -14
  244. package/cjs/core/Typography/Kbd.js +47 -61
  245. package/cjs/core/Typography/Text.js +49 -59
  246. package/cjs/core/VisuallyHidden/VisuallyHidden.js +44 -56
  247. package/cjs/index.d.ts +1 -0
  248. package/cjs/index.js +481 -233
  249. package/cjs/react-table/react-table.js +4 -9
  250. package/cjs/react-table/react-table.types-test.js +628 -0
  251. package/cjs/styles.d.ts +2 -1
  252. package/cjs/styles.js +17 -1
  253. package/cjs/utils/color/ColorValue.js +465 -485
  254. package/cjs/utils/color/index.js +6 -21
  255. package/cjs/utils/components/AutoclearingHiddenLiveRegion.d.ts +1 -2
  256. package/cjs/utils/components/AutoclearingHiddenLiveRegion.js +29 -48
  257. package/cjs/utils/components/Box.js +12 -14
  258. package/cjs/utils/components/ButtonBase.js +46 -51
  259. package/cjs/utils/components/FocusTrap.d.ts +1 -2
  260. package/cjs/utils/components/FocusTrap.js +55 -69
  261. package/cjs/utils/components/InputContainer.js +62 -55
  262. package/cjs/utils/components/InputFlexContainer.d.ts +2 -2
  263. package/cjs/utils/components/InputFlexContainer.js +65 -36
  264. package/cjs/utils/components/InputWithIcon.js +13 -11
  265. package/cjs/utils/components/LineClamp.d.ts +1 -1
  266. package/cjs/utils/components/LineClamp.js +32 -40
  267. package/cjs/utils/components/MiddleTextTruncation.d.ts +1 -1
  268. package/cjs/utils/components/MiddleTextTruncation.js +37 -65
  269. package/cjs/utils/components/Portal.d.ts +1 -1
  270. package/cjs/utils/components/Portal.js +43 -59
  271. package/cjs/utils/components/Resizer.d.ts +1 -1
  272. package/cjs/utils/components/Resizer.js +243 -192
  273. package/cjs/utils/components/ShadowRoot.d.ts +1 -1
  274. package/cjs/utils/components/ShadowRoot.js +96 -108
  275. package/cjs/utils/components/VirtualScroll.js +315 -292
  276. package/cjs/utils/components/WithCSSTransition.d.ts +2 -2
  277. package/cjs/utils/components/WithCSSTransition.js +54 -62
  278. package/cjs/utils/components/index.js +19 -34
  279. package/cjs/utils/functions/colors.d.ts +1 -1
  280. package/cjs/utils/functions/colors.js +43 -35
  281. package/cjs/utils/functions/date.js +18 -19
  282. package/cjs/utils/functions/dev.js +37 -34
  283. package/cjs/utils/functions/dom.d.ts +1 -1
  284. package/cjs/utils/functions/dom.js +46 -44
  285. package/cjs/utils/functions/focusable.d.ts +23 -0
  286. package/cjs/utils/functions/focusable.js +91 -30
  287. package/cjs/utils/functions/import.js +29 -32
  288. package/cjs/utils/functions/index.js +15 -30
  289. package/cjs/utils/functions/numbers.js +31 -31
  290. package/cjs/utils/functions/polymorphic.d.ts +3 -180
  291. package/cjs/utils/functions/polymorphic.js +62 -95
  292. package/cjs/utils/functions/react.js +29 -56
  293. package/cjs/utils/functions/supports.js +13 -13
  294. package/cjs/utils/hooks/index.js +20 -35
  295. package/cjs/utils/hooks/useContainerWidth.js +34 -61
  296. package/cjs/utils/hooks/useControlledState.d.ts +1 -1
  297. package/cjs/utils/hooks/useControlledState.js +30 -50
  298. package/cjs/utils/hooks/useDragAndDrop.js +122 -122
  299. package/cjs/utils/hooks/useEventListener.js +25 -58
  300. package/cjs/utils/hooks/useGlobals.d.ts +3 -3
  301. package/cjs/utils/hooks/useGlobals.js +49 -65
  302. package/cjs/utils/hooks/useId.js +18 -42
  303. package/cjs/utils/hooks/useIntersection.js +41 -63
  304. package/cjs/utils/hooks/useIsClient.js +16 -36
  305. package/cjs/utils/hooks/useIsomorphicLayoutEffect.js +13 -39
  306. package/cjs/utils/hooks/useLatestRef.js +16 -43
  307. package/cjs/utils/hooks/useMediaQuery.js +30 -43
  308. package/cjs/utils/hooks/useMergedRefs.d.ts +2 -2
  309. package/cjs/utils/hooks/useMergedRefs.js +30 -50
  310. package/cjs/utils/hooks/useOverflow.d.ts +1 -1
  311. package/cjs/utils/hooks/useOverflow.js +70 -107
  312. package/cjs/utils/hooks/useResizeObserver.js +35 -67
  313. package/cjs/utils/hooks/useSafeContext.js +16 -40
  314. package/cjs/utils/hooks/useSyncExternalStore.js +42 -65
  315. package/cjs/utils/icons/StatusIconMap.d.ts +4 -5
  316. package/cjs/utils/icons/StatusIconMap.js +35 -39
  317. package/cjs/utils/icons/Svg.js +15 -12
  318. package/cjs/utils/icons/SvgCalendar.d.ts +1 -1
  319. package/cjs/utils/icons/SvgCalendar.js +19 -34
  320. package/cjs/utils/icons/SvgCaretDownSmall.d.ts +1 -1
  321. package/cjs/utils/icons/SvgCaretDownSmall.js +19 -34
  322. package/cjs/utils/icons/SvgCaretRightSmall.d.ts +1 -1
  323. package/cjs/utils/icons/SvgCaretRightSmall.js +19 -34
  324. package/cjs/utils/icons/SvgCaretUpSmall.d.ts +1 -1
  325. package/cjs/utils/icons/SvgCaretUpSmall.js +19 -34
  326. package/cjs/utils/icons/SvgCheckmark.d.ts +1 -1
  327. package/cjs/utils/icons/SvgCheckmark.js +19 -34
  328. package/cjs/utils/icons/SvgCheckmarkSmall.d.ts +1 -1
  329. package/cjs/utils/icons/SvgCheckmarkSmall.js +19 -34
  330. package/cjs/utils/icons/SvgChevronLeft.d.ts +1 -1
  331. package/cjs/utils/icons/SvgChevronLeft.js +19 -34
  332. package/cjs/utils/icons/SvgChevronLeftDouble.d.ts +1 -1
  333. package/cjs/utils/icons/SvgChevronLeftDouble.js +19 -34
  334. package/cjs/utils/icons/SvgChevronRight.d.ts +1 -1
  335. package/cjs/utils/icons/SvgChevronRight.js +19 -34
  336. package/cjs/utils/icons/SvgChevronRightDouble.d.ts +1 -1
  337. package/cjs/utils/icons/SvgChevronRightDouble.js +19 -34
  338. package/cjs/utils/icons/SvgChevronRightSmall.d.ts +1 -1
  339. package/cjs/utils/icons/SvgChevronRightSmall.js +19 -34
  340. package/cjs/utils/icons/SvgClose.d.ts +1 -1
  341. package/cjs/utils/icons/SvgClose.js +19 -34
  342. package/cjs/utils/icons/SvgCloseSmall.d.ts +1 -1
  343. package/cjs/utils/icons/SvgCloseSmall.js +19 -34
  344. package/cjs/utils/icons/SvgColumnManager.d.ts +1 -1
  345. package/cjs/utils/icons/SvgColumnManager.js +19 -34
  346. package/cjs/utils/icons/SvgDocument.d.ts +1 -1
  347. package/cjs/utils/icons/SvgDocument.js +19 -34
  348. package/cjs/utils/icons/SvgFilter.d.ts +1 -1
  349. package/cjs/utils/icons/SvgFilter.js +19 -34
  350. package/cjs/utils/icons/SvgFilterHollow.d.ts +1 -1
  351. package/cjs/utils/icons/SvgFilterHollow.js +19 -34
  352. package/cjs/utils/icons/SvgImportantSmall.d.ts +1 -1
  353. package/cjs/utils/icons/SvgImportantSmall.js +19 -34
  354. package/cjs/utils/icons/SvgInfoCircular.d.ts +1 -1
  355. package/cjs/utils/icons/SvgInfoCircular.js +19 -34
  356. package/cjs/utils/icons/SvgMore.d.ts +1 -1
  357. package/cjs/utils/icons/SvgMore.js +19 -34
  358. package/cjs/utils/icons/SvgMoreVertical.d.ts +1 -1
  359. package/cjs/utils/icons/SvgMoreVertical.js +19 -34
  360. package/cjs/utils/icons/SvgNew.d.ts +1 -1
  361. package/cjs/utils/icons/SvgNew.js +19 -34
  362. package/cjs/utils/icons/SvgSearch.d.ts +1 -1
  363. package/cjs/utils/icons/SvgSearch.js +19 -34
  364. package/cjs/utils/icons/SvgSmileyHappy.d.ts +1 -1
  365. package/cjs/utils/icons/SvgSmileyHappy.js +19 -34
  366. package/cjs/utils/icons/SvgSortDown.d.ts +1 -1
  367. package/cjs/utils/icons/SvgSortDown.js +19 -34
  368. package/cjs/utils/icons/SvgSortUp.d.ts +1 -1
  369. package/cjs/utils/icons/SvgSortUp.js +19 -34
  370. package/cjs/utils/icons/SvgStatusError.d.ts +1 -1
  371. package/cjs/utils/icons/SvgStatusError.js +19 -34
  372. package/cjs/utils/icons/SvgStatusSuccess.d.ts +1 -1
  373. package/cjs/utils/icons/SvgStatusSuccess.js +19 -34
  374. package/cjs/utils/icons/SvgStatusWarning.d.ts +1 -1
  375. package/cjs/utils/icons/SvgStatusWarning.js +19 -34
  376. package/cjs/utils/icons/SvgSwap.d.ts +1 -1
  377. package/cjs/utils/icons/SvgSwap.js +19 -34
  378. package/cjs/utils/icons/SvgUpload.d.ts +1 -1
  379. package/cjs/utils/icons/SvgUpload.js +19 -34
  380. package/cjs/utils/icons/index.js +37 -52
  381. package/cjs/utils/index.js +13 -28
  382. package/cjs/utils/meta.d.ts +7 -0
  383. package/cjs/utils/meta.js +16 -0
  384. package/cjs/utils/props.js +4 -2
  385. package/cjs/utils/providers/HydrationProvider.d.ts +1 -1
  386. package/cjs/utils/providers/HydrationProvider.js +55 -68
  387. package/cjs/utils/providers/ScopeProvider.d.ts +1 -1
  388. package/cjs/utils/providers/ScopeProvider.js +58 -71
  389. package/cjs/utils/providers/index.js +7 -22
  390. package/cjs/utils/types.js +4 -2
  391. package/esm/core/Alert/Alert.d.ts +3 -7
  392. package/esm/core/Alert/Alert.js +96 -80
  393. package/esm/core/Avatar/Avatar.js +47 -36
  394. package/esm/core/AvatarGroup/AvatarGroup.js +59 -50
  395. package/esm/core/Backdrop/Backdrop.js +13 -6
  396. package/esm/core/Badge/Badge.js +30 -33
  397. package/esm/core/Breadcrumbs/Breadcrumbs.js +146 -93
  398. package/esm/core/ButtonGroup/ButtonGroup.js +123 -72
  399. package/esm/core/Buttons/Button.js +63 -22
  400. package/esm/core/Buttons/DropdownButton.js +36 -20
  401. package/esm/core/Buttons/IconButton.js +48 -17
  402. package/esm/core/Buttons/IdeasButton.js +13 -11
  403. package/esm/core/Buttons/SplitButton.js +82 -53
  404. package/esm/core/Carousel/Carousel.d.ts +13 -119
  405. package/esm/core/Carousel/Carousel.js +53 -64
  406. package/esm/core/Carousel/CarouselContext.js +0 -4
  407. package/esm/core/Carousel/CarouselDot.js +18 -14
  408. package/esm/core/Carousel/CarouselDotsList.js +146 -111
  409. package/esm/core/Carousel/CarouselNavigation.d.ts +6 -112
  410. package/esm/core/Carousel/CarouselNavigation.js +72 -45
  411. package/esm/core/Carousel/CarouselSlide.js +40 -30
  412. package/esm/core/Carousel/CarouselSlider.d.ts +1 -1
  413. package/esm/core/Carousel/CarouselSlider.js +62 -48
  414. package/esm/core/Checkbox/Checkbox.js +77 -39
  415. package/esm/core/ColorPicker/ColorBuilder.d.ts +1 -1
  416. package/esm/core/ColorPicker/ColorBuilder.js +284 -176
  417. package/esm/core/ColorPicker/ColorInputPanel.js +428 -252
  418. package/esm/core/ColorPicker/ColorPalette.js +39 -30
  419. package/esm/core/ColorPicker/ColorPicker.js +70 -63
  420. package/esm/core/ColorPicker/ColorPickerContext.d.ts +2 -2
  421. package/esm/core/ColorPicker/ColorPickerContext.js +7 -9
  422. package/esm/core/ColorPicker/ColorSwatch.js +32 -18
  423. package/esm/core/ComboBox/ComboBox.d.ts +13 -3
  424. package/esm/core/ComboBox/ComboBox.js +397 -284
  425. package/esm/core/ComboBox/ComboBox.test-types.js +87 -0
  426. package/esm/core/ComboBox/ComboBoxEndIcon.js +20 -9
  427. package/esm/core/ComboBox/ComboBoxInput.js +198 -142
  428. package/esm/core/ComboBox/ComboBoxInputContainer.js +30 -10
  429. package/esm/core/ComboBox/ComboBoxMenu.d.ts +1 -1
  430. package/esm/core/ComboBox/ComboBoxMenu.js +76 -43
  431. package/esm/core/ComboBox/ComboBoxMenuItem.js +69 -17
  432. package/esm/core/ComboBox/ComboBoxMultipleContainer.js +7 -6
  433. package/esm/core/ComboBox/helpers.d.ts +4 -27
  434. package/esm/core/ComboBox/helpers.js +0 -47
  435. package/esm/core/DatePicker/DatePicker.js +547 -341
  436. package/esm/core/Dialog/Dialog.js +58 -51
  437. package/esm/core/Dialog/DialogBackdrop.js +41 -29
  438. package/esm/core/Dialog/DialogButtonBar.js +0 -12
  439. package/esm/core/Dialog/DialogContent.js +0 -11
  440. package/esm/core/Dialog/DialogContext.js +1 -5
  441. package/esm/core/Dialog/DialogDragContext.d.ts +1 -1
  442. package/esm/core/Dialog/DialogDragContext.js +4 -8
  443. package/esm/core/Dialog/DialogMain.js +182 -127
  444. package/esm/core/Dialog/DialogTitleBar.js +47 -31
  445. package/esm/core/Dialog/DialogTitleBarTitle.js +0 -9
  446. package/esm/core/Divider/Divider.js +9 -9
  447. package/esm/core/DropdownMenu/DropdownMenu.d.ts +1 -1
  448. package/esm/core/DropdownMenu/DropdownMenu.js +52 -82
  449. package/esm/core/ExpandableBlock/ExpandableBlock.d.ts +3 -3
  450. package/esm/core/ExpandableBlock/ExpandableBlock.js +170 -134
  451. package/esm/core/Fieldset/Fieldset.js +24 -23
  452. package/esm/core/FileUpload/FileEmptyCard.js +31 -35
  453. package/esm/core/FileUpload/FileUpload.js +61 -44
  454. package/esm/core/FileUpload/FileUploadCard.d.ts +2 -2
  455. package/esm/core/FileUpload/FileUploadCard.js +156 -119
  456. package/esm/core/FileUpload/FileUploadTemplate.js +45 -21
  457. package/esm/core/Flex/Flex.js +64 -111
  458. package/esm/core/Footer/Footer.d.ts +1 -1
  459. package/esm/core/Footer/Footer.js +89 -73
  460. package/esm/core/Footer/FooterItem.js +0 -7
  461. package/esm/core/Footer/FooterList.js +0 -7
  462. package/esm/core/Footer/FooterSeparator.js +1 -8
  463. package/esm/core/Header/Header.js +59 -45
  464. package/esm/core/Header/HeaderBasicButton.js +11 -11
  465. package/esm/core/Header/HeaderBreadcrumbs.js +37 -22
  466. package/esm/core/Header/HeaderButton.js +64 -28
  467. package/esm/core/Header/HeaderDropdownButton.js +39 -17
  468. package/esm/core/Header/HeaderLogo.js +33 -16
  469. package/esm/core/Header/HeaderSplitButton.js +58 -18
  470. package/esm/core/Icon/Icon.js +27 -30
  471. package/esm/core/InformationPanel/InformationPanel.js +90 -66
  472. package/esm/core/InformationPanel/InformationPanelBody.js +0 -7
  473. package/esm/core/InformationPanel/InformationPanelContent.js +17 -30
  474. package/esm/core/InformationPanel/InformationPanelHeader.js +31 -27
  475. package/esm/core/InformationPanel/InformationPanelWrapper.js +3 -14
  476. package/esm/core/Input/Input.js +13 -14
  477. package/esm/core/InputGrid/InputGrid.js +143 -165
  478. package/esm/core/InputGroup/InputGroup.js +63 -40
  479. package/esm/core/InputWithDecorations/InputWithDecorations.d.ts +2 -2
  480. package/esm/core/InputWithDecorations/InputWithDecorations.js +50 -49
  481. package/esm/core/Label/Label.js +24 -16
  482. package/esm/core/LabeledInput/LabeledInput.js +59 -21
  483. package/esm/core/LabeledSelect/LabeledSelect.d.ts +3 -389
  484. package/esm/core/LabeledSelect/LabeledSelect.js +52 -43
  485. package/esm/core/LabeledSelect/LabeledSelect.types-test.js +95 -0
  486. package/esm/core/LabeledTextarea/LabeledTextarea.js +7 -32
  487. package/esm/core/LinkAction/LinkAction.d.ts +1 -1
  488. package/esm/core/LinkAction/LinkAction.js +8 -27
  489. package/esm/core/List/List.js +3 -5
  490. package/esm/core/List/ListItem.d.ts +3 -3
  491. package/esm/core/List/ListItem.js +25 -61
  492. package/esm/core/Menu/Menu.d.ts +80 -6
  493. package/esm/core/Menu/Menu.js +201 -61
  494. package/esm/core/Menu/MenuDivider.d.ts +1 -1
  495. package/esm/core/Menu/MenuDivider.js +1 -20
  496. package/esm/core/Menu/MenuExtraContent.js +1 -25
  497. package/esm/core/Menu/MenuItem.d.ts +0 -8
  498. package/esm/core/Menu/MenuItem.js +128 -145
  499. package/esm/core/Menu/MenuItemSkeleton.js +49 -19
  500. package/esm/core/Modal/Modal.js +44 -31
  501. package/esm/core/Modal/ModalButtonBar.js +0 -7
  502. package/esm/core/Modal/ModalContent.js +0 -7
  503. package/esm/core/NonIdealState/ErrorPage.js +174 -134
  504. package/esm/core/NonIdealState/NonIdealState.js +53 -17
  505. package/esm/core/NotificationMarker/NotificationMarker.js +23 -18
  506. package/esm/core/Overlay/Overlay.d.ts +3 -3
  507. package/esm/core/Overlay/Overlay.js +37 -63
  508. package/esm/core/Popover/Popover.d.ts +23 -30
  509. package/esm/core/Popover/Popover.js +263 -156
  510. package/esm/core/ProgressIndicators/ProgressLinear.js +52 -36
  511. package/esm/core/ProgressIndicators/ProgressRadial.js +56 -38
  512. package/esm/core/Radio/Radio.js +46 -21
  513. package/esm/core/RadioTiles/RadioTile.js +53 -17
  514. package/esm/core/RadioTiles/RadioTileGroup.js +11 -15
  515. package/esm/core/SearchBox/SearchBox.d.ts +2 -2
  516. package/esm/core/SearchBox/SearchBox.js +189 -128
  517. package/esm/core/Select/Select.d.ts +1 -1
  518. package/esm/core/Select/Select.js +431 -260
  519. package/esm/core/Select/Select.types-test.js +112 -0
  520. package/esm/core/Select/SelectTag.js +13 -11
  521. package/esm/core/Select/SelectTagContainer.js +22 -13
  522. package/esm/core/SideNavigation/SideNavigation.js +87 -39
  523. package/esm/core/SideNavigation/SidenavButton.js +33 -12
  524. package/esm/core/SideNavigation/SidenavSubmenu.d.ts +1 -1
  525. package/esm/core/SideNavigation/SidenavSubmenu.js +11 -15
  526. package/esm/core/SideNavigation/SidenavSubmenuHeader.js +18 -22
  527. package/esm/core/SkipToContentLink/SkipToContentLink.js +9 -14
  528. package/esm/core/Slider/Slider.js +333 -202
  529. package/esm/core/Slider/Thumb.d.ts +1 -1
  530. package/esm/core/Slider/Thumb.js +103 -59
  531. package/esm/core/Slider/Track.d.ts +1 -1
  532. package/esm/core/Slider/Track.js +79 -54
  533. package/esm/core/StatusMessage/StatusMessage.js +31 -17
  534. package/esm/core/Stepper/Stepper.js +74 -18
  535. package/esm/core/Stepper/StepperStep.js +89 -33
  536. package/esm/core/Stepper/WorkflowDiagram.js +25 -13
  537. package/esm/core/Stepper/WorkflowDiagramStep.d.ts +1 -1
  538. package/esm/core/Stepper/WorkflowDiagramStep.js +20 -8
  539. package/esm/core/Surface/Surface.js +81 -74
  540. package/esm/core/Table/SubRowExpander.d.ts +1 -1
  541. package/esm/core/Table/SubRowExpander.js +26 -11
  542. package/esm/core/Table/Table.js +811 -463
  543. package/esm/core/Table/TableCell.d.ts +1 -1
  544. package/esm/core/Table/TableCell.js +88 -43
  545. package/esm/core/Table/TablePaginator.d.ts +1 -2
  546. package/esm/core/Table/TablePaginator.js +289 -135
  547. package/esm/core/Table/TableRowMemoized.d.ts +10 -30
  548. package/esm/core/Table/TableRowMemoized.js +134 -70
  549. package/esm/core/Table/actionHandlers/expandHandler.d.ts +1 -1
  550. package/esm/core/Table/actionHandlers/expandHandler.js +10 -10
  551. package/esm/core/Table/actionHandlers/filterHandler.d.ts +1 -1
  552. package/esm/core/Table/actionHandlers/filterHandler.js +23 -15
  553. package/esm/core/Table/actionHandlers/index.js +5 -5
  554. package/esm/core/Table/actionHandlers/resizeHandler.d.ts +18 -18
  555. package/esm/core/Table/actionHandlers/resizeHandler.js +14 -11
  556. package/esm/core/Table/actionHandlers/selectHandler.d.ts +12 -12
  557. package/esm/core/Table/actionHandlers/selectHandler.js +114 -110
  558. package/esm/core/Table/cells/DefaultCell.d.ts +1 -1
  559. package/esm/core/Table/cells/DefaultCell.js +69 -29
  560. package/esm/core/Table/cells/EditableCell.d.ts +1 -1
  561. package/esm/core/Table/cells/EditableCell.js +78 -55
  562. package/esm/core/Table/cells/index.js +0 -4
  563. package/esm/core/Table/columns/actionColumn.d.ts +3 -3
  564. package/esm/core/Table/columns/actionColumn.js +81 -78
  565. package/esm/core/Table/columns/expanderColumn.d.ts +4 -4
  566. package/esm/core/Table/columns/expanderColumn.js +37 -52
  567. package/esm/core/Table/columns/index.js +0 -4
  568. package/esm/core/Table/columns/selectionColumn.d.ts +5 -6
  569. package/esm/core/Table/columns/selectionColumn.js +64 -48
  570. package/esm/core/Table/filters/BaseFilter.d.ts +1 -1
  571. package/esm/core/Table/filters/BaseFilter.js +12 -25
  572. package/esm/core/Table/filters/DateRangeFilter/DatePickerInput.js +108 -46
  573. package/esm/core/Table/filters/DateRangeFilter/DateRangeFilter.d.ts +1 -1
  574. package/esm/core/Table/filters/DateRangeFilter/DateRangeFilter.js +116 -56
  575. package/esm/core/Table/filters/FilterButtonBar.d.ts +1 -1
  576. package/esm/core/Table/filters/FilterButtonBar.js +34 -18
  577. package/esm/core/Table/filters/FilterToggle.d.ts +1 -2
  578. package/esm/core/Table/filters/FilterToggle.js +54 -26
  579. package/esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.d.ts +1 -2
  580. package/esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +55 -32
  581. package/esm/core/Table/filters/TextFilter/TextFilter.d.ts +1 -2
  582. package/esm/core/Table/filters/TextFilter/TextFilter.js +33 -24
  583. package/esm/core/Table/filters/customFilterFunctions.js +14 -22
  584. package/esm/core/Table/filters/defaultFilterFunctions.d.ts +7 -7
  585. package/esm/core/Table/filters/defaultFilterFunctions.js +83 -79
  586. package/esm/core/Table/filters/index.js +0 -4
  587. package/esm/core/Table/filters/tableFilters.d.ts +3 -3
  588. package/esm/core/Table/filters/tableFilters.js +16 -29
  589. package/esm/core/Table/hooks/index.js +0 -4
  590. package/esm/core/Table/hooks/useColumnDragAndDrop.js +89 -82
  591. package/esm/core/Table/hooks/useExpanderCell.d.ts +1 -1
  592. package/esm/core/Table/hooks/useExpanderCell.js +25 -24
  593. package/esm/core/Table/hooks/useResizeColumns.js +346 -292
  594. package/esm/core/Table/hooks/useScrollToRow.js +39 -38
  595. package/esm/core/Table/hooks/useSelectionCell.d.ts +1 -1
  596. package/esm/core/Table/hooks/useSelectionCell.js +14 -7
  597. package/esm/core/Table/hooks/useStickyColumns.js +58 -63
  598. package/esm/core/Table/hooks/useSubRowFiltering.js +87 -87
  599. package/esm/core/Table/hooks/useSubRowSelection.js +28 -31
  600. package/esm/core/Table/index.js +5 -5
  601. package/esm/core/Table/utils.d.ts +1 -1
  602. package/esm/core/Table/utils.js +55 -59
  603. package/esm/core/Tabs/Tabs.d.ts +3 -3
  604. package/esm/core/Tabs/Tabs.js +371 -315
  605. package/esm/core/Tag/Tag.js +48 -22
  606. package/esm/core/Tag/TagContainer.js +15 -15
  607. package/esm/core/Textarea/Textarea.js +7 -11
  608. package/esm/core/ThemeProvider/ThemeContext.d.ts +3 -3
  609. package/esm/core/ThemeProvider/ThemeContext.js +0 -4
  610. package/esm/core/ThemeProvider/ThemeProvider.js +199 -174
  611. package/esm/core/Tile/Tile.d.ts +11 -80
  612. package/esm/core/Tile/Tile.js +274 -283
  613. package/esm/core/TimePicker/TimePicker.js +468 -237
  614. package/esm/core/Toast/Toast.d.ts +1 -1
  615. package/esm/core/Toast/Toast.js +190 -116
  616. package/esm/core/Toast/Toaster.d.ts +2 -2
  617. package/esm/core/Toast/Toaster.js +109 -79
  618. package/esm/core/ToggleSwitch/ToggleSwitch.js +53 -33
  619. package/esm/core/Tooltip/Tooltip.d.ts +12 -11
  620. package/esm/core/Tooltip/Tooltip.js +220 -144
  621. package/esm/core/TransferList/TransferList.d.ts +4 -4
  622. package/esm/core/TransferList/TransferList.js +138 -118
  623. package/esm/core/Tree/Tree.d.ts +1 -2
  624. package/esm/core/Tree/Tree.js +193 -179
  625. package/esm/core/Tree/TreeContext.js +5 -9
  626. package/esm/core/Tree/TreeNode.d.ts +11 -4
  627. package/esm/core/Tree/TreeNode.js +234 -119
  628. package/esm/core/Tree/TreeNodeExpander.js +21 -11
  629. package/esm/core/Typography/Anchor.js +23 -24
  630. package/esm/core/Typography/Blockquote.js +15 -16
  631. package/esm/core/Typography/Code.js +0 -9
  632. package/esm/core/Typography/Kbd.js +22 -28
  633. package/esm/core/Typography/Text.js +24 -26
  634. package/esm/core/VisuallyHidden/VisuallyHidden.js +33 -24
  635. package/esm/index.d.ts +1 -0
  636. package/esm/index.js +22 -7
  637. package/esm/react-table/react-table.js +0 -7
  638. package/esm/react-table/react-table.types-test.js +641 -0
  639. package/esm/styles.d.ts +2 -1
  640. package/esm/styles.js +8 -9
  641. package/esm/utils/color/ColorValue.js +436 -477
  642. package/esm/utils/color/index.js +0 -4
  643. package/esm/utils/components/AutoclearingHiddenLiveRegion.d.ts +1 -2
  644. package/esm/utils/components/AutoclearingHiddenLiveRegion.js +13 -19
  645. package/esm/utils/components/Box.js +0 -9
  646. package/esm/utils/components/ButtonBase.js +29 -17
  647. package/esm/utils/components/FocusTrap.d.ts +1 -2
  648. package/esm/utils/components/FocusTrap.js +46 -40
  649. package/esm/utils/components/InputContainer.js +45 -21
  650. package/esm/utils/components/InputFlexContainer.d.ts +2 -2
  651. package/esm/utils/components/InputFlexContainer.js +28 -23
  652. package/esm/utils/components/InputWithIcon.js +0 -5
  653. package/esm/utils/components/LineClamp.d.ts +1 -1
  654. package/esm/utils/components/LineClamp.js +18 -11
  655. package/esm/utils/components/MiddleTextTruncation.d.ts +1 -1
  656. package/esm/utils/components/MiddleTextTruncation.js +25 -37
  657. package/esm/utils/components/Portal.d.ts +1 -1
  658. package/esm/utils/components/Portal.js +13 -31
  659. package/esm/utils/components/Resizer.d.ts +1 -1
  660. package/esm/utils/components/Resizer.js +239 -165
  661. package/esm/utils/components/ShadowRoot.d.ts +1 -1
  662. package/esm/utils/components/ShadowRoot.js +86 -78
  663. package/esm/utils/components/VirtualScroll.js +297 -263
  664. package/esm/utils/components/WithCSSTransition.d.ts +2 -2
  665. package/esm/utils/components/WithCSSTransition.js +42 -31
  666. package/esm/utils/components/index.js +0 -4
  667. package/esm/utils/functions/colors.d.ts +1 -1
  668. package/esm/utils/functions/colors.js +19 -28
  669. package/esm/utils/functions/date.js +8 -15
  670. package/esm/utils/functions/dev.js +15 -28
  671. package/esm/utils/functions/dom.d.ts +1 -1
  672. package/esm/utils/functions/dom.js +18 -36
  673. package/esm/utils/functions/focusable.d.ts +23 -0
  674. package/esm/utils/functions/focusable.js +68 -25
  675. package/esm/utils/functions/import.js +19 -28
  676. package/esm/utils/functions/index.js +0 -4
  677. package/esm/utils/functions/numbers.js +9 -25
  678. package/esm/utils/functions/polymorphic.d.ts +3 -180
  679. package/esm/utils/functions/polymorphic.js +43 -63
  680. package/esm/utils/functions/react.js +17 -28
  681. package/esm/utils/functions/supports.js +2 -8
  682. package/esm/utils/hooks/index.js +0 -4
  683. package/esm/utils/hooks/useContainerWidth.js +16 -32
  684. package/esm/utils/hooks/useControlledState.d.ts +1 -1
  685. package/esm/utils/hooks/useControlledState.js +19 -23
  686. package/esm/utils/hooks/useDragAndDrop.js +109 -93
  687. package/esm/utils/hooks/useEventListener.js +14 -31
  688. package/esm/utils/hooks/useGlobals.d.ts +3 -3
  689. package/esm/utils/hooks/useGlobals.js +27 -35
  690. package/esm/utils/hooks/useId.js +4 -13
  691. package/esm/utils/hooks/useIntersection.js +29 -35
  692. package/esm/utils/hooks/useIsClient.js +5 -9
  693. package/esm/utils/hooks/useIsomorphicLayoutEffect.js +2 -12
  694. package/esm/utils/hooks/useLatestRef.js +5 -16
  695. package/esm/utils/hooks/useMediaQuery.js +14 -15
  696. package/esm/utils/hooks/useMergedRefs.d.ts +2 -2
  697. package/esm/utils/hooks/useMergedRefs.js +10 -22
  698. package/esm/utils/hooks/useOverflow.d.ts +1 -1
  699. package/esm/utils/hooks/useOverflow.js +59 -78
  700. package/esm/utils/hooks/useResizeObserver.js +23 -39
  701. package/esm/utils/hooks/useSafeContext.js +5 -13
  702. package/esm/utils/hooks/useSyncExternalStore.js +31 -39
  703. package/esm/utils/icons/StatusIconMap.d.ts +4 -5
  704. package/esm/utils/icons/StatusIconMap.js +21 -9
  705. package/esm/utils/icons/Svg.js +3 -7
  706. package/esm/utils/icons/SvgCalendar.d.ts +1 -1
  707. package/esm/utils/icons/SvgCalendar.js +7 -6
  708. package/esm/utils/icons/SvgCaretDownSmall.d.ts +1 -1
  709. package/esm/utils/icons/SvgCaretDownSmall.js +7 -6
  710. package/esm/utils/icons/SvgCaretRightSmall.d.ts +1 -1
  711. package/esm/utils/icons/SvgCaretRightSmall.js +7 -6
  712. package/esm/utils/icons/SvgCaretUpSmall.d.ts +1 -1
  713. package/esm/utils/icons/SvgCaretUpSmall.js +7 -6
  714. package/esm/utils/icons/SvgCheckmark.d.ts +1 -1
  715. package/esm/utils/icons/SvgCheckmark.js +7 -6
  716. package/esm/utils/icons/SvgCheckmarkSmall.d.ts +1 -1
  717. package/esm/utils/icons/SvgCheckmarkSmall.js +7 -6
  718. package/esm/utils/icons/SvgChevronLeft.d.ts +1 -1
  719. package/esm/utils/icons/SvgChevronLeft.js +7 -6
  720. package/esm/utils/icons/SvgChevronLeftDouble.d.ts +1 -1
  721. package/esm/utils/icons/SvgChevronLeftDouble.js +7 -6
  722. package/esm/utils/icons/SvgChevronRight.d.ts +1 -1
  723. package/esm/utils/icons/SvgChevronRight.js +7 -6
  724. package/esm/utils/icons/SvgChevronRightDouble.d.ts +1 -1
  725. package/esm/utils/icons/SvgChevronRightDouble.js +7 -6
  726. package/esm/utils/icons/SvgChevronRightSmall.d.ts +1 -1
  727. package/esm/utils/icons/SvgChevronRightSmall.js +7 -6
  728. package/esm/utils/icons/SvgClose.d.ts +1 -1
  729. package/esm/utils/icons/SvgClose.js +7 -6
  730. package/esm/utils/icons/SvgCloseSmall.d.ts +1 -1
  731. package/esm/utils/icons/SvgCloseSmall.js +7 -6
  732. package/esm/utils/icons/SvgColumnManager.d.ts +1 -1
  733. package/esm/utils/icons/SvgColumnManager.js +7 -6
  734. package/esm/utils/icons/SvgDocument.d.ts +1 -1
  735. package/esm/utils/icons/SvgDocument.js +7 -6
  736. package/esm/utils/icons/SvgFilter.d.ts +1 -1
  737. package/esm/utils/icons/SvgFilter.js +7 -6
  738. package/esm/utils/icons/SvgFilterHollow.d.ts +1 -1
  739. package/esm/utils/icons/SvgFilterHollow.js +7 -6
  740. package/esm/utils/icons/SvgImportantSmall.d.ts +1 -1
  741. package/esm/utils/icons/SvgImportantSmall.js +7 -6
  742. package/esm/utils/icons/SvgInfoCircular.d.ts +1 -1
  743. package/esm/utils/icons/SvgInfoCircular.js +7 -6
  744. package/esm/utils/icons/SvgMore.d.ts +1 -1
  745. package/esm/utils/icons/SvgMore.js +7 -6
  746. package/esm/utils/icons/SvgMoreVertical.d.ts +1 -1
  747. package/esm/utils/icons/SvgMoreVertical.js +7 -6
  748. package/esm/utils/icons/SvgNew.d.ts +1 -1
  749. package/esm/utils/icons/SvgNew.js +7 -6
  750. package/esm/utils/icons/SvgSearch.d.ts +1 -1
  751. package/esm/utils/icons/SvgSearch.js +7 -6
  752. package/esm/utils/icons/SvgSmileyHappy.d.ts +1 -1
  753. package/esm/utils/icons/SvgSmileyHappy.js +7 -6
  754. package/esm/utils/icons/SvgSortDown.d.ts +1 -1
  755. package/esm/utils/icons/SvgSortDown.js +7 -6
  756. package/esm/utils/icons/SvgSortUp.d.ts +1 -1
  757. package/esm/utils/icons/SvgSortUp.js +7 -6
  758. package/esm/utils/icons/SvgStatusError.d.ts +1 -1
  759. package/esm/utils/icons/SvgStatusError.js +7 -6
  760. package/esm/utils/icons/SvgStatusSuccess.d.ts +1 -1
  761. package/esm/utils/icons/SvgStatusSuccess.js +7 -6
  762. package/esm/utils/icons/SvgStatusWarning.d.ts +1 -1
  763. package/esm/utils/icons/SvgStatusWarning.js +7 -6
  764. package/esm/utils/icons/SvgSwap.d.ts +1 -1
  765. package/esm/utils/icons/SvgSwap.js +7 -6
  766. package/esm/utils/icons/SvgUpload.d.ts +1 -1
  767. package/esm/utils/icons/SvgUpload.js +7 -6
  768. package/esm/utils/icons/index.js +0 -4
  769. package/esm/utils/index.js +0 -4
  770. package/esm/utils/meta.d.ts +7 -0
  771. package/esm/utils/meta.js +6 -0
  772. package/esm/utils/providers/HydrationProvider.d.ts +1 -1
  773. package/esm/utils/providers/HydrationProvider.js +33 -38
  774. package/esm/utils/providers/ScopeProvider.d.ts +1 -1
  775. package/esm/utils/providers/ScopeProvider.js +33 -40
  776. package/esm/utils/providers/index.js +0 -4
  777. package/package.json +22 -16
  778. package/styles.css +1 -1
  779. package/react-table.d.ts +0 -750
@@ -1,60 +1,22 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
1
+ 'use strict';
2
+ Object.defineProperty(exports, '__esModule', {
3
+ value: true,
17
4
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.LabeledTextarea = void 0;
27
- /*---------------------------------------------------------------------------------------------
28
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
29
- * See LICENSE.md in the project root for license terms and full copyright notice.
30
- *--------------------------------------------------------------------------------------------*/
31
- const React = __importStar(require("react"));
32
- const LabeledInput_js_1 = require("../LabeledInput/LabeledInput.js");
33
- /**
34
- * Textarea wrapper that allows for additional styling and labelling
35
- * @example
36
- * <LabeledTextarea
37
- * label='Textarea Label'
38
- * message='Help Message'
39
- * placeholder='This is a textarea'
40
- * />
41
- * <LabeledTextarea
42
- * label='Disabled Textarea Label'
43
- * message='Help Message'
44
- * placeholder='This is a textarea'
45
- * disabled={true}
46
- * />
47
- * <LabeledTextarea
48
- * label='Textarea Label'
49
- * message='Negative Message'
50
- * placeholder='This is a textarea'
51
- * status='negative'
52
- * />
53
- */
54
- exports.LabeledTextarea = React.forwardRef((props, forwardedRef) => {
55
- return (
56
- // ref types don't match but it's internal, so ts-ignore is ok here
57
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
58
- // @ts-ignore
59
- React.createElement(LabeledInput_js_1.LabeledInput, { as: 'textarea', rows: 3, ref: forwardedRef, ...props }));
5
+ Object.defineProperty(exports, 'LabeledTextarea', {
6
+ enumerable: true,
7
+ get: function () {
8
+ return LabeledTextarea;
9
+ },
10
+ });
11
+ const _interop_require_wildcard = require('@swc/helpers/_/_interop_require_wildcard');
12
+ const _jsxruntime = require('react/jsx-runtime');
13
+ const _react = _interop_require_wildcard._(require('react'));
14
+ const _LabeledInput = require('../LabeledInput/LabeledInput.js');
15
+ const LabeledTextarea = _react.forwardRef((props, forwardedRef) => {
16
+ return (0, _jsxruntime.jsx)(_LabeledInput.LabeledInput, {
17
+ as: 'textarea',
18
+ rows: 3,
19
+ ref: forwardedRef,
20
+ ...props,
21
+ });
60
22
  });
@@ -9,7 +9,7 @@ import type { PolymorphicForwardRefComponent } from '../../utils/props.js';
9
9
  * </Surface>
10
10
  * </LinkBox>
11
11
  */
12
- export declare const LinkAction: PolymorphicForwardRefComponent<"a", {}>;
12
+ export declare const LinkAction: PolymorphicForwardRefComponent<"a">;
13
13
  /**
14
14
  * Polymorphic link box component.
15
15
  * Used to wrap around your component to use LinkAction.
@@ -1,65 +1,38 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
1
+ 'use strict';
2
+ Object.defineProperty(exports, '__esModule', {
3
+ value: true,
17
4
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.LinkBox = exports.LinkAction = void 0;
30
- /*---------------------------------------------------------------------------------------------
31
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
32
- * See LICENSE.md in the project root for license terms and full copyright notice.
33
- *--------------------------------------------------------------------------------------------*/
34
- const React = __importStar(require("react"));
35
- const classnames_1 = __importDefault(require("classnames"));
36
- const polymorphic_js_1 = require("../../utils/functions/polymorphic.js");
37
- const index_js_1 = require("../../utils/components/index.js");
38
- /**
39
- * Polymorphic link action component.
40
- * It is rendered as `a` by default.
41
- * @example
42
- * <LinkBox>
43
- * <Surface>
44
- * <LinkAction href='/new-page'>Whole card is clickable</LinkAction>
45
- * </Surface>
46
- * </LinkBox>
47
- */
48
- exports.LinkAction = React.forwardRef((props, forwardedRef) => {
49
- const { as: asProp = (!!props.href ? 'a' : 'button') } = props;
50
- return (React.createElement(index_js_1.Box, { ...props, as: asProp, className: (0, classnames_1.default)('iui-link-action', props.className), ref: forwardedRef }));
5
+ function _export(target, all) {
6
+ for (var name in all)
7
+ Object.defineProperty(target, name, {
8
+ enumerable: true,
9
+ get: all[name],
10
+ });
11
+ }
12
+ _export(exports, {
13
+ LinkAction: function () {
14
+ return LinkAction;
15
+ },
16
+ LinkBox: function () {
17
+ return LinkBox;
18
+ },
51
19
  });
52
- exports.LinkAction.displayName = 'LinkAction';
53
- /**
54
- * Polymorphic link box component.
55
- * Used to wrap around your component to use LinkAction.
56
- * Rendered as `div` by default
57
- * @example
58
- * <LinkBox>
59
- * <Surface>
60
- * <LinkAction href='/new-page'>Whole card is clickable</LinkAction>
61
- * </Surface>
62
- * </LinkBox>
63
- */
64
- exports.LinkBox = polymorphic_js_1.polymorphic.div('iui-link-box');
65
- exports.LinkBox.displayName = 'LinkBox';
20
+ const _interop_require_default = require('@swc/helpers/_/_interop_require_default');
21
+ const _interop_require_wildcard = require('@swc/helpers/_/_interop_require_wildcard');
22
+ const _jsxruntime = require('react/jsx-runtime');
23
+ const _react = _interop_require_wildcard._(require('react'));
24
+ const _classnames = _interop_require_default._(require('classnames'));
25
+ const _polymorphic = require('../../utils/functions/polymorphic.js');
26
+ const _index = require('../../utils/components/index.js');
27
+ const LinkAction = _react.forwardRef((props, forwardedRef) => {
28
+ const { as: asProp = !!props.href ? 'a' : 'button' } = props;
29
+ return (0, _jsxruntime.jsx)(_index.Box, {
30
+ ...props,
31
+ as: asProp,
32
+ className: (0, _classnames.default)('iui-link-action', props.className),
33
+ ref: forwardedRef,
34
+ });
35
+ });
36
+ LinkAction.displayName = 'LinkAction';
37
+ const LinkBox = _polymorphic.polymorphic.div('iui-link-box');
38
+ LinkBox.displayName = 'LinkBox';
@@ -1,10 +1,15 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.List = void 0;
4
- /*---------------------------------------------------------------------------------------------
5
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
6
- * See LICENSE.md in the project root for license terms and full copyright notice.
7
- *--------------------------------------------------------------------------------------------*/
8
- const index_js_1 = require("../../utils/index.js");
9
- exports.List = index_js_1.polymorphic.ul('iui-list', { role: 'list' });
10
- exports.List.displayName = 'List';
1
+ 'use strict';
2
+ Object.defineProperty(exports, '__esModule', {
3
+ value: true,
4
+ });
5
+ Object.defineProperty(exports, 'List', {
6
+ enumerable: true,
7
+ get: function () {
8
+ return List;
9
+ },
10
+ });
11
+ const _index = require('../../utils/index.js');
12
+ const List = _index.polymorphic.ul('iui-list', {
13
+ role: 'list',
14
+ });
15
+ List.displayName = 'List';
@@ -44,7 +44,7 @@ export declare const ListItem: PolymorphicForwardRefComponent<"li", ListItemOwnP
44
44
  /**
45
45
  * Icon to be placed at the beginning or end of the ListItem.
46
46
  */
47
- Icon: PolymorphicForwardRefComponent<NonNullable<keyof JSX.IntrinsicElements>, {}>;
47
+ Icon: PolymorphicForwardRefComponent<keyof JSX.IntrinsicElements, {}>;
48
48
  /**
49
49
  * Wrapper for the main content of the ListItem.
50
50
  *
@@ -53,7 +53,7 @@ export declare const ListItem: PolymorphicForwardRefComponent<"li", ListItemOwnP
53
53
  * and push the icon to the end
54
54
  * - When using `ListItem.Description`.
55
55
  */
56
- Content: PolymorphicForwardRefComponent<NonNullable<keyof JSX.IntrinsicElements>, {}>;
56
+ Content: PolymorphicForwardRefComponent<keyof JSX.IntrinsicElements, {}>;
57
57
  /**
58
58
  * Description to be used in addition to the main label of the ListItem.
59
59
  * Should be used as a child of `ListItem.Content`.
@@ -66,7 +66,7 @@ export declare const ListItem: PolymorphicForwardRefComponent<"li", ListItemOwnP
66
66
  * </ListItem.Content>
67
67
  * </ListItem>
68
68
  */
69
- Description: PolymorphicForwardRefComponent<NonNullable<keyof JSX.IntrinsicElements>, {}>;
69
+ Description: PolymorphicForwardRefComponent<keyof JSX.IntrinsicElements, {}>;
70
70
  /**
71
71
  * Wrapper over [LinkAction](https://itwinui.bentley.com/docs/linkaction) which allows rendering a link inside a ListItem.
72
72
  * This ensures that clicking anywhere on the ListItem will trigger the link.
@@ -1,107 +1,56 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
1
+ 'use strict';
2
+ Object.defineProperty(exports, '__esModule', {
3
+ value: true,
17
4
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.ListItem = void 0;
30
- /*---------------------------------------------------------------------------------------------
31
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
32
- * See LICENSE.md in the project root for license terms and full copyright notice.
33
- *--------------------------------------------------------------------------------------------*/
34
- const React = __importStar(require("react"));
35
- const classnames_1 = __importDefault(require("classnames"));
36
- const index_js_1 = require("../../utils/index.js");
37
- const LinkAction_js_1 = require("../LinkAction/LinkAction.js");
38
- const ListItemComponent = React.forwardRef((props, ref) => {
39
- const { size = 'default', disabled = false, active = false, actionable = false, focused = false, className, ...rest } = props;
40
- return (React.createElement(index_js_1.Box, { as: 'li', className: (0, classnames_1.default)('iui-list-item', className), "data-iui-active": active ? 'true' : undefined, "data-iui-disabled": disabled ? 'true' : undefined, "data-iui-size": size === 'large' ? 'large' : undefined, "data-iui-actionable": actionable ? 'true' : undefined, "data-iui-focused": focused ? 'true' : undefined, ref: ref, ...rest }));
5
+ Object.defineProperty(exports, 'ListItem', {
6
+ enumerable: true,
7
+ get: function () {
8
+ return ListItem;
9
+ },
10
+ });
11
+ const _interop_require_default = require('@swc/helpers/_/_interop_require_default');
12
+ const _interop_require_wildcard = require('@swc/helpers/_/_interop_require_wildcard');
13
+ const _jsxruntime = require('react/jsx-runtime');
14
+ const _react = _interop_require_wildcard._(require('react'));
15
+ const _classnames = _interop_require_default._(require('classnames'));
16
+ const _index = require('../../utils/index.js');
17
+ const _LinkAction = require('../LinkAction/LinkAction.js');
18
+ const ListItemComponent = _react.forwardRef((props, ref) => {
19
+ const {
20
+ size = 'default',
21
+ disabled = false,
22
+ active = false,
23
+ actionable = false,
24
+ focused = false,
25
+ className,
26
+ ...rest
27
+ } = props;
28
+ return (0, _jsxruntime.jsx)(_index.Box, {
29
+ as: 'li',
30
+ className: (0, _classnames.default)('iui-list-item', className),
31
+ 'data-iui-active': active ? 'true' : undefined,
32
+ 'data-iui-disabled': disabled ? 'true' : undefined,
33
+ 'data-iui-size': size === 'large' ? 'large' : undefined,
34
+ 'data-iui-actionable': actionable ? 'true' : undefined,
35
+ 'data-iui-focused': focused ? 'true' : undefined,
36
+ ref: ref,
37
+ ...rest,
38
+ });
41
39
  });
42
40
  ListItemComponent.displayName = 'ListItem';
43
- // ----------------------------------------------------------------------------
44
- const ListItemIcon = (0, index_js_1.polymorphic)('iui-list-item-icon');
41
+ const ListItemIcon = (0, _index.polymorphic)('iui-list-item-icon');
45
42
  ListItemIcon.displayName = 'ListItem.Icon';
46
- // ----------------------------------------------------------------------------
47
- const ListItemContent = (0, index_js_1.polymorphic)('iui-list-item-content');
43
+ const ListItemContent = (0, _index.polymorphic)('iui-list-item-content');
48
44
  ListItemContent.displayName = 'ListItem.Content';
49
- // ----------------------------------------------------------------------------
50
- const ListItemDescription = (0, index_js_1.polymorphic)('iui-list-item-description');
45
+ const ListItemDescription = (0, _index.polymorphic)(
46
+ 'iui-list-item-description',
47
+ );
51
48
  ListItemDescription.displayName = 'ListItem.Description';
52
- // ----------------------------------------------------------------------------
53
- const ListItemAction = LinkAction_js_1.LinkAction;
49
+ const ListItemAction = _LinkAction.LinkAction;
54
50
  ListItemAction.displayName = 'ListItem.Action';
55
- // ----------------------------------------------------------------------------
56
- // Exported compound component
57
- /**
58
- * A generic ListItem component that can be used simply for displaying data, or as a base
59
- * for the list items in a more complex component (e.g. a custom Select).
60
- *
61
- * Includes support for left/right icons, multiple lines of text, and hover/focus/active/disabled styling.
62
- *
63
- * @example
64
- * <List>
65
- * <ListItem>item 1</ListItem>
66
- * <ListItem>item 2</ListItem>
67
- * <ListItem>item 3</ListItem>
68
- * </List>
69
- */
70
- exports.ListItem = Object.assign(ListItemComponent, {
71
- /**
72
- * Icon to be placed at the beginning or end of the ListItem.
73
- */
74
- Icon: ListItemIcon,
75
- /**
76
- * Wrapper for the main content of the ListItem.
77
- *
78
- * For basic list items, this wrapper is not needed, but it can be useful for two cases:
79
- * - When using an end icon. The `ListItem.Content` will fill the available space
80
- * and push the icon to the end
81
- * - When using `ListItem.Description`.
82
- */
83
- Content: ListItemContent,
84
- /**
85
- * Description to be used in addition to the main label of the ListItem.
86
- * Should be used as a child of `ListItem.Content`.
87
- *
88
- * @example
89
- * <ListItem>
90
- * <ListItem.Content>
91
- * <div>some list item</div>
92
- * <ListItem.Description>description for this item</ListItem.Description>
93
- * </ListItem.Content>
94
- * </ListItem>
95
- */
96
- Description: ListItemDescription,
97
- /**
98
- * Wrapper over [LinkAction](https://itwinui.bentley.com/docs/linkaction) which allows rendering a link inside a ListItem.
99
- * This ensures that clicking anywhere on the ListItem will trigger the link.
100
- *
101
- * @example
102
- * <ListItem>
103
- * <ListItem.Action href='https://example.com'>Example link</ListItem.Action>
104
- * </ListItem>
105
- */
106
- Action: ListItemAction,
51
+ const ListItem = Object.assign(ListItemComponent, {
52
+ Icon: ListItemIcon,
53
+ Content: ListItemContent,
54
+ Description: ListItemDescription,
55
+ Action: ListItemAction,
107
56
  });
@@ -1,5 +1,8 @@
1
1
  import * as React from 'react';
2
- import type { PolymorphicForwardRefComponent } from '../../utils/index.js';
2
+ import type { PolymorphicForwardRefComponent, PortalProps } from '../../utils/index.js';
3
+ import { usePopover } from '../Popover/Popover.js';
4
+ import { useInteractions, type UseListNavigationProps } from '@floating-ui/react';
5
+ type UsePopoverProps = Parameters<typeof usePopover>[0];
3
6
  type MenuProps = {
4
7
  /**
5
8
  * Menu items. Recommended to use `MenuItem` components.
@@ -9,13 +12,84 @@ type MenuProps = {
9
12
  */
10
13
  children: React.ReactNode;
11
14
  /**
12
- * If true, the first selected or enabled menu item will be focused automatically.
13
- * @default true
15
+ * The trigger that opens the menu.
14
16
  */
15
- setFocus?: boolean;
16
- };
17
+ trigger: React.ReactNode;
18
+ /**
19
+ * You can use this optional prop when the position reference is not the trigger.
20
+ * (Equivalent to using FloatingUI's `floating.refs.setPositionReference`)
21
+ */
22
+ positionReference?: Parameters<ReturnType<typeof usePopover>['refs']['setPositionReference']>[0];
23
+ /**
24
+ * Use this prop to override the default props passed to `usePopover` and `useListNavigation`.
25
+ */
26
+ popoverProps?: Omit<UsePopoverProps, 'interactions'> & {
27
+ interactions?: UsePopoverProps['interactions'] & {
28
+ listNavigation?: Partial<UseListNavigationProps>;
29
+ };
30
+ };
31
+ } & Pick<PortalProps, 'portal'>;
17
32
  /**
18
- * Basic menu component. Can be used for select or dropdown components.
33
+ * @private
34
+ *
35
+ * Used for dropdown components. E.g. `DropdownMenu`, `SplitButton`.
36
+ *
37
+ * What needs to be handled **manually**:
38
+ * - Menu items need to spread `MenuContext.popover.getItemProps()`.
39
+ * - Menu items need to focus itself on hover.
40
+ *
41
+ * What is handled automatically:
42
+ * - the portaling: use the optional `portal` prop for more customization
43
+ * - conditional rendering based on the popover's open state
44
+ * - spreading the popover props `getFloatingProps` and `getReferenceProps`.
45
+ * - As mentioned above, `getItemProps` need to be spread **manually** in the menu item.
46
+ * - setting the refs: use the optional`positionReference` prop to set the position reference
47
+ * - keyboard navigation: use the `interactions.listNavigation` prop for more customization
48
+ * - registering a `FloatingNode` in the `FloatingTree` if an ancestral `FloatingTree` is found
49
+ * - focus management:
50
+ * - focuses items on hover.
51
+ * - if *not* in a `FloatingTree`, focus moves to the trigger when the menu is closed.
52
+ * If in a `FloatingTree`, focus does not move back to the trigger since menu items handle the focus.
53
+ * - setting `aria-expanded` accordingly depending on the menu open state
54
+ *
55
+ * All `Menu` popover interactions are identical to `usePopover`'s interactions. Exception:
56
+ * - `hover`: When the `Menu` is within a `FloatingTree`, if a submenu has focus, the hover interaction is automatically
57
+ * disabled. This helps to keep the last hovered/focused submenu open even upon hovering out.
58
+ *
59
+ * @example
60
+ * const trigger = <Button>Menu</Button>;
61
+ * const [positionReference, setPositionReference] = React.useState<HTMLDivElement | null>(null);
62
+ * const popoverProps = { matchWidth: true };
63
+ * const nodeId = useFloatingNodeId();
64
+ *
65
+ * return (
66
+ * <Box ref={setPositionReference}>
67
+ * <Menu
68
+ * trigger={trigger}
69
+ * positionReference={positionReference}
70
+ * nodeId={nodeId}
71
+ * popoverProps={popoverProps}
72
+ * >
73
+ * <MenuItem>Item 1</MenuItem>
74
+ * <MenuItem>Item 2</MenuItem>
75
+ * </Menu>
76
+ * </Box>
77
+ * );
19
78
  */
20
79
  export declare const Menu: PolymorphicForwardRefComponent<"div", MenuProps>;
80
+ export type TreeEvent = {
81
+ nodeId: string;
82
+ parentId: string | null;
83
+ };
84
+ type PopoverGetItemProps = ({ focusableItemIndex, userProps, }: {
85
+ /**
86
+ * Index of this item out of all the focusable items in the parent `Menu`
87
+ */
88
+ focusableItemIndex: number | undefined;
89
+ userProps?: Parameters<NonNullable<ReturnType<typeof useInteractions>['getItemProps']>>[0];
90
+ }) => ReturnType<ReturnType<typeof useInteractions>['getItemProps']>;
91
+ export declare const MenuContext: React.Context<{
92
+ popoverGetItemProps: PopoverGetItemProps;
93
+ focusableElements: HTMLElement[];
94
+ } | undefined>;
21
95
  export {};