@itwin/itwinui-react 3.0.0-dev.0 → 3.0.0-dev.2

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 (602) hide show
  1. package/CHANGELOG.md +38 -0
  2. package/README.md +28 -22
  3. package/cjs/core/Alert/Alert.d.ts +47 -29
  4. package/cjs/core/Alert/Alert.js +73 -22
  5. package/cjs/core/Avatar/Avatar.d.ts +0 -1
  6. package/cjs/core/Avatar/Avatar.js +1 -2
  7. package/cjs/core/AvatarGroup/AvatarGroup.d.ts +0 -1
  8. package/cjs/core/AvatarGroup/AvatarGroup.js +1 -2
  9. package/cjs/core/Backdrop/Backdrop.d.ts +0 -1
  10. package/cjs/core/Backdrop/Backdrop.js +0 -1
  11. package/cjs/core/Badge/Badge.d.ts +0 -1
  12. package/cjs/core/Badge/Badge.js +0 -1
  13. package/cjs/core/Breadcrumbs/Breadcrumbs.d.ts +0 -1
  14. package/cjs/core/Breadcrumbs/Breadcrumbs.js +2 -4
  15. package/cjs/core/ButtonGroup/ButtonGroup.d.ts +0 -1
  16. package/cjs/core/ButtonGroup/ButtonGroup.js +1 -5
  17. package/cjs/core/Buttons/Button/Button.d.ts +0 -1
  18. package/cjs/core/Buttons/Button/Button.js +0 -1
  19. package/cjs/core/Buttons/DropdownButton/DropdownButton.d.ts +0 -1
  20. package/cjs/core/Buttons/DropdownButton/DropdownButton.js +3 -6
  21. package/cjs/core/Buttons/IconButton/IconButton.d.ts +0 -2
  22. package/cjs/core/Buttons/IconButton/IconButton.js +0 -2
  23. package/cjs/core/Buttons/SplitButton/SplitButton.d.ts +0 -1
  24. package/cjs/core/Buttons/SplitButton/SplitButton.js +0 -1
  25. package/cjs/core/Carousel/Carousel.d.ts +2 -3
  26. package/cjs/core/Carousel/Carousel.js +3 -6
  27. package/cjs/core/Carousel/CarouselDotsList.d.ts +0 -1
  28. package/cjs/core/Carousel/CarouselDotsList.js +8 -11
  29. package/cjs/core/Carousel/CarouselNavigation.d.ts +2 -2
  30. package/cjs/core/Carousel/CarouselNavigation.js +3 -5
  31. package/cjs/core/Carousel/CarouselSlider.js +10 -15
  32. package/cjs/core/Checkbox/Checkbox.d.ts +0 -1
  33. package/cjs/core/Checkbox/Checkbox.js +0 -1
  34. package/cjs/core/ColorPicker/ColorBuilder.d.ts +0 -1
  35. package/cjs/core/ColorPicker/ColorBuilder.js +7 -11
  36. package/cjs/core/ColorPicker/ColorInputPanel.d.ts +0 -1
  37. package/cjs/core/ColorPicker/ColorInputPanel.js +12 -16
  38. package/cjs/core/ColorPicker/ColorPalette.d.ts +0 -1
  39. package/cjs/core/ColorPicker/ColorPalette.js +4 -7
  40. package/cjs/core/ColorPicker/ColorPicker.d.ts +0 -1
  41. package/cjs/core/ColorPicker/ColorPicker.js +3 -4
  42. package/cjs/core/ColorPicker/ColorSwatch.d.ts +0 -1
  43. package/cjs/core/ColorPicker/ColorSwatch.js +0 -1
  44. package/cjs/core/ComboBox/ComboBox.d.ts +0 -1
  45. package/cjs/core/ComboBox/ComboBox.js +25 -33
  46. package/cjs/core/ComboBox/ComboBoxDropdown.js +1 -2
  47. package/cjs/core/ComboBox/ComboBoxEndIcon.js +1 -1
  48. package/cjs/core/ComboBox/ComboBoxInput.js +21 -20
  49. package/cjs/core/ComboBox/ComboBoxMenu.js +3 -4
  50. package/cjs/core/ComboBox/ComboBoxMenuItem.js +2 -2
  51. package/cjs/core/ComboBox/helpers.js +4 -5
  52. package/cjs/core/DatePicker/DatePicker.d.ts +0 -1
  53. package/cjs/core/DatePicker/DatePicker.js +32 -33
  54. package/cjs/core/Dialog/Dialog.d.ts +0 -1
  55. package/cjs/core/Dialog/Dialog.js +12 -5
  56. package/cjs/core/Dialog/DialogBackdrop.js +1 -1
  57. package/cjs/core/Dialog/DialogButtonBar.d.ts +0 -1
  58. package/cjs/core/Dialog/DialogButtonBar.js +0 -1
  59. package/cjs/core/Dialog/DialogContent.d.ts +0 -1
  60. package/cjs/core/Dialog/DialogContent.js +0 -1
  61. package/cjs/core/Dialog/DialogContext.d.ts +15 -0
  62. package/cjs/core/Dialog/DialogMain.d.ts +0 -1
  63. package/cjs/core/Dialog/DialogMain.js +18 -25
  64. package/cjs/core/Dialog/DialogTitleBar.d.ts +0 -1
  65. package/cjs/core/Dialog/DialogTitleBar.js +0 -1
  66. package/cjs/core/Dialog/DialogTitleBarTitle.d.ts +0 -1
  67. package/cjs/core/Dialog/DialogTitleBarTitle.js +0 -1
  68. package/cjs/core/DropdownMenu/DropdownMenu.js +6 -8
  69. package/cjs/core/ExpandableBlock/ExpandableBlock.d.ts +5 -1
  70. package/cjs/core/ExpandableBlock/ExpandableBlock.js +8 -6
  71. package/cjs/core/Fieldset/Fieldset.d.ts +0 -1
  72. package/cjs/core/Fieldset/Fieldset.js +0 -1
  73. package/cjs/core/FileUpload/FileEmptyCard.js +1 -1
  74. package/cjs/core/FileUpload/FileUpload.d.ts +0 -1
  75. package/cjs/core/FileUpload/FileUpload.js +3 -7
  76. package/cjs/core/FileUpload/FileUploadCard.d.ts +0 -1
  77. package/cjs/core/FileUpload/FileUploadCard.js +10 -12
  78. package/cjs/core/FileUpload/FileUploadTemplate.d.ts +0 -1
  79. package/cjs/core/FileUpload/FileUploadTemplate.js +0 -1
  80. package/cjs/core/Footer/Footer.d.ts +0 -1
  81. package/cjs/core/Footer/Footer.js +0 -1
  82. package/cjs/core/Footer/FooterItem.d.ts +0 -1
  83. package/cjs/core/Footer/FooterItem.js +0 -1
  84. package/cjs/core/Footer/FooterList.d.ts +0 -1
  85. package/cjs/core/Footer/FooterList.js +0 -1
  86. package/cjs/core/Footer/FooterSeparator.d.ts +0 -1
  87. package/cjs/core/Footer/FooterSeparator.js +0 -1
  88. package/cjs/core/Header/Header.d.ts +0 -1
  89. package/cjs/core/Header/Header.js +0 -1
  90. package/cjs/core/Header/HeaderBreadcrumbs.d.ts +0 -1
  91. package/cjs/core/Header/HeaderBreadcrumbs.js +0 -1
  92. package/cjs/core/Header/HeaderButton.d.ts +0 -1
  93. package/cjs/core/Header/HeaderButton.js +0 -1
  94. package/cjs/core/Header/HeaderLogo.d.ts +0 -1
  95. package/cjs/core/Header/HeaderLogo.js +0 -1
  96. package/cjs/core/InformationPanel/InformationPanel.d.ts +0 -1
  97. package/cjs/core/InformationPanel/InformationPanel.js +1 -5
  98. package/cjs/core/InformationPanel/InformationPanelBody.d.ts +0 -1
  99. package/cjs/core/InformationPanel/InformationPanelBody.js +0 -1
  100. package/cjs/core/InformationPanel/InformationPanelContent.d.ts +0 -1
  101. package/cjs/core/InformationPanel/InformationPanelContent.js +0 -1
  102. package/cjs/core/InformationPanel/InformationPanelHeader.d.ts +0 -1
  103. package/cjs/core/InformationPanel/InformationPanelHeader.js +0 -1
  104. package/cjs/core/InformationPanel/InformationPanelWrapper.d.ts +0 -1
  105. package/cjs/core/InformationPanel/InformationPanelWrapper.js +0 -1
  106. package/cjs/core/Input/Input.d.ts +0 -1
  107. package/cjs/core/Input/Input.js +0 -1
  108. package/cjs/core/InputGroup/InputGroup.d.ts +0 -1
  109. package/cjs/core/InputGroup/InputGroup.js +0 -1
  110. package/cjs/core/Label/Label.d.ts +0 -1
  111. package/cjs/core/Label/Label.js +0 -1
  112. package/cjs/core/LabeledInput/LabeledInput.d.ts +0 -1
  113. package/cjs/core/LabeledInput/LabeledInput.js +1 -2
  114. package/cjs/core/LabeledSelect/LabeledSelect.d.ts +0 -1
  115. package/cjs/core/LabeledSelect/LabeledSelect.js +0 -1
  116. package/cjs/core/LabeledTextarea/LabeledTextarea.d.ts +0 -1
  117. package/cjs/core/LabeledTextarea/LabeledTextarea.js +1 -2
  118. package/cjs/core/List/List.d.ts +0 -1
  119. package/cjs/core/List/List.js +0 -1
  120. package/cjs/core/List/ListItem.d.ts +0 -1
  121. package/cjs/core/List/ListItem.js +0 -1
  122. package/cjs/core/Menu/Menu.d.ts +0 -1
  123. package/cjs/core/Menu/Menu.js +3 -5
  124. package/cjs/core/Menu/MenuDivider.d.ts +0 -1
  125. package/cjs/core/Menu/MenuDivider.js +0 -1
  126. package/cjs/core/Menu/MenuExtraContent.d.ts +0 -1
  127. package/cjs/core/Menu/MenuExtraContent.js +0 -1
  128. package/cjs/core/Menu/MenuItem.d.ts +0 -1
  129. package/cjs/core/Menu/MenuItem.js +8 -12
  130. package/cjs/core/Menu/MenuItemSkeleton.d.ts +0 -1
  131. package/cjs/core/Menu/MenuItemSkeleton.js +0 -1
  132. package/cjs/core/Modal/Modal.d.ts +8 -10
  133. package/cjs/core/Modal/Modal.js +7 -18
  134. package/cjs/core/NonIdealState/NonIdealState.d.ts +0 -1
  135. package/cjs/core/NonIdealState/NonIdealState.js +0 -1
  136. package/cjs/core/NotificationMarker/NotificationMarker.d.ts +0 -1
  137. package/cjs/core/NotificationMarker/NotificationMarker.js +0 -1
  138. package/cjs/core/ProgressIndicators/ProgressLinear/ProgressLinear.d.ts +0 -1
  139. package/cjs/core/ProgressIndicators/ProgressLinear/ProgressLinear.js +0 -1
  140. package/cjs/core/ProgressIndicators/ProgressRadial/ProgressRadial.d.ts +0 -1
  141. package/cjs/core/ProgressIndicators/ProgressRadial/ProgressRadial.js +0 -1
  142. package/cjs/core/Radio/Radio.d.ts +0 -1
  143. package/cjs/core/Radio/Radio.js +0 -1
  144. package/cjs/core/RadioTiles/RadioTile.d.ts +0 -1
  145. package/cjs/core/RadioTiles/RadioTile.js +0 -1
  146. package/cjs/core/RadioTiles/RadioTileGroup.d.ts +0 -1
  147. package/cjs/core/RadioTiles/RadioTileGroup.js +0 -1
  148. package/cjs/core/SearchBox/SearchBox.d.ts +0 -1
  149. package/cjs/core/SearchBox/SearchBox.js +12 -13
  150. package/cjs/core/Select/Select.d.ts +0 -1
  151. package/cjs/core/Select/Select.js +12 -18
  152. package/cjs/core/Select/SelectTag.d.ts +0 -1
  153. package/cjs/core/Select/SelectTag.js +0 -1
  154. package/cjs/core/SideNavigation/SideNavigation.d.ts +0 -1
  155. package/cjs/core/SideNavigation/SideNavigation.js +2 -3
  156. package/cjs/core/SideNavigation/SidenavButton.d.ts +0 -1
  157. package/cjs/core/SideNavigation/SidenavButton.js +0 -1
  158. package/cjs/core/SideNavigation/SidenavSubmenu.d.ts +0 -1
  159. package/cjs/core/SideNavigation/SidenavSubmenu.js +0 -1
  160. package/cjs/core/SideNavigation/SidenavSubmenuHeader.d.ts +0 -1
  161. package/cjs/core/SideNavigation/SidenavSubmenuHeader.js +0 -1
  162. package/cjs/core/SkipToContentLink/SkipToContentLink.d.ts +0 -1
  163. package/cjs/core/SkipToContentLink/SkipToContentLink.js +0 -1
  164. package/cjs/core/Slider/Slider.d.ts +0 -1
  165. package/cjs/core/Slider/Slider.js +16 -20
  166. package/cjs/core/Slider/Thumb.js +1 -1
  167. package/cjs/core/Slider/Track.js +2 -1
  168. package/cjs/core/StatusMessage/StatusMessage.js +1 -1
  169. package/cjs/core/Stepper/Stepper.d.ts +0 -1
  170. package/cjs/core/Stepper/Stepper.js +1 -2
  171. package/cjs/core/Stepper/StepperStep.js +1 -1
  172. package/cjs/core/Stepper/WorkflowDiagram.d.ts +0 -1
  173. package/cjs/core/Stepper/WorkflowDiagram.js +0 -1
  174. package/cjs/core/Surface/Surface.d.ts +0 -1
  175. package/cjs/core/Surface/Surface.js +0 -1
  176. package/cjs/core/Table/Table.d.ts +0 -1
  177. package/cjs/core/Table/Table.js +33 -34
  178. package/cjs/core/Table/TableCell.js +3 -2
  179. package/cjs/core/Table/TablePaginator.d.ts +0 -1
  180. package/cjs/core/Table/TablePaginator.js +10 -12
  181. package/cjs/core/Table/TableRowMemoized.js +40 -47
  182. package/cjs/core/Table/actionHandlers/expandHandler.js +3 -3
  183. package/cjs/core/Table/actionHandlers/filterHandler.js +4 -5
  184. package/cjs/core/Table/actionHandlers/selectHandler.js +6 -6
  185. package/cjs/core/Table/cells/DefaultCell.js +4 -3
  186. package/cjs/core/Table/cells/EditableCell.js +7 -13
  187. package/cjs/core/Table/columns/actionColumn.js +3 -6
  188. package/cjs/core/Table/columns/expanderColumn.js +3 -3
  189. package/cjs/core/Table/columns/selectionColumn.js +4 -4
  190. package/cjs/core/Table/filters/BaseFilter.d.ts +0 -1
  191. package/cjs/core/Table/filters/BaseFilter.js +1 -2
  192. package/cjs/core/Table/filters/DateRangeFilter/DatePickerInput.js +2 -4
  193. package/cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.d.ts +0 -1
  194. package/cjs/core/Table/filters/DateRangeFilter/DateRangeFilter.js +2 -4
  195. package/cjs/core/Table/filters/FilterButtonBar.d.ts +0 -1
  196. package/cjs/core/Table/filters/FilterButtonBar.js +1 -2
  197. package/cjs/core/Table/filters/FilterToggle.d.ts +0 -1
  198. package/cjs/core/Table/filters/FilterToggle.js +0 -1
  199. package/cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.d.ts +0 -1
  200. package/cjs/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +2 -4
  201. package/cjs/core/Table/filters/TextFilter/TextFilter.d.ts +0 -1
  202. package/cjs/core/Table/filters/TextFilter/TextFilter.js +1 -3
  203. package/cjs/core/Table/hooks/useColumnDragAndDrop.js +8 -4
  204. package/cjs/core/Table/hooks/useResizeColumns.js +16 -22
  205. package/cjs/core/Table/hooks/useScrollToRow.js +1 -2
  206. package/cjs/core/Table/hooks/useStickyColumns.js +3 -5
  207. package/cjs/core/Table/hooks/useSubRowFiltering.js +2 -4
  208. package/cjs/core/Tabs/Tab.d.ts +0 -1
  209. package/cjs/core/Tabs/Tab.js +0 -1
  210. package/cjs/core/Tabs/Tabs.d.ts +0 -1
  211. package/cjs/core/Tabs/Tabs.js +16 -19
  212. package/cjs/core/Tag/Tag.d.ts +0 -1
  213. package/cjs/core/Tag/Tag.js +0 -1
  214. package/cjs/core/Tag/TagContainer.d.ts +0 -1
  215. package/cjs/core/Tag/TagContainer.js +0 -1
  216. package/cjs/core/Textarea/Textarea.d.ts +0 -1
  217. package/cjs/core/Textarea/Textarea.js +0 -1
  218. package/cjs/core/ThemeProvider/ThemeContext.d.ts +1 -1
  219. package/cjs/core/ThemeProvider/ThemeProvider.d.ts +2 -5
  220. package/cjs/core/ThemeProvider/ThemeProvider.js +11 -15
  221. package/cjs/core/Tile/Tile.d.ts +0 -1
  222. package/cjs/core/Tile/Tile.js +3 -7
  223. package/cjs/core/TimePicker/TimePicker.d.ts +0 -1
  224. package/cjs/core/TimePicker/TimePicker.js +13 -14
  225. package/cjs/core/Toast/Toast.d.ts +0 -1
  226. package/cjs/core/Toast/Toast.js +2 -4
  227. package/cjs/core/Toast/ToastWrapper.d.ts +0 -1
  228. package/cjs/core/Toast/ToastWrapper.js +0 -1
  229. package/cjs/core/Toast/Toaster.js +6 -11
  230. package/cjs/core/ToggleSwitch/ToggleSwitch.d.ts +0 -1
  231. package/cjs/core/ToggleSwitch/ToggleSwitch.js +1 -3
  232. package/cjs/core/Tooltip/Tooltip.d.ts +0 -1
  233. package/cjs/core/Tooltip/Tooltip.js +0 -1
  234. package/cjs/core/TransferList/TransferList.d.ts +69 -0
  235. package/cjs/core/TransferList/TransferList.js +147 -0
  236. package/cjs/core/TransferList/index.d.ts +3 -0
  237. package/cjs/core/TransferList/index.js +10 -0
  238. package/cjs/core/Tree/Tree.d.ts +0 -1
  239. package/cjs/core/Tree/Tree.js +9 -14
  240. package/cjs/core/Tree/TreeNode.d.ts +0 -1
  241. package/cjs/core/Tree/TreeNode.js +9 -11
  242. package/cjs/core/Tree/TreeNodeExpander.d.ts +0 -1
  243. package/cjs/core/Tree/TreeNodeExpander.js +0 -1
  244. package/cjs/core/Typography/Anchor/Anchor.d.ts +0 -1
  245. package/cjs/core/Typography/Anchor/Anchor.js +0 -1
  246. package/cjs/core/Typography/Blockquote/Blockquote.d.ts +0 -1
  247. package/cjs/core/Typography/Blockquote/Blockquote.js +0 -1
  248. package/cjs/core/Typography/Code/Code.d.ts +0 -1
  249. package/cjs/core/Typography/Code/Code.js +0 -1
  250. package/cjs/core/Typography/Kbd/Kbd.d.ts +0 -1
  251. package/cjs/core/Typography/Kbd/Kbd.js +0 -1
  252. package/cjs/core/Typography/Text/Text.d.ts +0 -1
  253. package/cjs/core/Typography/Text/Text.js +0 -1
  254. package/cjs/core/index.d.ts +1 -0
  255. package/cjs/core/index.js +118 -116
  256. package/cjs/core/utils/color/ColorValue.js +9 -15
  257. package/cjs/core/utils/components/AutoclearingHiddenLiveRegion.js +2 -3
  258. package/cjs/core/utils/components/Divider.d.ts +0 -1
  259. package/cjs/core/utils/components/Divider.js +0 -1
  260. package/cjs/core/utils/components/Flex.d.ts +0 -1
  261. package/cjs/core/utils/components/Flex.js +0 -1
  262. package/cjs/core/utils/components/FocusTrap.js +4 -4
  263. package/cjs/core/utils/components/Icon.d.ts +0 -1
  264. package/cjs/core/utils/components/Icon.js +0 -1
  265. package/cjs/core/utils/components/InputContainer.d.ts +0 -1
  266. package/cjs/core/utils/components/InputContainer.js +0 -1
  267. package/cjs/core/utils/components/InputFlexContainer.d.ts +0 -1
  268. package/cjs/core/utils/components/InputFlexContainer.js +0 -1
  269. package/cjs/core/utils/components/LinkAction.d.ts +0 -1
  270. package/cjs/core/utils/components/LinkAction.js +0 -1
  271. package/cjs/core/utils/components/MiddleTextTruncation.js +1 -2
  272. package/cjs/core/utils/components/Popover.d.ts +0 -1
  273. package/cjs/core/utils/components/Popover.js +5 -9
  274. package/cjs/core/utils/components/Resizer.js +7 -6
  275. package/cjs/core/utils/components/VirtualScroll.js +14 -21
  276. package/cjs/core/utils/components/VisuallyHidden.d.ts +0 -1
  277. package/cjs/core/utils/components/VisuallyHidden.js +0 -1
  278. package/cjs/core/utils/functions/dom.d.ts +6 -0
  279. package/cjs/core/utils/functions/dom.js +24 -6
  280. package/cjs/core/utils/functions/index.d.ts +0 -1
  281. package/cjs/core/utils/functions/index.js +0 -1
  282. package/cjs/core/utils/functions/polymorphic.js +9 -1
  283. package/cjs/core/utils/functions/supports.js +1 -1
  284. package/cjs/core/utils/hooks/index.d.ts +0 -1
  285. package/cjs/core/utils/hooks/index.js +0 -1
  286. package/cjs/core/utils/hooks/useContainerWidth.js +1 -1
  287. package/cjs/core/utils/hooks/useDragAndDrop.js +8 -10
  288. package/cjs/core/utils/hooks/useEventListener.js +1 -1
  289. package/cjs/core/utils/hooks/useGlobals.d.ts +9 -4
  290. package/cjs/core/utils/hooks/useGlobals.js +6 -6
  291. package/cjs/core/utils/hooks/useId.js +1 -2
  292. package/cjs/core/utils/hooks/useIntersection.js +2 -3
  293. package/cjs/core/utils/hooks/useMediaQuery.js +6 -8
  294. package/cjs/core/utils/hooks/useOverflow.js +1 -2
  295. package/cjs/core/utils/hooks/useResizeObserver.js +3 -4
  296. package/cjs/styles.d.ts +5 -0
  297. package/cjs/styles.js +450 -0
  298. package/esm/core/Alert/Alert.d.ts +47 -29
  299. package/esm/core/Alert/Alert.js +74 -23
  300. package/esm/core/Avatar/Avatar.d.ts +0 -1
  301. package/esm/core/Avatar/Avatar.js +1 -2
  302. package/esm/core/AvatarGroup/AvatarGroup.d.ts +0 -1
  303. package/esm/core/AvatarGroup/AvatarGroup.js +1 -2
  304. package/esm/core/Backdrop/Backdrop.d.ts +0 -1
  305. package/esm/core/Backdrop/Backdrop.js +0 -1
  306. package/esm/core/Badge/Badge.d.ts +0 -1
  307. package/esm/core/Badge/Badge.js +0 -1
  308. package/esm/core/Breadcrumbs/Breadcrumbs.d.ts +0 -1
  309. package/esm/core/Breadcrumbs/Breadcrumbs.js +2 -4
  310. package/esm/core/ButtonGroup/ButtonGroup.d.ts +0 -1
  311. package/esm/core/ButtonGroup/ButtonGroup.js +1 -5
  312. package/esm/core/Buttons/Button/Button.d.ts +0 -1
  313. package/esm/core/Buttons/Button/Button.js +0 -1
  314. package/esm/core/Buttons/DropdownButton/DropdownButton.d.ts +0 -1
  315. package/esm/core/Buttons/DropdownButton/DropdownButton.js +3 -6
  316. package/esm/core/Buttons/IconButton/IconButton.d.ts +0 -2
  317. package/esm/core/Buttons/IconButton/IconButton.js +0 -2
  318. package/esm/core/Buttons/SplitButton/SplitButton.d.ts +0 -1
  319. package/esm/core/Buttons/SplitButton/SplitButton.js +0 -1
  320. package/esm/core/Carousel/Carousel.d.ts +2 -3
  321. package/esm/core/Carousel/Carousel.js +3 -6
  322. package/esm/core/Carousel/CarouselDotsList.d.ts +0 -1
  323. package/esm/core/Carousel/CarouselDotsList.js +8 -11
  324. package/esm/core/Carousel/CarouselNavigation.d.ts +2 -2
  325. package/esm/core/Carousel/CarouselNavigation.js +3 -5
  326. package/esm/core/Carousel/CarouselSlider.js +10 -15
  327. package/esm/core/Checkbox/Checkbox.d.ts +0 -1
  328. package/esm/core/Checkbox/Checkbox.js +0 -1
  329. package/esm/core/ColorPicker/ColorBuilder.d.ts +0 -1
  330. package/esm/core/ColorPicker/ColorBuilder.js +7 -11
  331. package/esm/core/ColorPicker/ColorInputPanel.d.ts +0 -1
  332. package/esm/core/ColorPicker/ColorInputPanel.js +12 -16
  333. package/esm/core/ColorPicker/ColorPalette.d.ts +0 -1
  334. package/esm/core/ColorPicker/ColorPalette.js +4 -7
  335. package/esm/core/ColorPicker/ColorPicker.d.ts +0 -1
  336. package/esm/core/ColorPicker/ColorPicker.js +3 -4
  337. package/esm/core/ColorPicker/ColorSwatch.d.ts +0 -1
  338. package/esm/core/ColorPicker/ColorSwatch.js +0 -1
  339. package/esm/core/ComboBox/ComboBox.d.ts +0 -1
  340. package/esm/core/ComboBox/ComboBox.js +25 -33
  341. package/esm/core/ComboBox/ComboBoxDropdown.js +1 -2
  342. package/esm/core/ComboBox/ComboBoxEndIcon.js +1 -1
  343. package/esm/core/ComboBox/ComboBoxInput.js +21 -20
  344. package/esm/core/ComboBox/ComboBoxMenu.js +3 -4
  345. package/esm/core/ComboBox/ComboBoxMenuItem.js +2 -2
  346. package/esm/core/ComboBox/helpers.js +4 -5
  347. package/esm/core/DatePicker/DatePicker.d.ts +0 -1
  348. package/esm/core/DatePicker/DatePicker.js +32 -33
  349. package/esm/core/Dialog/Dialog.d.ts +0 -1
  350. package/esm/core/Dialog/Dialog.js +13 -6
  351. package/esm/core/Dialog/DialogBackdrop.js +1 -1
  352. package/esm/core/Dialog/DialogButtonBar.d.ts +0 -1
  353. package/esm/core/Dialog/DialogButtonBar.js +0 -1
  354. package/esm/core/Dialog/DialogContent.d.ts +0 -1
  355. package/esm/core/Dialog/DialogContent.js +0 -1
  356. package/esm/core/Dialog/DialogContext.d.ts +15 -0
  357. package/esm/core/Dialog/DialogMain.d.ts +0 -1
  358. package/esm/core/Dialog/DialogMain.js +18 -25
  359. package/esm/core/Dialog/DialogTitleBar.d.ts +0 -1
  360. package/esm/core/Dialog/DialogTitleBar.js +0 -1
  361. package/esm/core/Dialog/DialogTitleBarTitle.d.ts +0 -1
  362. package/esm/core/Dialog/DialogTitleBarTitle.js +0 -1
  363. package/esm/core/DropdownMenu/DropdownMenu.js +6 -8
  364. package/esm/core/ExpandableBlock/ExpandableBlock.d.ts +5 -1
  365. package/esm/core/ExpandableBlock/ExpandableBlock.js +8 -6
  366. package/esm/core/Fieldset/Fieldset.d.ts +0 -1
  367. package/esm/core/Fieldset/Fieldset.js +0 -1
  368. package/esm/core/FileUpload/FileEmptyCard.js +1 -1
  369. package/esm/core/FileUpload/FileUpload.d.ts +0 -1
  370. package/esm/core/FileUpload/FileUpload.js +3 -7
  371. package/esm/core/FileUpload/FileUploadCard.d.ts +0 -1
  372. package/esm/core/FileUpload/FileUploadCard.js +10 -12
  373. package/esm/core/FileUpload/FileUploadTemplate.d.ts +0 -1
  374. package/esm/core/FileUpload/FileUploadTemplate.js +0 -1
  375. package/esm/core/Footer/Footer.d.ts +0 -1
  376. package/esm/core/Footer/Footer.js +0 -1
  377. package/esm/core/Footer/FooterItem.d.ts +0 -1
  378. package/esm/core/Footer/FooterItem.js +0 -1
  379. package/esm/core/Footer/FooterList.d.ts +0 -1
  380. package/esm/core/Footer/FooterList.js +0 -1
  381. package/esm/core/Footer/FooterSeparator.d.ts +0 -1
  382. package/esm/core/Footer/FooterSeparator.js +0 -1
  383. package/esm/core/Header/Header.d.ts +0 -1
  384. package/esm/core/Header/Header.js +0 -1
  385. package/esm/core/Header/HeaderBreadcrumbs.d.ts +0 -1
  386. package/esm/core/Header/HeaderBreadcrumbs.js +0 -1
  387. package/esm/core/Header/HeaderButton.d.ts +0 -1
  388. package/esm/core/Header/HeaderButton.js +0 -1
  389. package/esm/core/Header/HeaderLogo.d.ts +0 -1
  390. package/esm/core/Header/HeaderLogo.js +0 -1
  391. package/esm/core/InformationPanel/InformationPanel.d.ts +0 -1
  392. package/esm/core/InformationPanel/InformationPanel.js +1 -5
  393. package/esm/core/InformationPanel/InformationPanelBody.d.ts +0 -1
  394. package/esm/core/InformationPanel/InformationPanelBody.js +0 -1
  395. package/esm/core/InformationPanel/InformationPanelContent.d.ts +0 -1
  396. package/esm/core/InformationPanel/InformationPanelContent.js +0 -1
  397. package/esm/core/InformationPanel/InformationPanelHeader.d.ts +0 -1
  398. package/esm/core/InformationPanel/InformationPanelHeader.js +0 -1
  399. package/esm/core/InformationPanel/InformationPanelWrapper.d.ts +0 -1
  400. package/esm/core/InformationPanel/InformationPanelWrapper.js +0 -1
  401. package/esm/core/Input/Input.d.ts +0 -1
  402. package/esm/core/Input/Input.js +0 -1
  403. package/esm/core/InputGroup/InputGroup.d.ts +0 -1
  404. package/esm/core/InputGroup/InputGroup.js +0 -1
  405. package/esm/core/Label/Label.d.ts +0 -1
  406. package/esm/core/Label/Label.js +0 -1
  407. package/esm/core/LabeledInput/LabeledInput.d.ts +0 -1
  408. package/esm/core/LabeledInput/LabeledInput.js +1 -2
  409. package/esm/core/LabeledSelect/LabeledSelect.d.ts +0 -1
  410. package/esm/core/LabeledSelect/LabeledSelect.js +0 -1
  411. package/esm/core/LabeledTextarea/LabeledTextarea.d.ts +0 -1
  412. package/esm/core/LabeledTextarea/LabeledTextarea.js +1 -2
  413. package/esm/core/List/List.d.ts +0 -1
  414. package/esm/core/List/List.js +0 -1
  415. package/esm/core/List/ListItem.d.ts +0 -1
  416. package/esm/core/List/ListItem.js +0 -1
  417. package/esm/core/Menu/Menu.d.ts +0 -1
  418. package/esm/core/Menu/Menu.js +3 -5
  419. package/esm/core/Menu/MenuDivider.d.ts +0 -1
  420. package/esm/core/Menu/MenuDivider.js +0 -1
  421. package/esm/core/Menu/MenuExtraContent.d.ts +0 -1
  422. package/esm/core/Menu/MenuExtraContent.js +0 -1
  423. package/esm/core/Menu/MenuItem.d.ts +0 -1
  424. package/esm/core/Menu/MenuItem.js +8 -12
  425. package/esm/core/Menu/MenuItemSkeleton.d.ts +0 -1
  426. package/esm/core/Menu/MenuItemSkeleton.js +0 -1
  427. package/esm/core/Modal/Modal.d.ts +8 -10
  428. package/esm/core/Modal/Modal.js +3 -11
  429. package/esm/core/NonIdealState/NonIdealState.d.ts +0 -1
  430. package/esm/core/NonIdealState/NonIdealState.js +0 -1
  431. package/esm/core/NotificationMarker/NotificationMarker.d.ts +0 -1
  432. package/esm/core/NotificationMarker/NotificationMarker.js +0 -1
  433. package/esm/core/ProgressIndicators/ProgressLinear/ProgressLinear.d.ts +0 -1
  434. package/esm/core/ProgressIndicators/ProgressLinear/ProgressLinear.js +0 -1
  435. package/esm/core/ProgressIndicators/ProgressRadial/ProgressRadial.d.ts +0 -1
  436. package/esm/core/ProgressIndicators/ProgressRadial/ProgressRadial.js +0 -1
  437. package/esm/core/Radio/Radio.d.ts +0 -1
  438. package/esm/core/Radio/Radio.js +0 -1
  439. package/esm/core/RadioTiles/RadioTile.d.ts +0 -1
  440. package/esm/core/RadioTiles/RadioTile.js +0 -1
  441. package/esm/core/RadioTiles/RadioTileGroup.d.ts +0 -1
  442. package/esm/core/RadioTiles/RadioTileGroup.js +0 -1
  443. package/esm/core/SearchBox/SearchBox.d.ts +0 -1
  444. package/esm/core/SearchBox/SearchBox.js +12 -13
  445. package/esm/core/Select/Select.d.ts +0 -1
  446. package/esm/core/Select/Select.js +12 -18
  447. package/esm/core/Select/SelectTag.d.ts +0 -1
  448. package/esm/core/Select/SelectTag.js +0 -1
  449. package/esm/core/SideNavigation/SideNavigation.d.ts +0 -1
  450. package/esm/core/SideNavigation/SideNavigation.js +2 -3
  451. package/esm/core/SideNavigation/SidenavButton.d.ts +0 -1
  452. package/esm/core/SideNavigation/SidenavButton.js +0 -1
  453. package/esm/core/SideNavigation/SidenavSubmenu.d.ts +0 -1
  454. package/esm/core/SideNavigation/SidenavSubmenu.js +0 -1
  455. package/esm/core/SideNavigation/SidenavSubmenuHeader.d.ts +0 -1
  456. package/esm/core/SideNavigation/SidenavSubmenuHeader.js +0 -1
  457. package/esm/core/SkipToContentLink/SkipToContentLink.d.ts +0 -1
  458. package/esm/core/SkipToContentLink/SkipToContentLink.js +0 -1
  459. package/esm/core/Slider/Slider.d.ts +0 -1
  460. package/esm/core/Slider/Slider.js +16 -20
  461. package/esm/core/Slider/Thumb.js +1 -1
  462. package/esm/core/Slider/Track.js +2 -1
  463. package/esm/core/StatusMessage/StatusMessage.js +1 -1
  464. package/esm/core/Stepper/Stepper.d.ts +0 -1
  465. package/esm/core/Stepper/Stepper.js +1 -2
  466. package/esm/core/Stepper/StepperStep.js +1 -1
  467. package/esm/core/Stepper/WorkflowDiagram.d.ts +0 -1
  468. package/esm/core/Stepper/WorkflowDiagram.js +0 -1
  469. package/esm/core/Surface/Surface.d.ts +0 -1
  470. package/esm/core/Surface/Surface.js +0 -1
  471. package/esm/core/Table/Table.d.ts +0 -1
  472. package/esm/core/Table/Table.js +34 -35
  473. package/esm/core/Table/TableCell.js +3 -2
  474. package/esm/core/Table/TablePaginator.d.ts +0 -1
  475. package/esm/core/Table/TablePaginator.js +11 -13
  476. package/esm/core/Table/TableRowMemoized.js +41 -48
  477. package/esm/core/Table/actionHandlers/expandHandler.js +3 -3
  478. package/esm/core/Table/actionHandlers/filterHandler.js +4 -5
  479. package/esm/core/Table/actionHandlers/selectHandler.js +6 -6
  480. package/esm/core/Table/cells/DefaultCell.js +4 -3
  481. package/esm/core/Table/cells/EditableCell.js +8 -14
  482. package/esm/core/Table/columns/actionColumn.js +3 -6
  483. package/esm/core/Table/columns/expanderColumn.js +3 -3
  484. package/esm/core/Table/columns/selectionColumn.js +4 -4
  485. package/esm/core/Table/filters/BaseFilter.d.ts +0 -1
  486. package/esm/core/Table/filters/BaseFilter.js +2 -3
  487. package/esm/core/Table/filters/DateRangeFilter/DatePickerInput.js +2 -4
  488. package/esm/core/Table/filters/DateRangeFilter/DateRangeFilter.d.ts +0 -1
  489. package/esm/core/Table/filters/DateRangeFilter/DateRangeFilter.js +2 -4
  490. package/esm/core/Table/filters/FilterButtonBar.d.ts +0 -1
  491. package/esm/core/Table/filters/FilterButtonBar.js +2 -3
  492. package/esm/core/Table/filters/FilterToggle.d.ts +0 -1
  493. package/esm/core/Table/filters/FilterToggle.js +0 -1
  494. package/esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.d.ts +0 -1
  495. package/esm/core/Table/filters/NumberRangeFilter/NumberRangeFilter.js +2 -4
  496. package/esm/core/Table/filters/TextFilter/TextFilter.d.ts +0 -1
  497. package/esm/core/Table/filters/TextFilter/TextFilter.js +1 -3
  498. package/esm/core/Table/hooks/useColumnDragAndDrop.js +5 -4
  499. package/esm/core/Table/hooks/useResizeColumns.js +16 -22
  500. package/esm/core/Table/hooks/useScrollToRow.js +1 -2
  501. package/esm/core/Table/hooks/useStickyColumns.js +3 -5
  502. package/esm/core/Table/hooks/useSubRowFiltering.js +2 -4
  503. package/esm/core/Tabs/Tab.d.ts +0 -1
  504. package/esm/core/Tabs/Tab.js +0 -1
  505. package/esm/core/Tabs/Tabs.d.ts +0 -1
  506. package/esm/core/Tabs/Tabs.js +16 -19
  507. package/esm/core/Tag/Tag.d.ts +0 -1
  508. package/esm/core/Tag/Tag.js +0 -1
  509. package/esm/core/Tag/TagContainer.d.ts +0 -1
  510. package/esm/core/Tag/TagContainer.js +0 -1
  511. package/esm/core/Textarea/Textarea.d.ts +0 -1
  512. package/esm/core/Textarea/Textarea.js +0 -1
  513. package/esm/core/ThemeProvider/ThemeContext.d.ts +1 -1
  514. package/esm/core/ThemeProvider/ThemeProvider.d.ts +2 -5
  515. package/esm/core/ThemeProvider/ThemeProvider.js +12 -16
  516. package/esm/core/Tile/Tile.d.ts +0 -1
  517. package/esm/core/Tile/Tile.js +3 -7
  518. package/esm/core/TimePicker/TimePicker.d.ts +0 -1
  519. package/esm/core/TimePicker/TimePicker.js +13 -14
  520. package/esm/core/Toast/Toast.d.ts +0 -1
  521. package/esm/core/Toast/Toast.js +2 -4
  522. package/esm/core/Toast/ToastWrapper.d.ts +0 -1
  523. package/esm/core/Toast/ToastWrapper.js +0 -1
  524. package/esm/core/Toast/Toaster.js +6 -11
  525. package/esm/core/ToggleSwitch/ToggleSwitch.d.ts +0 -1
  526. package/esm/core/ToggleSwitch/ToggleSwitch.js +1 -3
  527. package/esm/core/Tooltip/Tooltip.d.ts +0 -1
  528. package/esm/core/Tooltip/Tooltip.js +0 -1
  529. package/esm/core/TransferList/TransferList.d.ts +69 -0
  530. package/esm/core/TransferList/TransferList.js +141 -0
  531. package/esm/core/TransferList/index.d.ts +3 -0
  532. package/esm/core/TransferList/index.js +6 -0
  533. package/esm/core/Tree/Tree.d.ts +0 -1
  534. package/esm/core/Tree/Tree.js +9 -14
  535. package/esm/core/Tree/TreeNode.d.ts +0 -1
  536. package/esm/core/Tree/TreeNode.js +9 -11
  537. package/esm/core/Tree/TreeNodeExpander.d.ts +0 -1
  538. package/esm/core/Tree/TreeNodeExpander.js +0 -1
  539. package/esm/core/Typography/Anchor/Anchor.d.ts +0 -1
  540. package/esm/core/Typography/Anchor/Anchor.js +0 -1
  541. package/esm/core/Typography/Blockquote/Blockquote.d.ts +0 -1
  542. package/esm/core/Typography/Blockquote/Blockquote.js +0 -1
  543. package/esm/core/Typography/Code/Code.d.ts +0 -1
  544. package/esm/core/Typography/Code/Code.js +0 -1
  545. package/esm/core/Typography/Kbd/Kbd.d.ts +0 -1
  546. package/esm/core/Typography/Kbd/Kbd.js +0 -1
  547. package/esm/core/Typography/Text/Text.d.ts +0 -1
  548. package/esm/core/Typography/Text/Text.js +0 -1
  549. package/esm/core/index.d.ts +1 -0
  550. package/esm/core/index.js +1 -0
  551. package/esm/core/utils/color/ColorValue.js +9 -15
  552. package/esm/core/utils/components/AutoclearingHiddenLiveRegion.js +2 -3
  553. package/esm/core/utils/components/Divider.d.ts +0 -1
  554. package/esm/core/utils/components/Divider.js +0 -1
  555. package/esm/core/utils/components/Flex.d.ts +0 -1
  556. package/esm/core/utils/components/Flex.js +0 -1
  557. package/esm/core/utils/components/FocusTrap.js +4 -4
  558. package/esm/core/utils/components/Icon.d.ts +0 -1
  559. package/esm/core/utils/components/Icon.js +0 -1
  560. package/esm/core/utils/components/InputContainer.d.ts +0 -1
  561. package/esm/core/utils/components/InputContainer.js +0 -1
  562. package/esm/core/utils/components/InputFlexContainer.d.ts +0 -1
  563. package/esm/core/utils/components/InputFlexContainer.js +0 -1
  564. package/esm/core/utils/components/LinkAction.d.ts +0 -1
  565. package/esm/core/utils/components/LinkAction.js +0 -1
  566. package/esm/core/utils/components/MiddleTextTruncation.js +1 -2
  567. package/esm/core/utils/components/Popover.d.ts +0 -1
  568. package/esm/core/utils/components/Popover.js +5 -9
  569. package/esm/core/utils/components/Resizer.js +7 -6
  570. package/esm/core/utils/components/VirtualScroll.js +14 -21
  571. package/esm/core/utils/components/VisuallyHidden.d.ts +0 -1
  572. package/esm/core/utils/components/VisuallyHidden.js +0 -1
  573. package/esm/core/utils/functions/dom.d.ts +6 -0
  574. package/esm/core/utils/functions/dom.js +19 -5
  575. package/esm/core/utils/functions/index.d.ts +0 -1
  576. package/esm/core/utils/functions/index.js +0 -1
  577. package/esm/core/utils/functions/polymorphic.js +9 -1
  578. package/esm/core/utils/functions/supports.js +1 -1
  579. package/esm/core/utils/hooks/index.d.ts +0 -1
  580. package/esm/core/utils/hooks/index.js +0 -1
  581. package/esm/core/utils/hooks/useContainerWidth.js +1 -1
  582. package/esm/core/utils/hooks/useDragAndDrop.js +8 -10
  583. package/esm/core/utils/hooks/useEventListener.js +1 -1
  584. package/esm/core/utils/hooks/useGlobals.d.ts +9 -4
  585. package/esm/core/utils/hooks/useGlobals.js +6 -6
  586. package/esm/core/utils/hooks/useId.js +1 -2
  587. package/esm/core/utils/hooks/useIntersection.js +2 -3
  588. package/esm/core/utils/hooks/useMediaQuery.js +6 -8
  589. package/esm/core/utils/hooks/useOverflow.js +1 -2
  590. package/esm/core/utils/hooks/useResizeObserver.js +3 -4
  591. package/esm/styles.d.ts +5 -0
  592. package/esm/styles.js +451 -0
  593. package/package.json +14 -11
  594. package/styles.css +1940 -0
  595. package/cjs/core/utils/functions/styles.d.ts +0 -6
  596. package/cjs/core/utils/functions/styles.js +0 -21
  597. package/cjs/core/utils/hooks/useIsThemeAlreadySet.d.ts +0 -7
  598. package/cjs/core/utils/hooks/useIsThemeAlreadySet.js +0 -54
  599. package/esm/core/utils/functions/styles.d.ts +0 -6
  600. package/esm/core/utils/functions/styles.js +0 -17
  601. package/esm/core/utils/hooks/useIsThemeAlreadySet.d.ts +0 -7
  602. package/esm/core/utils/hooks/useIsThemeAlreadySet.js +0 -27
@@ -8,7 +8,6 @@ import { IconButton } from '../Buttons/index.js';
8
8
  import { Input } from '../Input/index.js';
9
9
  import { ColorValue, InputContainer, SvgSwap, Box } from '../utils/index.js';
10
10
  import { useColorPickerContext } from './ColorPickerContext.js';
11
- import '@itwin/itwinui-css/css/color-picker.css';
12
11
  /**
13
12
  * `ColorInputPanel` shows input fields to enter precise color values in the specified format.
14
13
  * It also allows switching between the specified formats using a swap button.
@@ -19,7 +18,6 @@ import '@itwin/itwinui-css/css/color-picker.css';
19
18
  * </ColorPicker>
20
19
  */
21
20
  export const ColorInputPanel = React.forwardRef((props, ref) => {
22
- var _a, _b, _c, _d, _f, _g, _h, _j;
23
21
  const { defaultColorFormat, allowedColorFormats = ['hsl', 'rgb', 'hex'], className, ...rest } = props;
24
22
  const inputsContainerRef = React.useRef(null);
25
23
  const { activeColor, applyHsvColorChange, hsvColor, showAlpha } = useColorPickerContext();
@@ -30,14 +28,13 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
30
28
  // need to use state since input may have parsing error
31
29
  const [input, setInput] = React.useState(['', '', '', '']);
32
30
  React.useEffect(() => {
33
- var _a, _b;
34
31
  if (currentFormat === 'hsl') {
35
32
  const hsl = activeColor.toHslColor();
36
33
  setInput([
37
34
  ColorValue.getFormattedColorNumber(hsvColor.h),
38
35
  ColorValue.getFormattedColorNumber(hsl.s),
39
36
  ColorValue.getFormattedColorNumber(hsl.l),
40
- ColorValue.getFormattedColorNumber((_a = hsl.a) !== null && _a !== void 0 ? _a : activeColor.getAlpha() / 255, 2),
37
+ ColorValue.getFormattedColorNumber(hsl.a ?? activeColor.getAlpha() / 255, 2),
41
38
  ]);
42
39
  }
43
40
  else if (currentFormat === 'rgb') {
@@ -46,7 +43,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
46
43
  rgb.r.toString(),
47
44
  rgb.g.toString(),
48
45
  rgb.b.toString(),
49
- ColorValue.getFormattedColorNumber((_b = rgb.a) !== null && _b !== void 0 ? _b : activeColor.getAlpha() / 255, 2),
46
+ ColorValue.getFormattedColorNumber(rgb.a ?? activeColor.getAlpha() / 255, 2),
50
47
  ]);
51
48
  }
52
49
  else {
@@ -56,9 +53,8 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
56
53
  }, [activeColor, hsvColor.h, currentFormat, showAlpha]);
57
54
  const [validHexInput, setValidHexInput] = React.useState(true);
58
55
  const swapColorFormat = React.useCallback(() => {
59
- var _a;
60
- const newFormat = (_a = allowedColorFormats[(allowedColorFormats.indexOf(currentFormat) + 1) %
61
- allowedColorFormats.length]) !== null && _a !== void 0 ? _a : allowedColorFormats[0];
56
+ const newFormat = allowedColorFormats[(allowedColorFormats.indexOf(currentFormat) + 1) %
57
+ allowedColorFormats.length] ?? allowedColorFormats[0];
62
58
  setCurrentFormat(newFormat);
63
59
  }, [currentFormat, allowedColorFormats]);
64
60
  const isFocusInside = (focused) => !!(focused &&
@@ -139,7 +135,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
139
135
  React.createElement(InputContainer, { status: Number(input[0]) < 0 || Number(input[0]) > 360
140
136
  ? 'negative'
141
137
  : undefined },
142
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '359', step: '.1', placeholder: 'H', value: (_a = input[0]) !== null && _a !== void 0 ? _a : '', onChange: (event) => {
138
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '359', step: '.1', placeholder: 'H', value: input[0] ?? '', onChange: (event) => {
143
139
  setInput([event.target.value, input[1], input[2], input[3]]);
144
140
  }, onKeyDown: (event) => {
145
141
  if (event.key === 'Enter') {
@@ -155,7 +151,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
155
151
  React.createElement(InputContainer, { status: Number(input[1]) < 0 || Number(input[1]) > 100
156
152
  ? 'negative'
157
153
  : undefined },
158
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '100', step: '.1', placeholder: 'S', value: (_b = input[1]) !== null && _b !== void 0 ? _b : '', onChange: (event) => {
154
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '100', step: '.1', placeholder: 'S', value: input[1] ?? '', onChange: (event) => {
159
155
  setInput([input[0], event.target.value, input[2], input[3]]);
160
156
  }, onKeyDown: (event) => {
161
157
  if (event.key === 'Enter') {
@@ -171,7 +167,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
171
167
  React.createElement(InputContainer, { status: Number(input[2]) < 0 || Number(input[2]) > 100
172
168
  ? 'negative'
173
169
  : undefined },
174
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '100', step: '.1', placeholder: 'L', value: (_c = input[2]) !== null && _c !== void 0 ? _c : '', onChange: (event) => {
170
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '100', step: '.1', placeholder: 'L', value: input[2] ?? '', onChange: (event) => {
175
171
  setInput([input[0], input[1], event.target.value, input[3]]);
176
172
  }, onKeyDown: (event) => {
177
173
  if (event.key === 'Enter') {
@@ -187,7 +183,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
187
183
  showAlpha && (React.createElement(InputContainer, { status: Number(input[3]) < 0 || Number(input[3]) > 1
188
184
  ? 'negative'
189
185
  : undefined },
190
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '1', step: '.01', placeholder: 'A', value: (_d = input[3]) !== null && _d !== void 0 ? _d : '', onChange: (event) => {
186
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '1', step: '.01', placeholder: 'A', value: input[3] ?? '', onChange: (event) => {
191
187
  setInput([input[0], input[1], input[2], event.target.value]);
192
188
  }, onKeyDown: (event) => {
193
189
  if (event.key === 'Enter') {
@@ -204,7 +200,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
204
200
  React.createElement(InputContainer, { status: Number(input[0]) < 0 || Number(input[0]) > 255
205
201
  ? 'negative'
206
202
  : undefined },
207
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'R', value: (_f = input[0]) !== null && _f !== void 0 ? _f : '', onChange: (event) => {
203
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'R', value: input[0] ?? '', onChange: (event) => {
208
204
  setInput([event.target.value, input[1], input[2], input[3]]);
209
205
  }, onKeyDown: (event) => {
210
206
  if (event.key === 'Enter') {
@@ -220,7 +216,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
220
216
  React.createElement(InputContainer, { status: Number(input[1]) < 0 || Number(input[1]) > 255
221
217
  ? 'negative'
222
218
  : undefined },
223
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'G', value: (_g = input[1]) !== null && _g !== void 0 ? _g : '', onChange: (event) => {
219
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'G', value: input[1] ?? '', onChange: (event) => {
224
220
  setInput([input[0], event.target.value, input[2], input[3]]);
225
221
  }, onKeyDown: (event) => {
226
222
  if (event.key === 'Enter') {
@@ -236,7 +232,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
236
232
  React.createElement(InputContainer, { status: Number(input[2]) < 0 || Number(input[2]) > 255
237
233
  ? 'negative'
238
234
  : undefined },
239
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'B', value: (_h = input[2]) !== null && _h !== void 0 ? _h : '', onChange: (event) => {
235
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '255', placeholder: 'B', value: input[2] ?? '', onChange: (event) => {
240
236
  setInput([input[0], input[1], event.target.value, input[3]]);
241
237
  }, onKeyDown: (event) => {
242
238
  if (event.key === 'Enter') {
@@ -252,7 +248,7 @@ export const ColorInputPanel = React.forwardRef((props, ref) => {
252
248
  showAlpha && (React.createElement(InputContainer, { status: Number(input[3]) < 0 || Number(input[3]) > 1
253
249
  ? 'negative'
254
250
  : undefined },
255
- React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '1', step: '.01', placeholder: 'A', value: (_j = input[3]) !== null && _j !== void 0 ? _j : '', onChange: (event) => {
251
+ React.createElement(Input, { size: 'small', type: 'number', min: '0', max: '1', step: '.01', placeholder: 'A', value: input[3] ?? '', onChange: (event) => {
256
252
  setInput([input[0], input[1], input[2], event.target.value]);
257
253
  }, onKeyDown: (event) => {
258
254
  if (event.key === 'Enter') {
@@ -1,7 +1,6 @@
1
1
  import * as React from 'react';
2
2
  import { ColorValue } from '../utils/index.js';
3
3
  import type { ColorType, PolymorphicForwardRefComponent } from '../utils/index.js';
4
- import '@itwin/itwinui-css/css/color-picker.css';
5
4
  export declare type ColorPaletteProps = {
6
5
  /**
7
6
  * Label shown above the palette.
@@ -8,7 +8,6 @@ import { ColorValue, getFocusableElements, useMergedRefs, Box, } from '../utils/
8
8
  import { getColorValue } from './ColorPicker.js';
9
9
  import { ColorSwatch } from './ColorSwatch.js';
10
10
  import { useColorPickerContext } from './ColorPickerContext.js';
11
- import '@itwin/itwinui-css/css/color-picker.css';
12
11
  /**
13
12
  * `ColorPalette` is used to show a group of `ColorSwatch` components.
14
13
  * @example
@@ -26,9 +25,8 @@ export const ColorPalette = React.forwardRef((props, ref) => {
26
25
  const [focusedIndex, setFocusedIndex] = React.useState();
27
26
  // callback ref to set tabindex=0 on first child if none of the swatches are tabbable
28
27
  const setDefaultTabIndex = (el) => {
29
- var _a;
30
28
  if (el && !el.querySelector('[tabindex="0"]')) {
31
- (_a = el.firstElementChild) === null || _a === void 0 ? void 0 : _a.setAttribute('tabindex', '0');
29
+ el.firstElementChild?.setAttribute('tabindex', '0');
32
30
  }
33
31
  };
34
32
  const paletteRef = React.useRef(null);
@@ -42,7 +40,7 @@ export const ColorPalette = React.forwardRef((props, ref) => {
42
40
  if (!swatches.length) {
43
41
  return;
44
42
  }
45
- const currentIndex = swatches.findIndex((swatch) => { var _a; return swatch === ((_a = paletteRef.current) === null || _a === void 0 ? void 0 : _a.ownerDocument.activeElement); });
43
+ const currentIndex = swatches.findIndex((swatch) => swatch === paletteRef.current?.ownerDocument.activeElement);
46
44
  if (currentIndex < 0) {
47
45
  return;
48
46
  }
@@ -84,10 +82,9 @@ export const ColorPalette = React.forwardRef((props, ref) => {
84
82
  };
85
83
  // call focus() when focusedIndex changes
86
84
  React.useEffect(() => {
87
- var _a;
88
85
  if (focusedIndex != null) {
89
86
  const swatches = getFocusableElements(paletteRef.current);
90
- (_a = swatches[focusedIndex]) === null || _a === void 0 ? void 0 : _a.focus();
87
+ swatches[focusedIndex]?.focus();
91
88
  }
92
89
  }, [focusedIndex]);
93
90
  return (React.createElement(Box, { className: cx('iui-color-palette-wrapper', className), ref: ref, ...rest },
@@ -99,7 +96,7 @@ export const ColorPalette = React.forwardRef((props, ref) => {
99
96
  const color = getColorValue(_color);
100
97
  return (React.createElement(ColorSwatch, { key: index, color: color, onClick: (event) => {
101
98
  event.preventDefault();
102
- onChangeComplete === null || onChangeComplete === void 0 ? void 0 : onChangeComplete(color);
99
+ onChangeComplete?.(color);
103
100
  setActiveColor(color);
104
101
  }, isActive: color.equals(activeColor) }));
105
102
  }))));
@@ -1,5 +1,4 @@
1
1
  import * as React from 'react';
2
- import '@itwin/itwinui-css/css/color-picker.css';
3
2
  import { ColorValue } from '../utils/index.js';
4
3
  import type { ColorType, PolymorphicForwardRefComponent } from '../utils/index.js';
5
4
  export declare const getColorValue: (color: ColorType | ColorValue | undefined) => ColorValue;
@@ -3,7 +3,6 @@
3
3
  * See LICENSE.md in the project root for license terms and full copyright notice.
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import * as React from 'react';
6
- import '@itwin/itwinui-css/css/color-picker.css';
7
6
  import { ColorValue, getTabbableElements, useMergedRefs, Box, } from '../utils/index.js';
8
7
  import cx from 'classnames';
9
8
  import { ColorPickerContext } from './ColorPickerContext.js';
@@ -55,13 +54,13 @@ export const ColorPicker = React.forwardRef((props, forwardedRef) => {
55
54
  const applyHsvColorChange = React.useCallback((newColor, selectionChanged, newColorValue) => {
56
55
  // save the HSV values
57
56
  setHsvColor(newColor);
58
- const newActiveColor = newColorValue !== null && newColorValue !== void 0 ? newColorValue : ColorValue.create(newColor);
57
+ const newActiveColor = newColorValue ?? ColorValue.create(newColor);
59
58
  // Only update selected color when dragging is done
60
59
  if (selectionChanged) {
61
- onChangeComplete === null || onChangeComplete === void 0 ? void 0 : onChangeComplete(newActiveColor);
60
+ onChangeComplete?.(newActiveColor);
62
61
  }
63
62
  else {
64
- onChange === null || onChange === void 0 ? void 0 : onChange(newActiveColor);
63
+ onChange?.(newActiveColor);
65
64
  }
66
65
  activeColorTbgr.current = newActiveColor.toTbgr();
67
66
  // this converts it to store in tbgr
@@ -1,4 +1,3 @@
1
- import '@itwin/itwinui-css/css/color-picker.css';
2
1
  import { ColorValue } from '../utils/index.js';
3
2
  import type { ColorType, PolymorphicForwardRefComponent } from '../utils/index.js';
4
3
  declare type ColorSwatchProps = {
@@ -4,7 +4,6 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import * as React from 'react';
6
6
  import cx from 'classnames';
7
- import '@itwin/itwinui-css/css/color-picker.css';
8
7
  import { ColorValue, Box } from '../utils/index.js';
9
8
  import { getColorValue } from './ColorPicker.js';
10
9
  /**
@@ -2,7 +2,6 @@ import * as React from 'react';
2
2
  import type { SelectOption } from '../Select/index.js';
3
3
  import type { Input } from '../Input/Input.js';
4
4
  import type { PopoverProps, InputContainerProps, CommonProps } from '../utils/index.js';
5
- import 'tippy.js/animations/shift-away.css';
6
5
  declare type ActionType = 'added' | 'removed';
7
6
  declare type MultipleOnChangeProps<T> = {
8
7
  value: T;
@@ -7,7 +7,6 @@ import { MenuExtraContent } from '../Menu/index.js';
7
7
  import SelectTag from '../Select/SelectTag.js';
8
8
  import { Text } from '../Typography/index.js';
9
9
  import { getRandomValue, mergeRefs, useLatestRef, useIsomorphicLayoutEffect, AutoclearingHiddenLiveRegion, } from '../utils/index.js';
10
- import 'tippy.js/animations/shift-away.css';
11
10
  import { ComboBoxActionContext, comboBoxReducer, ComboBoxRefsContext, ComboBoxStateContext, } from './helpers.js';
12
11
  import { ComboBoxDropdown } from './ComboBoxDropdown.js';
13
12
  import { ComboBoxEndIcon } from './ComboBoxEndIcon.js';
@@ -25,8 +24,7 @@ const isSingleOnChange = (onChange, multiple) => {
25
24
  };
26
25
  /** Returns either `option.id` or derives a stable id using `idPrefix` and `option.label` (without whitespace) */
27
26
  const getOptionId = (option, idPrefix) => {
28
- var _a;
29
- return (_a = option.id) !== null && _a !== void 0 ? _a : `${idPrefix}-option-${option.label.replace(/\s/g, '-')}`;
27
+ return option.id ?? `${idPrefix}-option-${option.label.replace(/\s/g, '-')}`;
30
28
  };
31
29
  /**
32
30
  * ComboBox component that allows typing a value to filter the options in dropdown list.
@@ -42,13 +40,11 @@ const getOptionId = (option, idPrefix) => {
42
40
  * />
43
41
  */
44
42
  export const ComboBox = (props) => {
45
- var _a, _b;
46
43
  const { options, value: valueProp, onChange, filterFunction, inputProps, dropdownMenuProps, emptyStateMessage = 'No options found', itemRenderer, enableVirtualization = false, multiple = false, onShow, onHide, ...rest } = props;
47
44
  // Generate a stateful random id if not specified
48
- const [id] = React.useState(() => {
49
- var _a, _b;
50
- return (_b = (_a = props.id) !== null && _a !== void 0 ? _a : ((inputProps === null || inputProps === void 0 ? void 0 : inputProps.id) && `${inputProps.id}-cb`)) !== null && _b !== void 0 ? _b : `iui-cb-${getRandomValue(10)}`;
51
- });
45
+ const [id] = React.useState(() => props.id ??
46
+ (inputProps?.id && `${inputProps.id}-cb`) ??
47
+ `iui-cb-${getRandomValue(10)}`);
52
48
  // Refs get set in subcomponents
53
49
  const inputRef = React.useRef(null);
54
50
  const menuRef = React.useRef(null);
@@ -74,7 +70,7 @@ export const ComboBox = (props) => {
74
70
  const getSelectedIndexes = React.useCallback(() => {
75
71
  if (isMultipleEnabled(valueProp, multiple)) {
76
72
  const indexArray = [];
77
- valueProp === null || valueProp === void 0 ? void 0 : valueProp.forEach((value) => {
73
+ valueProp?.forEach((value) => {
78
74
  const indexToAdd = options.findIndex((option) => option.value === value);
79
75
  if (indexToAdd > -1) {
80
76
  indexArray.push(indexToAdd);
@@ -93,10 +89,9 @@ export const ComboBox = (props) => {
93
89
  focusedIndex: -1,
94
90
  });
95
91
  useIsomorphicLayoutEffect(() => {
96
- var _a, _b;
97
92
  // When the dropdown opens
98
93
  if (isOpen) {
99
- (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus(); // Focus the input
94
+ inputRef.current?.focus(); // Focus the input
100
95
  // Reset the filtered list (does not reset when multiple enabled)
101
96
  if (!multiple) {
102
97
  setFilteredOptions(optionsRef.current);
@@ -110,7 +105,7 @@ export const ComboBox = (props) => {
110
105
  // Reset the input value if not multiple
111
106
  if (!isMultipleEnabled(selected, multiple)) {
112
107
  setInputValue(selected != undefined && selected >= 0
113
- ? (_b = optionsRef.current[selected]) === null || _b === void 0 ? void 0 : _b.label
108
+ ? optionsRef.current[selected]?.label
114
109
  : '');
115
110
  }
116
111
  }
@@ -125,9 +120,9 @@ export const ComboBox = (props) => {
125
120
  // Update filtered options to the latest value options according to input value
126
121
  const [filteredOptions, setFilteredOptions] = React.useState(options);
127
122
  React.useEffect(() => {
128
- var _a;
129
123
  if (inputValue) {
130
- setFilteredOptions((_a = filterFunction === null || filterFunction === void 0 ? void 0 : filterFunction(options, inputValue)) !== null && _a !== void 0 ? _a : options.filter((option) => option.label.toLowerCase().includes(inputValue.toLowerCase())));
124
+ setFilteredOptions(filterFunction?.(options, inputValue) ??
125
+ options.filter((option) => option.label.toLowerCase().includes(inputValue.toLowerCase())));
131
126
  }
132
127
  else {
133
128
  setFilteredOptions(options);
@@ -137,18 +132,18 @@ export const ComboBox = (props) => {
137
132
  // eslint-disable-next-line react-hooks/exhaustive-deps
138
133
  }, [options]);
139
134
  // Filter options based on input value
140
- const [inputValue, setInputValue] = React.useState((_b = (_a = inputProps === null || inputProps === void 0 ? void 0 : inputProps.value) === null || _a === void 0 ? void 0 : _a.toString()) !== null && _b !== void 0 ? _b : '');
135
+ const [inputValue, setInputValue] = React.useState(inputProps?.value?.toString() ?? '');
141
136
  const [liveRegionSelection, setLiveRegionSelection] = React.useState('');
142
137
  const handleOnInput = React.useCallback((event) => {
143
- var _a, _b;
144
138
  const { value } = event.currentTarget;
145
139
  setInputValue(value);
146
140
  dispatch({ type: 'open' }); // reopen when typing
147
- setFilteredOptions((_a = filterFunction === null || filterFunction === void 0 ? void 0 : filterFunction(optionsRef.current, value)) !== null && _a !== void 0 ? _a : optionsRef.current.filter((option) => option.label.toLowerCase().includes(value.toLowerCase())));
141
+ setFilteredOptions(filterFunction?.(optionsRef.current, value) ??
142
+ optionsRef.current.filter((option) => option.label.toLowerCase().includes(value.toLowerCase())));
148
143
  if (focusedIndex != -1) {
149
144
  dispatch({ type: 'focus', value: -1 });
150
145
  }
151
- (_b = inputProps === null || inputProps === void 0 ? void 0 : inputProps.onChange) === null || _b === void 0 ? void 0 : _b.call(inputProps, event);
146
+ inputProps?.onChange?.(event);
152
147
  }, [filterFunction, focusedIndex, inputProps, optionsRef]);
153
148
  // When the value prop changes, update the selected index/indices
154
149
  React.useEffect(() => {
@@ -197,23 +192,21 @@ export const ComboBox = (props) => {
197
192
  }, [selected]);
198
193
  // Calls user defined onChange
199
194
  const onChangeHandler = React.useCallback((__originalIndex, actionType, newArray) => {
200
- var _a, _b, _c, _d;
201
195
  if (isSingleOnChange(onChangeProp.current, multiple)) {
202
- (_a = onChangeProp.current) === null || _a === void 0 ? void 0 : _a.call(onChangeProp, (_b = optionsRef.current[__originalIndex]) === null || _b === void 0 ? void 0 : _b.value);
196
+ onChangeProp.current?.(optionsRef.current[__originalIndex]?.value);
203
197
  }
204
198
  else {
205
199
  actionType &&
206
200
  newArray &&
207
- ((_c = onChangeProp.current) === null || _c === void 0 ? void 0 : _c.call(onChangeProp, newArray === null || newArray === void 0 ? void 0 : newArray.map((item) => { var _a; return (_a = optionsRef.current[item]) === null || _a === void 0 ? void 0 : _a.value; }), {
208
- value: (_d = optionsRef.current[__originalIndex]) === null || _d === void 0 ? void 0 : _d.value,
201
+ onChangeProp.current?.(newArray?.map((item) => optionsRef.current[item]?.value), {
202
+ value: optionsRef.current[__originalIndex]?.value,
209
203
  type: actionType,
210
- }));
204
+ });
211
205
  }
212
206
  }, [multiple, onChangeProp, optionsRef]);
213
207
  const onClickHandler = React.useCallback((__originalIndex) => {
214
- var _a, _b;
215
- (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.focus({ preventScroll: true }); // return focus to input
216
- if ((_b = optionsRef.current[__originalIndex]) === null || _b === void 0 ? void 0 : _b.disabled) {
208
+ inputRef.current?.focus({ preventScroll: true }); // return focus to input
209
+ if (optionsRef.current[__originalIndex]?.disabled) {
217
210
  return;
218
211
  }
219
212
  if (isMultipleEnabled(selected, multiple)) {
@@ -225,7 +218,7 @@ export const ComboBox = (props) => {
225
218
  onChangeHandler(__originalIndex, actionType, newArray);
226
219
  // update live region
227
220
  setLiveRegionSelection(newArray
228
- .map((item) => { var _a; return (_a = optionsRef.current[item]) === null || _a === void 0 ? void 0 : _a.label; })
221
+ .map((item) => optionsRef.current[item]?.label)
229
222
  .filter(Boolean)
230
223
  .join(', '));
231
224
  }
@@ -246,7 +239,7 @@ export const ComboBox = (props) => {
246
239
  const optionId = getOptionId(option, id);
247
240
  const { __originalIndex } = optionsExtraInfoRef.current[optionId];
248
241
  const { icon, startIcon: startIconProp, ...restOptions } = option;
249
- const startIcon = startIconProp !== null && startIconProp !== void 0 ? startIconProp : icon;
242
+ const startIcon = startIconProp ?? icon;
250
243
  const customItem = itemRenderer
251
244
  ? itemRenderer(option, {
252
245
  isFocused: focusedIndex === __originalIndex,
@@ -257,9 +250,8 @@ export const ComboBox = (props) => {
257
250
  : null;
258
251
  return customItem ? (React.cloneElement(customItem, {
259
252
  onClick: (e) => {
260
- var _a, _b;
261
253
  onClickHandler(__originalIndex);
262
- (_b = (_a = customItem.props).onClick) === null || _b === void 0 ? void 0 : _b.call(_a, e);
254
+ customItem.props.onClick?.(e);
263
255
  },
264
256
  // ComboBox.MenuItem handles scrollIntoView, data-iui-index and focused through context
265
257
  // but we still need to pass them here for backwards compatibility with MenuItem
@@ -268,7 +260,7 @@ export const ComboBox = (props) => {
268
260
  'data-iui-filtered-index': filteredIndex,
269
261
  ref: mergeRefs(customItem.props.ref, (el) => {
270
262
  if (!enableVirtualization && focusedIndex === __originalIndex) {
271
- el === null || el === void 0 ? void 0 : el.scrollIntoView({ block: 'nearest' });
263
+ el?.scrollIntoView({ block: 'nearest' });
272
264
  }
273
265
  }),
274
266
  })) : (React.createElement(ComboBoxMenuItem, { key: optionId, id: optionId, startIcon: startIcon, ...restOptions, isSelected: isMenuItemSelected(__originalIndex), onClick: () => {
@@ -298,7 +290,7 @@ export const ComboBox = (props) => {
298
290
  getMenuItem,
299
291
  multiple,
300
292
  } },
301
- React.createElement(ComboBoxInputContainer, { disabled: inputProps === null || inputProps === void 0 ? void 0 : inputProps.disabled, ...rest },
293
+ React.createElement(ComboBoxInputContainer, { disabled: inputProps?.disabled, ...rest },
302
294
  React.createElement(React.Fragment, null,
303
295
  React.createElement(ComboBoxInput, { value: inputValue, ...inputProps, onChange: handleOnInput, selectTags: isMultipleEnabled(selected, multiple)
304
296
  ? selected.map((index) => {
@@ -306,7 +298,7 @@ export const ComboBox = (props) => {
306
298
  return (React.createElement(SelectTag, { key: item.label, label: item.label }));
307
299
  })
308
300
  : undefined })),
309
- React.createElement(ComboBoxEndIcon, { disabled: inputProps === null || inputProps === void 0 ? void 0 : inputProps.disabled, isOpen: isOpen }),
301
+ React.createElement(ComboBoxEndIcon, { disabled: inputProps?.disabled, isOpen: isOpen }),
310
302
  multiple ? (React.createElement(AutoclearingHiddenLiveRegion, { text: liveRegionSelection })) : null),
311
303
  React.createElement(ComboBoxDropdown, { ...dropdownMenuProps, onShow: onShow, onHide: onHide },
312
304
  React.createElement(ComboBoxMenu, null, filteredOptions.length > 0 && !enableVirtualization
@@ -17,8 +17,7 @@ export const ComboBoxDropdown = React.forwardRef((props, forwardedRef) => {
17
17
  }
18
18
  }, [dispatch, props.visible]);
19
19
  return (React.createElement(Popover, { placement: 'bottom-start', visible: isOpen, onClickOutside: React.useCallback((_, { target }) => {
20
- var _a;
21
- if (!((_a = toggleButtonRef.current) === null || _a === void 0 ? void 0 : _a.contains(target))) {
20
+ if (!toggleButtonRef.current?.contains(target)) {
22
21
  dispatch({ type: 'close' });
23
22
  }
24
23
  }, [dispatch, toggleButtonRef]), animation: 'shift-away', duration: 200, reference: inputRef, ref: forwardedRef, content: children, ...rest }));
@@ -17,6 +17,6 @@ export const ComboBoxEndIcon = React.forwardRef((props, forwardedRef) => {
17
17
  'iui-open': isOpen,
18
18
  }, className), onClick: mergeEventHandlers(onClickProp, () => {
19
19
  dispatch({ type: isOpen ? 'close' : 'open' });
20
- }), ...rest }, children !== null && children !== void 0 ? children : React.createElement(SvgCaretDownSmall, { "aria-hidden": true })));
20
+ }), ...rest }, children ?? React.createElement(SvgCaretDownSmall, { "aria-hidden": true })));
21
21
  });
22
22
  ComboBoxEndIcon.displayName = 'ComboBoxEndIcon';
@@ -13,18 +13,16 @@ export const ComboBoxInput = React.forwardRef((props, forwardedRef) => {
13
13
  const dispatch = useSafeContext(ComboBoxActionContext);
14
14
  const { inputRef, menuRef, optionsExtraInfoRef } = useSafeContext(ComboBoxRefsContext);
15
15
  const refs = useMergedRefs(inputRef, forwardedRef);
16
- const focusedIndexRef = React.useRef(focusedIndex !== null && focusedIndex !== void 0 ? focusedIndex : -1);
16
+ const focusedIndexRef = React.useRef(focusedIndex ?? -1);
17
17
  React.useEffect(() => {
18
- focusedIndexRef.current = focusedIndex !== null && focusedIndex !== void 0 ? focusedIndex : -1;
18
+ focusedIndexRef.current = focusedIndex ?? -1;
19
19
  }, [focusedIndex]);
20
20
  const getIdFromIndex = (index) => {
21
- var _a, _b, _c;
22
- return ((_c = (_b = (_a = menuRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-iui-index="${index}"]`)) === null || _b === void 0 ? void 0 : _b.id) !== null && _c !== void 0 ? _c : '');
21
+ return (menuRef.current?.querySelector(`[data-iui-index="${index}"]`)?.id ?? '');
23
22
  };
24
23
  const handleKeyDown = React.useCallback((event) => {
25
- var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
26
- onKeyDownProp === null || onKeyDownProp === void 0 ? void 0 : onKeyDownProp(event);
27
- const length = (_a = Object.keys(optionsExtraInfoRef.current).length) !== null && _a !== void 0 ? _a : 0;
24
+ onKeyDownProp?.(event);
25
+ const length = Object.keys(optionsExtraInfoRef.current).length ?? 0;
28
26
  if (event.altKey) {
29
27
  return;
30
28
  }
@@ -38,22 +36,23 @@ export const ComboBoxInput = React.forwardRef((props, forwardedRef) => {
38
36
  return;
39
37
  }
40
38
  if (focusedIndexRef.current === -1) {
41
- const currentElement = (_b = menuRef.current) === null || _b === void 0 ? void 0 : _b.querySelector('[data-iui-index]');
39
+ const currentElement = menuRef.current?.querySelector('[data-iui-index]');
42
40
  return dispatch({
43
41
  type: 'focus',
44
- value: Number((_c = currentElement === null || currentElement === void 0 ? void 0 : currentElement.getAttribute('data-iui-index')) !== null && _c !== void 0 ? _c : 0),
42
+ value: Number(currentElement?.getAttribute('data-iui-index') ?? 0),
45
43
  });
46
44
  }
47
45
  // If virtualization is enabled, dont let round scrolling
48
46
  if (enableVirtualization &&
49
- !((_e = (_d = menuRef.current) === null || _d === void 0 ? void 0 : _d.querySelector(`[data-iui-index="${focusedIndexRef.current}"]`)) === null || _e === void 0 ? void 0 : _e.nextElementSibling)) {
47
+ !menuRef.current?.querySelector(`[data-iui-index="${focusedIndexRef.current}"]`)?.nextElementSibling) {
50
48
  return;
51
49
  }
52
50
  let nextIndex = focusedIndexRef.current;
53
51
  do {
54
- const currentElement = (_f = menuRef.current) === null || _f === void 0 ? void 0 : _f.querySelector(`[data-iui-index="${nextIndex}"]`);
55
- const nextElement = (_g = currentElement === null || currentElement === void 0 ? void 0 : currentElement.nextElementSibling) !== null && _g !== void 0 ? _g : (_h = menuRef.current) === null || _h === void 0 ? void 0 : _h.querySelector('[data-iui-index]');
56
- nextIndex = Number(nextElement === null || nextElement === void 0 ? void 0 : nextElement.getAttribute('data-iui-index'));
52
+ const currentElement = menuRef.current?.querySelector(`[data-iui-index="${nextIndex}"]`);
53
+ const nextElement = currentElement?.nextElementSibling ??
54
+ menuRef.current?.querySelector('[data-iui-index]');
55
+ nextIndex = Number(nextElement?.getAttribute('data-iui-index'));
57
56
  if (nextElement) {
58
57
  return dispatch({ type: 'focus', value: nextIndex });
59
58
  }
@@ -70,20 +69,22 @@ export const ComboBoxInput = React.forwardRef((props, forwardedRef) => {
70
69
  }
71
70
  // If virtualization is enabled, dont let round scrolling
72
71
  if (enableVirtualization &&
73
- !((_k = (_j = menuRef.current) === null || _j === void 0 ? void 0 : _j.querySelector(`[data-iui-index="${focusedIndexRef.current}"]`)) === null || _k === void 0 ? void 0 : _k.previousElementSibling)) {
72
+ !menuRef.current?.querySelector(`[data-iui-index="${focusedIndexRef.current}"]`)?.previousElementSibling) {
74
73
  return;
75
74
  }
76
75
  if (focusedIndexRef.current === -1) {
77
76
  return dispatch({
78
77
  type: 'focus',
79
- value: (_m = (_l = Object.values(optionsExtraInfoRef.current)) === null || _l === void 0 ? void 0 : _l[length - 1].__originalIndex) !== null && _m !== void 0 ? _m : -1,
78
+ value: Object.values(optionsExtraInfoRef.current)?.[length - 1]
79
+ .__originalIndex ?? -1,
80
80
  });
81
81
  }
82
82
  let prevIndex = focusedIndexRef.current;
83
83
  do {
84
- const currentElement = (_o = menuRef.current) === null || _o === void 0 ? void 0 : _o.querySelector(`[data-iui-index="${prevIndex}"]`);
85
- const prevElement = (_p = currentElement === null || currentElement === void 0 ? void 0 : currentElement.previousElementSibling) !== null && _p !== void 0 ? _p : (_q = menuRef.current) === null || _q === void 0 ? void 0 : _q.querySelector('[data-iui-index]:last-of-type');
86
- prevIndex = Number(prevElement === null || prevElement === void 0 ? void 0 : prevElement.getAttribute('data-iui-index'));
84
+ const currentElement = menuRef.current?.querySelector(`[data-iui-index="${prevIndex}"]`);
85
+ const prevElement = currentElement?.previousElementSibling ??
86
+ menuRef.current?.querySelector('[data-iui-index]:last-of-type');
87
+ prevIndex = Number(prevElement?.getAttribute('data-iui-index'));
87
88
  if (prevElement) {
88
89
  return dispatch({ type: 'focus', value: prevIndex });
89
90
  }
@@ -94,7 +95,7 @@ export const ComboBoxInput = React.forwardRef((props, forwardedRef) => {
94
95
  event.preventDefault();
95
96
  if (isOpen) {
96
97
  if (focusedIndexRef.current > -1) {
97
- onClickHandler === null || onClickHandler === void 0 ? void 0 : onClickHandler(focusedIndexRef.current);
98
+ onClickHandler?.(focusedIndexRef.current);
98
99
  }
99
100
  }
100
101
  else {
@@ -122,7 +123,7 @@ export const ComboBoxInput = React.forwardRef((props, forwardedRef) => {
122
123
  ]);
123
124
  const handleFocus = React.useCallback((event) => {
124
125
  dispatch({ type: 'open' });
125
- onFocusProp === null || onFocusProp === void 0 ? void 0 : onFocusProp(event);
126
+ onFocusProp?.(event);
126
127
  }, [dispatch, onFocusProp]);
127
128
  const handleClick = React.useCallback(() => {
128
129
  if (!isOpen) {
@@ -8,7 +8,7 @@ import { Menu } from '../Menu/index.js';
8
8
  import { Surface } from '../Surface/index.js';
9
9
  import { useSafeContext, useMergedRefs, useVirtualization, mergeRefs, getWindow, } from '../utils/index.js';
10
10
  import { ComboBoxStateContext, ComboBoxRefsContext } from './helpers.js';
11
- const isOverflowOverlaySupported = () => { var _a, _b, _c; return (_c = (_b = (_a = getWindow()) === null || _a === void 0 ? void 0 : _a.CSS) === null || _b === void 0 ? void 0 : _b.supports) === null || _c === void 0 ? void 0 : _c.call(_b, 'overflow: overlay'); };
11
+ const isOverflowOverlaySupported = () => getWindow()?.CSS?.supports?.('overflow: overlay');
12
12
  const VirtualizedComboBoxMenu = React.forwardRef(({ children, className, style, ...rest }, forwardedRef) => {
13
13
  const { minWidth, id, filteredOptions, getMenuItem, focusedIndex } = useSafeContext(ComboBoxStateContext);
14
14
  const { menuRef } = useSafeContext(ComboBoxRefsContext);
@@ -17,12 +17,11 @@ const VirtualizedComboBoxMenu = React.forwardRef(({ children, className, style,
17
17
  : children, // Here is expected empty state content
18
18
  [filteredOptions, getMenuItem, children]);
19
19
  const focusedVisibleIndex = React.useMemo(() => {
20
- var _a, _b;
21
- const currentElement = (_a = menuRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-iui-index="${focusedIndex}"]`);
20
+ const currentElement = menuRef.current?.querySelector(`[data-iui-index="${focusedIndex}"]`);
22
21
  if (!currentElement) {
23
22
  return focusedIndex;
24
23
  }
25
- return Number((_b = currentElement.getAttribute('data-iui-filtered-index')) !== null && _b !== void 0 ? _b : focusedIndex);
24
+ return Number(currentElement.getAttribute('data-iui-filtered-index') ?? focusedIndex);
26
25
  }, [focusedIndex, menuRef]);
27
26
  const { outerProps, innerProps, visibleChildren } = useVirtualization({
28
27
  // 'Fool' VirtualScroll by passing length 1
@@ -11,11 +11,11 @@ export const ComboBoxMenuItem = React.memo(React.forwardRef((props, forwardedRef
11
11
  const { focusedIndex, enableVirtualization } = useSafeContext(ComboBoxStateContext);
12
12
  const focusRef = (el) => {
13
13
  if (!enableVirtualization && focusedIndex === index) {
14
- el === null || el === void 0 ? void 0 : el.scrollIntoView({ block: 'nearest' });
14
+ el?.scrollIntoView({ block: 'nearest' });
15
15
  }
16
16
  };
17
17
  const refs = useMergedRefs(forwardedRef, focusRef);
18
- return (React.createElement(ListItem, { actionable: true, size: size, active: isSelected, disabled: disabled, focused: focusedIndex === index, ref: refs, onClick: () => onClick === null || onClick === void 0 ? void 0 : onClick(value), role: role, tabIndex: role === 'presentation' ? undefined : -1, "aria-selected": isSelected, "aria-disabled": disabled, "data-iui-index": index, ...rest },
18
+ return (React.createElement(ListItem, { actionable: true, size: size, active: isSelected, disabled: disabled, focused: focusedIndex === index, ref: refs, onClick: () => onClick?.(value), role: role, tabIndex: role === 'presentation' ? undefined : -1, "aria-selected": isSelected, "aria-disabled": disabled, "data-iui-index": index, ...rest },
19
19
  startIcon && (React.createElement(ListItem.Icon, { as: 'span', "aria-hidden": true }, startIcon)),
20
20
  React.createElement(ListItem.Content, null,
21
21
  children,
@@ -4,7 +4,6 @@
4
4
  *--------------------------------------------------------------------------------------------*/
5
5
  import * as React from 'react';
6
6
  export const comboBoxReducer = (state, action) => {
7
- var _a, _b, _c, _d, _e;
8
7
  switch (action.type) {
9
8
  case 'open': {
10
9
  return { ...state, isOpen: true };
@@ -18,8 +17,8 @@ export const comboBoxReducer = (state, action) => {
18
17
  }
19
18
  return {
20
19
  ...state,
21
- selected: (_a = action.value) !== null && _a !== void 0 ? _a : state.selected,
22
- focusedIndex: (_b = action.value) !== null && _b !== void 0 ? _b : state.focusedIndex,
20
+ selected: action.value ?? state.selected,
21
+ focusedIndex: action.value ?? state.focusedIndex,
23
22
  };
24
23
  }
25
24
  case 'multiselect': {
@@ -32,12 +31,12 @@ export const comboBoxReducer = (state, action) => {
32
31
  if (Array.isArray(state.selected)) {
33
32
  return {
34
33
  ...state,
35
- focusedIndex: (_c = action.value) !== null && _c !== void 0 ? _c : -1,
34
+ focusedIndex: action.value ?? -1,
36
35
  };
37
36
  }
38
37
  return {
39
38
  ...state,
40
- focusedIndex: (_e = (_d = action.value) !== null && _d !== void 0 ? _d : state.selected) !== null && _e !== void 0 ? _e : -1,
39
+ focusedIndex: action.value ?? state.selected ?? -1,
41
40
  };
42
41
  }
43
42
  default: {