@carbon/react 1.83.0 → 1.84.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 (524) hide show
  1. package/.playwright/INTERNAL_AVT_REPORT_DO_NOT_USE.json +909 -874
  2. package/README.md +1 -1
  3. package/es/components/AILabel/index.js +27 -30
  4. package/es/components/AISkeleton/AISkeletonIcon.js +4 -5
  5. package/es/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  6. package/es/components/AISkeleton/AISkeletonText.js +4 -5
  7. package/es/components/Accordion/Accordion.Skeleton.js +9 -10
  8. package/es/components/Accordion/Accordion.js +10 -11
  9. package/es/components/Accordion/AccordionItem.js +13 -14
  10. package/es/components/Accordion/AccordionProvider.js +4 -5
  11. package/es/components/AspectRatio/AspectRatio.js +7 -8
  12. package/es/components/BadgeIndicator/index.js +5 -6
  13. package/es/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  14. package/es/components/Button/Button.Skeleton.js +7 -8
  15. package/es/components/Button/ButtonBase.js +23 -24
  16. package/es/components/ChatButton/ChatButton.Skeleton.js +5 -6
  17. package/es/components/ChatButton/ChatButton.js +11 -12
  18. package/es/components/Checkbox/Checkbox.Skeleton.js +4 -5
  19. package/es/components/Checkbox/Checkbox.js +19 -20
  20. package/es/components/CheckboxGroup/CheckboxGroup.js +16 -17
  21. package/es/components/ClassPrefix/index.js +4 -5
  22. package/es/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  23. package/es/components/CodeSnippet/CodeSnippet.js +25 -26
  24. package/es/components/ComboBox/ComboBox.js +24 -30
  25. package/es/components/ComboBox/tools/filter.js +9 -12
  26. package/es/components/ComboButton/index.js +16 -18
  27. package/es/components/ComposedModal/ComposedModal.js +50 -36
  28. package/es/components/ComposedModal/ModalFooter.js +37 -42
  29. package/es/components/ComposedModal/ModalHeader.js +14 -15
  30. package/es/components/ContainedList/ContainedList.js +10 -11
  31. package/es/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  32. package/es/components/ContentSwitcher/ContentSwitcher.d.ts +9 -29
  33. package/es/components/ContentSwitcher/ContentSwitcher.js +96 -128
  34. package/es/components/ContentSwitcher/index.d.ts +3 -4
  35. package/es/components/ContextMenu/useContextMenu.js +1 -2
  36. package/es/components/Copy/Copy.js +11 -12
  37. package/es/components/CopyButton/CopyButton.js +10 -11
  38. package/es/components/DataTable/DataTable.js +45 -53
  39. package/es/components/DataTable/Table.js +15 -18
  40. package/es/components/DataTable/TableBatchAction.js +8 -11
  41. package/es/components/DataTable/TableBatchActions.js +18 -20
  42. package/es/components/DataTable/TableBody.js +8 -11
  43. package/es/components/DataTable/TableContainer.js +9 -10
  44. package/es/components/DataTable/TableDecoratorRow.js +4 -5
  45. package/es/components/DataTable/TableExpandHeader.js +14 -15
  46. package/es/components/DataTable/TableExpandRow.js +13 -14
  47. package/es/components/DataTable/TableExpandedRow.js +6 -7
  48. package/es/components/DataTable/TableHeader.js +15 -16
  49. package/es/components/DataTable/TableSelectAll.js +11 -12
  50. package/es/components/DataTable/TableSelectRow.js +12 -13
  51. package/es/components/DataTable/TableSlugRow.js +4 -5
  52. package/es/components/DataTable/TableToolbar.js +7 -8
  53. package/es/components/DataTable/TableToolbarMenu.js +8 -9
  54. package/es/components/DataTable/TableToolbarSearch.js +22 -24
  55. package/es/components/DataTable/state/sorting.js +3 -4
  56. package/es/components/DataTable/tools/filter.js +10 -12
  57. package/es/components/DataTable/tools/normalize.js +6 -8
  58. package/es/components/DataTable/tools/sorting.js +24 -30
  59. package/es/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  60. package/es/components/DatePicker/DatePicker.Skeleton.js +7 -8
  61. package/es/components/DatePicker/DatePicker.js +88 -65
  62. package/es/components/DatePickerInput/DatePickerInput.js +5 -6
  63. package/es/components/Dialog/index.d.ts +193 -8
  64. package/es/components/Dialog/index.js +454 -35
  65. package/es/components/Dropdown/Dropdown.Skeleton.js +6 -7
  66. package/es/components/Dropdown/Dropdown.js +40 -43
  67. package/es/components/ErrorBoundary/ErrorBoundary.js +2 -2
  68. package/es/components/ExpandableSearch/ExpandableSearch.js +9 -10
  69. package/es/components/FeatureFlags/index.js +11 -12
  70. package/es/components/FileUploader/FileUploader.Skeleton.js +4 -5
  71. package/es/components/FileUploader/FileUploader.js +22 -24
  72. package/es/components/FileUploader/FileUploaderButton.js +16 -17
  73. package/es/components/FileUploader/FileUploaderDropContainer.js +15 -16
  74. package/es/components/FileUploader/FileUploaderItem.js +13 -14
  75. package/es/components/FileUploader/Filename.js +9 -10
  76. package/es/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  77. package/es/components/FluidComboBox/FluidComboBox.js +5 -6
  78. package/es/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  79. package/es/components/FluidDatePicker/FluidDatePicker.js +10 -11
  80. package/es/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  81. package/es/components/FluidDropdown/FluidDropdown.js +5 -6
  82. package/es/components/FluidForm/FluidForm.js +5 -6
  83. package/es/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  84. package/es/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  85. package/es/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  86. package/es/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  87. package/es/components/FluidNumberInput/FluidNumberInput.js +38 -5
  88. package/es/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  89. package/es/components/FluidSearch/FluidSearch.js +4 -5
  90. package/es/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  91. package/es/components/FluidSelect/FluidSelect.js +5 -6
  92. package/es/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  93. package/es/components/FluidTextArea/FluidTextArea.js +4 -5
  94. package/es/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  95. package/es/components/FluidTextInput/FluidTextInput.js +5 -6
  96. package/es/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  97. package/es/components/FluidTimePicker/FluidTimePicker.js +11 -12
  98. package/es/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  99. package/es/components/Form/Form.js +5 -6
  100. package/es/components/FormGroup/FormGroup.js +11 -12
  101. package/es/components/FormItem/FormItem.js +5 -6
  102. package/es/components/FormLabel/FormLabel.js +6 -7
  103. package/es/components/Grid/CSSGrid.js +17 -19
  104. package/es/components/Grid/Column.js +28 -27
  105. package/es/components/Grid/ColumnHang.js +6 -7
  106. package/es/components/Grid/FlexGrid.js +9 -10
  107. package/es/components/Grid/GridContext.js +5 -6
  108. package/es/components/Grid/Row.js +8 -9
  109. package/es/components/Heading/index.js +5 -6
  110. package/es/components/Icon/Icon.Skeleton.js +4 -5
  111. package/es/components/IconButton/index.js +20 -21
  112. package/es/components/IconIndicator/index.js +7 -8
  113. package/es/components/IdPrefix/index.js +4 -5
  114. package/es/components/InlineLoading/InlineLoading.js +9 -10
  115. package/es/components/Layer/index.js +8 -9
  116. package/es/components/Layout/index.js +21 -26
  117. package/es/components/LayoutDirection/LayoutDirection.js +6 -7
  118. package/es/components/Link/Link.d.ts +1 -1
  119. package/es/components/Link/Link.js +14 -15
  120. package/es/components/ListBox/ListBoxField.js +6 -7
  121. package/es/components/ListBox/ListBoxMenu.js +5 -6
  122. package/es/components/ListBox/ListBoxMenuIcon.js +4 -5
  123. package/es/components/ListBox/ListBoxMenuItem.js +8 -10
  124. package/es/components/ListBox/ListBoxSelection.js +8 -9
  125. package/es/components/ListBox/next/ListBoxSelection.js +9 -10
  126. package/es/components/ListBox/next/ListBoxTrigger.js +5 -6
  127. package/es/components/ListItem/ListItem.js +5 -6
  128. package/es/components/Loading/Loading.js +8 -9
  129. package/es/components/Menu/Menu.js +23 -24
  130. package/es/components/Menu/MenuItem.js +39 -44
  131. package/es/components/MenuButton/index.js +16 -18
  132. package/es/components/Modal/Modal.js +74 -65
  133. package/es/components/ModalWrapper/ModalWrapper.js +2 -2
  134. package/es/components/MultiSelect/FilterableMultiSelect.js +67 -48
  135. package/es/components/MultiSelect/MultiSelect.js +43 -45
  136. package/es/components/MultiSelect/tools/sorting.js +11 -15
  137. package/es/components/Notification/Notification.js +96 -105
  138. package/es/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  139. package/es/components/NumberInput/NumberFormatPropTypes.js +40 -0
  140. package/es/components/NumberInput/NumberInput.Skeleton.js +6 -7
  141. package/es/components/NumberInput/NumberInput.d.ts +39 -3
  142. package/es/components/NumberInput/NumberInput.js +174 -44
  143. package/es/components/OrderedList/OrderedList.js +7 -8
  144. package/es/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  145. package/es/components/OverflowMenu/OverflowMenu.js +39 -46
  146. package/es/components/OverflowMenu/next/index.js +12 -13
  147. package/es/components/PageHeader/PageHeader.d.ts +39 -14
  148. package/es/components/PageHeader/PageHeader.js +187 -81
  149. package/es/components/PageHeader/index.d.ts +2 -2
  150. package/es/components/PageHeader/index.js +1 -1
  151. package/es/components/Pagination/Pagination.Skeleton.js +4 -5
  152. package/es/components/Pagination/Pagination.js +24 -25
  153. package/es/components/Pagination/experimental/PageSelector.js +8 -9
  154. package/es/components/Pagination/experimental/Pagination.js +20 -21
  155. package/es/components/PaginationNav/PaginationNav.js +33 -38
  156. package/es/components/Popover/index.js +26 -28
  157. package/es/components/ProgressBar/ProgressBar.js +11 -12
  158. package/es/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  159. package/es/components/ProgressIndicator/ProgressIndicator.js +29 -32
  160. package/es/components/RadioTile/RadioTile.js +17 -18
  161. package/es/components/Search/Search.Skeleton.js +5 -6
  162. package/es/components/Search/Search.js +26 -29
  163. package/es/components/Select/Select.Skeleton.js +5 -6
  164. package/es/components/Select/Select.js +24 -25
  165. package/es/components/SelectItem/SelectItem.js +8 -9
  166. package/es/components/SelectItemGroup/SelectItemGroup.js +7 -8
  167. package/es/components/ShapeIndicator/index.js +7 -8
  168. package/es/components/SkeletonIcon/SkeletonIcon.js +4 -5
  169. package/es/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  170. package/es/components/SkeletonText/SkeletonText.js +8 -9
  171. package/es/components/Slider/Slider.Skeleton.js +8 -9
  172. package/es/components/Slider/Slider.js +75 -83
  173. package/es/components/Slider/SliderHandles.js +6 -6
  174. package/es/components/StructuredList/StructuredList.Skeleton.js +5 -6
  175. package/es/components/Tabs/Tabs.Skeleton.js +5 -6
  176. package/es/components/Tabs/Tabs.js +83 -98
  177. package/es/components/Tabs/usePressable.js +7 -8
  178. package/es/components/Tag/DismissibleTag.js +16 -17
  179. package/es/components/Tag/OperationalTag.js +10 -11
  180. package/es/components/Tag/SelectableTag.js +13 -14
  181. package/es/components/Tag/Tag.Skeleton.js +5 -6
  182. package/es/components/Tag/Tag.js +19 -20
  183. package/es/components/Text/Text.js +6 -7
  184. package/es/components/Text/TextDirection.js +5 -6
  185. package/es/components/TextArea/TextArea.js +7 -7
  186. package/es/components/TextInput/ControlledPasswordInput.js +24 -25
  187. package/es/components/TextInput/PasswordInput.js +26 -27
  188. package/es/components/TextInput/TextInput.Skeleton.js +5 -6
  189. package/es/components/TextInput/TextInput.js +27 -28
  190. package/es/components/TextInput/util.js +14 -17
  191. package/es/components/Theme/index.js +10 -12
  192. package/es/components/Tile/Tile.js +68 -74
  193. package/es/components/TileGroup/TileGroup.d.ts +4 -4
  194. package/es/components/TileGroup/TileGroup.js +45 -53
  195. package/es/components/TileGroup/index.d.ts +3 -3
  196. package/es/components/Toggle/Toggle.Skeleton.js +4 -5
  197. package/es/components/Toggle/Toggle.js +17 -18
  198. package/es/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  199. package/es/components/Toggletip/index.js +33 -39
  200. package/es/components/Tooltip/DefinitionTooltip.js +13 -14
  201. package/es/components/Tooltip/Tooltip.js +15 -16
  202. package/es/components/TreeView/TreeNode.js +20 -21
  203. package/es/components/TreeView/TreeView.js +14 -16
  204. package/es/components/UIShell/Content.js +6 -7
  205. package/es/components/UIShell/Header.js +5 -6
  206. package/es/components/UIShell/HeaderContainer.js +5 -6
  207. package/es/components/UIShell/HeaderGlobalAction.js +12 -13
  208. package/es/components/UIShell/HeaderMenu.d.ts +10 -112
  209. package/es/components/UIShell/HeaderMenu.js +154 -201
  210. package/es/components/UIShell/HeaderMenuButton.js +10 -11
  211. package/es/components/UIShell/HeaderMenuItem.js +12 -12
  212. package/es/components/UIShell/HeaderName.js +6 -7
  213. package/es/components/UIShell/HeaderNavigation.js +7 -8
  214. package/es/components/UIShell/HeaderPanel.js +9 -10
  215. package/es/components/UIShell/HeaderSideNavItems.js +5 -6
  216. package/es/components/UIShell/Link.js +8 -9
  217. package/es/components/UIShell/SideNav.js +23 -25
  218. package/es/components/UIShell/SideNavDetails.js +6 -7
  219. package/es/components/UIShell/SideNavDivider.js +3 -4
  220. package/es/components/UIShell/SideNavFooter.js +6 -7
  221. package/es/components/UIShell/SideNavHeader.js +5 -6
  222. package/es/components/UIShell/SideNavIcon.js +5 -6
  223. package/es/components/UIShell/SideNavItem.js +5 -6
  224. package/es/components/UIShell/SideNavItems.js +5 -6
  225. package/es/components/UIShell/SideNavLink.js +10 -11
  226. package/es/components/UIShell/SideNavLinkText.js +5 -6
  227. package/es/components/UIShell/SideNavMenu.js +11 -12
  228. package/es/components/UIShell/SkipToContent.js +7 -8
  229. package/es/components/UIShell/Switcher.js +4 -5
  230. package/es/components/UIShell/SwitcherDivider.js +4 -5
  231. package/es/components/UnorderedList/UnorderedList.js +6 -7
  232. package/es/index.js +3 -3
  233. package/es/internal/FloatingMenu.js +26 -28
  234. package/es/internal/Selection.js +15 -17
  235. package/es/internal/getAnnouncement.d.ts +8 -0
  236. package/es/internal/getAnnouncement.js +22 -0
  237. package/es/internal/keyboard/match.js +6 -7
  238. package/es/internal/useControllableState.d.ts +1 -1
  239. package/es/internal/useControllableState.js +8 -9
  240. package/es/internal/useDelayedState.js +1 -2
  241. package/es/internal/useDocumentLang.d.ts +12 -0
  242. package/es/internal/useId.js +2 -4
  243. package/es/internal/useMatchMedia.js +1 -2
  244. package/es/internal/useMergedRefs.d.ts +1 -1
  245. package/es/internal/useNoInteractiveChildren.js +2 -4
  246. package/es/internal/useNormalizedInputProps.js +9 -10
  247. package/es/internal/useOverflowItems.d.ts +29 -0
  248. package/es/internal/useOverflowItems.js +122 -0
  249. package/es/internal/useResizeObserver.js +4 -5
  250. package/es/internal/useSavedCallback.js +1 -3
  251. package/es/internal/wrapFocus.js +20 -29
  252. package/es/prop-types/deprecate.js +1 -4
  253. package/es/prop-types/deprecateValuesWithin.js +1 -4
  254. package/es/prop-types/isRequiredOneOf.js +1 -4
  255. package/es/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  256. package/es/tools/events.js +1 -4
  257. package/es/tools/mergeRefs.js +9 -14
  258. package/es/tools/uniqueId.js +1 -2
  259. package/es/tools/wrapComponent.js +9 -11
  260. package/lib/components/AILabel/index.js +27 -30
  261. package/lib/components/AISkeleton/AISkeletonIcon.js +4 -5
  262. package/lib/components/AISkeleton/AISkeletonPlaceholder.js +4 -5
  263. package/lib/components/AISkeleton/AISkeletonText.js +4 -5
  264. package/lib/components/Accordion/Accordion.Skeleton.js +9 -10
  265. package/lib/components/Accordion/Accordion.js +10 -11
  266. package/lib/components/Accordion/AccordionItem.js +13 -14
  267. package/lib/components/Accordion/AccordionProvider.js +4 -5
  268. package/lib/components/AspectRatio/AspectRatio.js +7 -8
  269. package/lib/components/BadgeIndicator/index.js +5 -6
  270. package/lib/components/Breadcrumb/Breadcrumb.Skeleton.js +4 -5
  271. package/lib/components/Button/Button.Skeleton.js +7 -8
  272. package/lib/components/Button/ButtonBase.js +23 -24
  273. package/lib/components/ChatButton/ChatButton.Skeleton.js +5 -6
  274. package/lib/components/ChatButton/ChatButton.js +11 -12
  275. package/lib/components/Checkbox/Checkbox.Skeleton.js +4 -5
  276. package/lib/components/Checkbox/Checkbox.js +19 -20
  277. package/lib/components/CheckboxGroup/CheckboxGroup.js +16 -17
  278. package/lib/components/ClassPrefix/index.js +4 -5
  279. package/lib/components/CodeSnippet/CodeSnippet.Skeleton.js +5 -6
  280. package/lib/components/CodeSnippet/CodeSnippet.js +25 -26
  281. package/lib/components/ComboBox/ComboBox.js +24 -30
  282. package/lib/components/ComboBox/tools/filter.js +9 -12
  283. package/lib/components/ComboButton/index.js +16 -18
  284. package/lib/components/ComposedModal/ComposedModal.js +50 -36
  285. package/lib/components/ComposedModal/ModalFooter.js +37 -42
  286. package/lib/components/ComposedModal/ModalHeader.js +14 -15
  287. package/lib/components/ContainedList/ContainedList.js +10 -11
  288. package/lib/components/ContainedList/ContainedListItem/ContainedListItem.js +9 -10
  289. package/lib/components/ContentSwitcher/ContentSwitcher.d.ts +9 -29
  290. package/lib/components/ContentSwitcher/ContentSwitcher.js +94 -126
  291. package/lib/components/ContentSwitcher/index.d.ts +3 -4
  292. package/lib/components/ContextMenu/useContextMenu.js +1 -2
  293. package/lib/components/Copy/Copy.js +11 -12
  294. package/lib/components/CopyButton/CopyButton.js +10 -11
  295. package/lib/components/DataTable/DataTable.js +45 -53
  296. package/lib/components/DataTable/Table.js +15 -18
  297. package/lib/components/DataTable/TableBatchAction.js +8 -11
  298. package/lib/components/DataTable/TableBatchActions.js +18 -20
  299. package/lib/components/DataTable/TableBody.js +8 -11
  300. package/lib/components/DataTable/TableContainer.js +9 -10
  301. package/lib/components/DataTable/TableDecoratorRow.js +4 -5
  302. package/lib/components/DataTable/TableExpandHeader.js +14 -15
  303. package/lib/components/DataTable/TableExpandRow.js +13 -14
  304. package/lib/components/DataTable/TableExpandedRow.js +6 -7
  305. package/lib/components/DataTable/TableHeader.js +15 -16
  306. package/lib/components/DataTable/TableSelectAll.js +11 -12
  307. package/lib/components/DataTable/TableSelectRow.js +12 -13
  308. package/lib/components/DataTable/TableSlugRow.js +4 -5
  309. package/lib/components/DataTable/TableToolbar.js +7 -8
  310. package/lib/components/DataTable/TableToolbarMenu.js +8 -9
  311. package/lib/components/DataTable/TableToolbarSearch.js +22 -24
  312. package/lib/components/DataTable/state/sorting.js +3 -4
  313. package/lib/components/DataTable/tools/filter.js +10 -12
  314. package/lib/components/DataTable/tools/normalize.js +6 -8
  315. package/lib/components/DataTable/tools/sorting.js +24 -30
  316. package/lib/components/DataTableSkeleton/DataTableSkeleton.js +11 -12
  317. package/lib/components/DatePicker/DatePicker.Skeleton.js +7 -8
  318. package/lib/components/DatePicker/DatePicker.js +87 -64
  319. package/lib/components/DatePickerInput/DatePickerInput.js +5 -6
  320. package/lib/components/Dialog/index.d.ts +193 -8
  321. package/lib/components/Dialog/index.js +457 -33
  322. package/lib/components/Dropdown/Dropdown.Skeleton.js +6 -7
  323. package/lib/components/Dropdown/Dropdown.js +40 -43
  324. package/lib/components/ErrorBoundary/ErrorBoundary.js +2 -2
  325. package/lib/components/ExpandableSearch/ExpandableSearch.js +9 -10
  326. package/lib/components/FeatureFlags/index.js +11 -12
  327. package/lib/components/FileUploader/FileUploader.Skeleton.js +4 -5
  328. package/lib/components/FileUploader/FileUploader.js +22 -24
  329. package/lib/components/FileUploader/FileUploaderButton.js +16 -17
  330. package/lib/components/FileUploader/FileUploaderDropContainer.js +15 -16
  331. package/lib/components/FileUploader/FileUploaderItem.js +13 -14
  332. package/lib/components/FileUploader/Filename.js +9 -10
  333. package/lib/components/FluidComboBox/FluidComboBox.Skeleton.js +4 -5
  334. package/lib/components/FluidComboBox/FluidComboBox.js +5 -6
  335. package/lib/components/FluidDatePicker/FluidDatePicker.Skeleton.js +5 -6
  336. package/lib/components/FluidDatePicker/FluidDatePicker.js +10 -11
  337. package/lib/components/FluidDropdown/FluidDropdown.Skeleton.js +4 -5
  338. package/lib/components/FluidDropdown/FluidDropdown.js +5 -6
  339. package/lib/components/FluidForm/FluidForm.js +5 -6
  340. package/lib/components/FluidMultiSelect/FluidMultiSelect.Skeleton.js +4 -5
  341. package/lib/components/FluidMultiSelect/FluidMultiSelect.js +6 -7
  342. package/lib/components/FluidNumberInput/FluidNumberInput.Skeleton.js +4 -5
  343. package/lib/components/FluidNumberInput/FluidNumberInput.d.ts +40 -1
  344. package/lib/components/FluidNumberInput/FluidNumberInput.js +38 -5
  345. package/lib/components/FluidSearch/FluidSearch.Skeleton.js +4 -5
  346. package/lib/components/FluidSearch/FluidSearch.js +4 -5
  347. package/lib/components/FluidSelect/FluidSelect.Skeleton.js +4 -5
  348. package/lib/components/FluidSelect/FluidSelect.js +5 -6
  349. package/lib/components/FluidTextArea/FluidTextArea.Skeleton.js +4 -5
  350. package/lib/components/FluidTextArea/FluidTextArea.js +4 -5
  351. package/lib/components/FluidTextInput/FluidTextInput.Skeleton.js +4 -5
  352. package/lib/components/FluidTextInput/FluidTextInput.js +5 -6
  353. package/lib/components/FluidTimePicker/FluidTimePicker.Skeleton.js +5 -6
  354. package/lib/components/FluidTimePicker/FluidTimePicker.js +11 -12
  355. package/lib/components/FluidTimePickerSelect/FluidTimePickerSelect.js +5 -6
  356. package/lib/components/Form/Form.js +5 -6
  357. package/lib/components/FormGroup/FormGroup.js +11 -12
  358. package/lib/components/FormItem/FormItem.js +5 -6
  359. package/lib/components/FormLabel/FormLabel.js +6 -7
  360. package/lib/components/Grid/CSSGrid.js +17 -19
  361. package/lib/components/Grid/Column.js +28 -27
  362. package/lib/components/Grid/ColumnHang.js +6 -7
  363. package/lib/components/Grid/FlexGrid.js +9 -10
  364. package/lib/components/Grid/GridContext.js +5 -6
  365. package/lib/components/Grid/Row.js +8 -9
  366. package/lib/components/Heading/index.js +5 -6
  367. package/lib/components/Icon/Icon.Skeleton.js +4 -5
  368. package/lib/components/IconButton/index.js +20 -21
  369. package/lib/components/IconIndicator/index.js +7 -8
  370. package/lib/components/IdPrefix/index.js +4 -5
  371. package/lib/components/InlineLoading/InlineLoading.js +9 -10
  372. package/lib/components/Layer/index.js +8 -9
  373. package/lib/components/Layout/index.js +21 -26
  374. package/lib/components/LayoutDirection/LayoutDirection.js +6 -7
  375. package/lib/components/Link/Link.d.ts +1 -1
  376. package/lib/components/Link/Link.js +14 -15
  377. package/lib/components/ListBox/ListBoxField.js +6 -7
  378. package/lib/components/ListBox/ListBoxMenu.js +5 -6
  379. package/lib/components/ListBox/ListBoxMenuIcon.js +4 -5
  380. package/lib/components/ListBox/ListBoxMenuItem.js +8 -10
  381. package/lib/components/ListBox/ListBoxSelection.js +8 -9
  382. package/lib/components/ListBox/next/ListBoxSelection.js +9 -10
  383. package/lib/components/ListBox/next/ListBoxTrigger.js +5 -6
  384. package/lib/components/ListItem/ListItem.js +5 -6
  385. package/lib/components/Loading/Loading.js +8 -9
  386. package/lib/components/Menu/Menu.js +23 -24
  387. package/lib/components/Menu/MenuItem.js +39 -44
  388. package/lib/components/MenuButton/index.js +16 -18
  389. package/lib/components/Modal/Modal.js +74 -65
  390. package/lib/components/ModalWrapper/ModalWrapper.js +2 -2
  391. package/lib/components/MultiSelect/FilterableMultiSelect.js +66 -47
  392. package/lib/components/MultiSelect/MultiSelect.js +43 -45
  393. package/lib/components/MultiSelect/tools/sorting.js +11 -15
  394. package/lib/components/Notification/Notification.js +96 -105
  395. package/lib/components/NumberInput/NumberFormatPropTypes.d.ts +29 -0
  396. package/lib/components/NumberInput/NumberFormatPropTypes.js +48 -0
  397. package/lib/components/NumberInput/NumberInput.Skeleton.js +6 -7
  398. package/lib/components/NumberInput/NumberInput.d.ts +39 -3
  399. package/lib/components/NumberInput/NumberInput.js +173 -43
  400. package/lib/components/OrderedList/OrderedList.js +7 -8
  401. package/lib/components/OverflowMenu/OverflowMenu.d.ts +1 -1
  402. package/lib/components/OverflowMenu/OverflowMenu.js +39 -46
  403. package/lib/components/OverflowMenu/next/index.js +12 -13
  404. package/lib/components/PageHeader/PageHeader.d.ts +39 -14
  405. package/lib/components/PageHeader/PageHeader.js +185 -81
  406. package/lib/components/PageHeader/index.d.ts +2 -2
  407. package/lib/components/PageHeader/index.js +0 -2
  408. package/lib/components/Pagination/Pagination.Skeleton.js +4 -5
  409. package/lib/components/Pagination/Pagination.js +24 -25
  410. package/lib/components/Pagination/experimental/PageSelector.js +8 -9
  411. package/lib/components/Pagination/experimental/Pagination.js +20 -21
  412. package/lib/components/PaginationNav/PaginationNav.js +33 -38
  413. package/lib/components/Popover/index.js +26 -28
  414. package/lib/components/ProgressBar/ProgressBar.js +11 -12
  415. package/lib/components/ProgressIndicator/ProgressIndicator.Skeleton.js +5 -6
  416. package/lib/components/ProgressIndicator/ProgressIndicator.js +29 -32
  417. package/lib/components/RadioTile/RadioTile.js +17 -18
  418. package/lib/components/Search/Search.Skeleton.js +5 -6
  419. package/lib/components/Search/Search.js +26 -29
  420. package/lib/components/Select/Select.Skeleton.js +5 -6
  421. package/lib/components/Select/Select.js +24 -25
  422. package/lib/components/SelectItem/SelectItem.js +8 -9
  423. package/lib/components/SelectItemGroup/SelectItemGroup.js +7 -8
  424. package/lib/components/ShapeIndicator/index.js +7 -8
  425. package/lib/components/SkeletonIcon/SkeletonIcon.js +4 -5
  426. package/lib/components/SkeletonPlaceholder/SkeletonPlaceholder.js +4 -5
  427. package/lib/components/SkeletonText/SkeletonText.js +8 -9
  428. package/lib/components/Slider/Slider.Skeleton.js +8 -9
  429. package/lib/components/Slider/Slider.js +75 -83
  430. package/lib/components/Slider/SliderHandles.js +6 -6
  431. package/lib/components/StructuredList/StructuredList.Skeleton.js +5 -6
  432. package/lib/components/Tabs/Tabs.Skeleton.js +5 -6
  433. package/lib/components/Tabs/Tabs.js +83 -98
  434. package/lib/components/Tabs/usePressable.js +7 -8
  435. package/lib/components/Tag/DismissibleTag.js +16 -17
  436. package/lib/components/Tag/OperationalTag.js +10 -11
  437. package/lib/components/Tag/SelectableTag.js +13 -14
  438. package/lib/components/Tag/Tag.Skeleton.js +5 -6
  439. package/lib/components/Tag/Tag.js +19 -20
  440. package/lib/components/Text/Text.js +6 -7
  441. package/lib/components/Text/TextDirection.js +5 -6
  442. package/lib/components/TextArea/TextArea.js +7 -7
  443. package/lib/components/TextInput/ControlledPasswordInput.js +24 -25
  444. package/lib/components/TextInput/PasswordInput.js +26 -27
  445. package/lib/components/TextInput/TextInput.Skeleton.js +5 -6
  446. package/lib/components/TextInput/TextInput.js +27 -28
  447. package/lib/components/TextInput/util.js +14 -17
  448. package/lib/components/Theme/index.js +10 -12
  449. package/lib/components/Tile/Tile.js +68 -74
  450. package/lib/components/TileGroup/TileGroup.d.ts +4 -4
  451. package/lib/components/TileGroup/TileGroup.js +44 -52
  452. package/lib/components/TileGroup/index.d.ts +3 -3
  453. package/lib/components/Toggle/Toggle.Skeleton.js +4 -5
  454. package/lib/components/Toggle/Toggle.js +17 -18
  455. package/lib/components/ToggleSmall/ToggleSmall.Skeleton.js +6 -7
  456. package/lib/components/Toggletip/index.js +33 -39
  457. package/lib/components/Tooltip/DefinitionTooltip.js +13 -14
  458. package/lib/components/Tooltip/Tooltip.js +15 -16
  459. package/lib/components/TreeView/TreeNode.js +20 -21
  460. package/lib/components/TreeView/TreeView.js +14 -16
  461. package/lib/components/UIShell/Content.js +6 -7
  462. package/lib/components/UIShell/Header.js +5 -6
  463. package/lib/components/UIShell/HeaderContainer.js +5 -6
  464. package/lib/components/UIShell/HeaderGlobalAction.js +12 -13
  465. package/lib/components/UIShell/HeaderMenu.d.ts +10 -112
  466. package/lib/components/UIShell/HeaderMenu.js +152 -199
  467. package/lib/components/UIShell/HeaderMenuButton.js +10 -11
  468. package/lib/components/UIShell/HeaderMenuItem.js +12 -12
  469. package/lib/components/UIShell/HeaderName.js +6 -7
  470. package/lib/components/UIShell/HeaderNavigation.js +7 -8
  471. package/lib/components/UIShell/HeaderPanel.js +9 -10
  472. package/lib/components/UIShell/HeaderSideNavItems.js +5 -6
  473. package/lib/components/UIShell/Link.js +8 -9
  474. package/lib/components/UIShell/SideNav.js +23 -25
  475. package/lib/components/UIShell/SideNavDetails.js +6 -7
  476. package/lib/components/UIShell/SideNavDivider.js +3 -4
  477. package/lib/components/UIShell/SideNavFooter.js +6 -7
  478. package/lib/components/UIShell/SideNavHeader.js +5 -6
  479. package/lib/components/UIShell/SideNavIcon.js +5 -6
  480. package/lib/components/UIShell/SideNavItem.js +5 -6
  481. package/lib/components/UIShell/SideNavItems.js +5 -6
  482. package/lib/components/UIShell/SideNavLink.js +10 -11
  483. package/lib/components/UIShell/SideNavLinkText.js +5 -6
  484. package/lib/components/UIShell/SideNavMenu.js +11 -12
  485. package/lib/components/UIShell/SkipToContent.js +7 -8
  486. package/lib/components/UIShell/Switcher.js +4 -5
  487. package/lib/components/UIShell/SwitcherDivider.js +4 -5
  488. package/lib/components/UnorderedList/UnorderedList.js +6 -7
  489. package/lib/index.js +36 -36
  490. package/lib/internal/FloatingMenu.js +26 -28
  491. package/lib/internal/Selection.js +15 -17
  492. package/lib/internal/getAnnouncement.d.ts +8 -0
  493. package/lib/internal/getAnnouncement.js +26 -0
  494. package/lib/internal/keyboard/match.js +6 -7
  495. package/lib/internal/useControllableState.d.ts +1 -1
  496. package/lib/internal/useControllableState.js +8 -9
  497. package/lib/internal/useDelayedState.js +1 -2
  498. package/lib/internal/useDocumentLang.d.ts +12 -0
  499. package/lib/internal/useId.js +2 -4
  500. package/lib/internal/useMatchMedia.js +1 -2
  501. package/lib/internal/useMergedRefs.d.ts +1 -1
  502. package/lib/internal/useNoInteractiveChildren.js +2 -4
  503. package/lib/internal/useNormalizedInputProps.js +9 -10
  504. package/lib/internal/useOverflowItems.d.ts +29 -0
  505. package/lib/internal/useOverflowItems.js +126 -0
  506. package/lib/internal/useResizeObserver.js +4 -5
  507. package/lib/internal/useSavedCallback.js +1 -3
  508. package/lib/internal/wrapFocus.js +20 -29
  509. package/lib/prop-types/deprecate.js +1 -4
  510. package/lib/prop-types/deprecateValuesWithin.js +1 -4
  511. package/lib/prop-types/isRequiredOneOf.js +1 -4
  512. package/lib/prop-types/requiredIfGivenPropIsTruthy.js +1 -4
  513. package/lib/tools/events.js +1 -4
  514. package/lib/tools/mergeRefs.js +9 -14
  515. package/lib/tools/uniqueId.js +1 -2
  516. package/lib/tools/wrapComponent.js +9 -11
  517. package/package.json +21 -19
  518. package/telemetry.yml +25 -1
  519. package/es/components/ContentSwitcher/index.js +0 -13
  520. package/es/feature-flags.d.ts +0 -7
  521. package/es/internal/useAnnouncer.js +0 -21
  522. package/lib/components/ContentSwitcher/index.js +0 -18
  523. package/lib/feature-flags.d.ts +0 -7
  524. package/lib/internal/useAnnouncer.js +0 -25
@@ -36,42 +36,41 @@ import { debounce } from '../../node_modules/es-toolkit/dist/compat/function/deb
36
36
  import { Text } from '../Text/Text.js';
37
37
 
38
38
  const ModalSizes = ['xs', 'sm', 'md', 'lg'];
39
- const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
40
- let {
41
- 'aria-label': ariaLabelProp,
42
- children,
43
- className,
44
- decorator,
45
- modalHeading = '',
46
- modalLabel = '',
47
- modalAriaLabel,
48
- passiveModal = false,
49
- secondaryButtonText,
50
- primaryButtonText,
51
- open,
52
- onRequestClose = noopFn,
53
- onRequestSubmit = noopFn,
54
- onSecondarySubmit,
55
- primaryButtonDisabled = false,
56
- danger,
57
- alert,
58
- secondaryButtons,
59
- selectorPrimaryFocus = '[data-modal-primary-focus]',
60
- selectorsFloatingMenus,
61
- shouldSubmitOnEnter,
62
- size,
63
- hasScrollingContent = false,
64
- closeButtonLabel = 'Close',
65
- preventCloseOnClickOutside = false,
66
- isFullWidth,
67
- launcherButtonRef,
68
- loadingStatus = 'inactive',
69
- loadingDescription,
70
- loadingIconDescription,
71
- onLoadingSuccess = noopFn,
72
- slug,
73
- ...rest
74
- } = _ref;
39
+ const Modal = /*#__PURE__*/React.forwardRef(function Modal({
40
+ 'aria-label': ariaLabelProp,
41
+ children,
42
+ className,
43
+ decorator,
44
+ modalHeading = '',
45
+ modalLabel = '',
46
+ modalAriaLabel,
47
+ passiveModal = false,
48
+ secondaryButtonText,
49
+ primaryButtonText,
50
+ open,
51
+ onRequestClose = noopFn,
52
+ onRequestSubmit = noopFn,
53
+ onSecondarySubmit,
54
+ primaryButtonDisabled = false,
55
+ danger,
56
+ alert,
57
+ secondaryButtons,
58
+ selectorPrimaryFocus = '[data-modal-primary-focus]',
59
+ selectorsFloatingMenus,
60
+ shouldSubmitOnEnter,
61
+ size,
62
+ hasScrollingContent = false,
63
+ closeButtonLabel = 'Close',
64
+ preventCloseOnClickOutside = false,
65
+ isFullWidth,
66
+ launcherButtonRef,
67
+ loadingStatus = 'inactive',
68
+ loadingDescription,
69
+ loadingIconDescription,
70
+ onLoadingSuccess = noopFn,
71
+ slug,
72
+ ...rest
73
+ }, ref) {
75
74
  const prefix = usePrefix();
76
75
  const button = useRef(null);
77
76
  const secondaryButton = useRef(null);
@@ -126,12 +125,11 @@ const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
126
125
  onRequestClose(evt);
127
126
  }
128
127
  }
129
- function handleBlur(_ref2) {
130
- let {
131
- target: oldActiveNode,
132
- relatedTarget: currentActiveNode
133
- } = _ref2;
134
- if (open && oldActiveNode instanceof HTMLElement && currentActiveNode instanceof HTMLElement) {
128
+ function handleBlur({
129
+ target: oldActiveNode,
130
+ relatedTarget: currentActiveNode
131
+ }) {
132
+ if (!enableDialogElement && open && oldActiveNode instanceof HTMLElement && currentActiveNode instanceof HTMLElement) {
135
133
  const {
136
134
  current: bodyNode
137
135
  } = innerModal;
@@ -150,6 +148,23 @@ const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
150
148
  selectorsFloatingMenus
151
149
  });
152
150
  }
151
+
152
+ // Adjust scroll if needed so that element with focus is not obscured by gradient
153
+ const modalContent = document.querySelector(`.${prefix}--modal-content`);
154
+ if (!modalContent || !modalContent.classList.contains(`${prefix}--modal-scroll-content`) || !currentActiveNode || !modalContent.contains(currentActiveNode)) {
155
+ return;
156
+ }
157
+ const lastContent = modalContent.children[modalContent.children.length - 1];
158
+ const gradientSpacing = modalContent.scrollHeight - lastContent.offsetTop - lastContent.clientHeight;
159
+ for (let elem of modalContent.children) {
160
+ if (elem.contains(currentActiveNode)) {
161
+ const spaceBelow = modalContent.clientHeight - elem.offsetTop + modalContent.scrollTop - elem.clientHeight;
162
+ if (spaceBelow < gradientSpacing) {
163
+ modalContent.scrollTop = modalContent.scrollTop + (gradientSpacing - spaceBelow);
164
+ }
165
+ break;
166
+ }
167
+ }
153
168
  }
154
169
  const onSecondaryButtonClick = onSecondarySubmit ? onSecondarySubmit : onRequestClose;
155
170
  const modalClasses = cx(`${prefix}--modal`, {
@@ -316,17 +331,14 @@ const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
316
331
  }, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/React.createElement(ButtonSet, {
317
332
  className: footerClasses,
318
333
  "aria-busy": loadingActive
319
- }, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map((_ref3, i) => {
320
- let {
321
- buttonText,
322
- onClick: onButtonClick
323
- } = _ref3;
324
- return /*#__PURE__*/React.createElement(Button, {
325
- key: `${buttonText}-${i}`,
326
- kind: "secondary",
327
- onClick: onButtonClick
328
- }, buttonText);
329
- }) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
334
+ }, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map(({
335
+ buttonText,
336
+ onClick: onButtonClick
337
+ }, i) => /*#__PURE__*/React.createElement(Button, {
338
+ key: `${buttonText}-${i}`,
339
+ kind: "secondary",
340
+ onClick: onButtonClick
341
+ }, buttonText)) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
330
342
  disabled: loadingActive,
331
343
  kind: "secondary",
332
344
  onClick: onSecondaryButtonClick,
@@ -375,17 +387,14 @@ const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
375
387
  }, hasScrollingContentProps), children), !passiveModal && /*#__PURE__*/React.createElement(ButtonSet, {
376
388
  className: footerClasses,
377
389
  "aria-busy": loadingActive
378
- }, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map((_ref4, i) => {
379
- let {
380
- buttonText,
381
- onClick: onButtonClick
382
- } = _ref4;
383
- return /*#__PURE__*/React.createElement(Button, {
384
- key: `${buttonText}-${i}`,
385
- kind: "secondary",
386
- onClick: onButtonClick
387
- }, buttonText);
388
- }) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
390
+ }, Array.isArray(secondaryButtons) && secondaryButtons.length <= 2 ? secondaryButtons.map(({
391
+ buttonText,
392
+ onClick: onButtonClick
393
+ }, i) => /*#__PURE__*/React.createElement(Button, {
394
+ key: `${buttonText}-${i}`,
395
+ kind: "secondary",
396
+ onClick: onButtonClick
397
+ }, buttonText)) : secondaryButtonText && /*#__PURE__*/React.createElement(Button, {
389
398
  disabled: loadingActive,
390
399
  kind: "secondary",
391
400
  onClick: onSecondaryButtonClick,
@@ -412,7 +421,7 @@ const Modal = /*#__PURE__*/React.forwardRef(function Modal(_ref, ref) {
412
421
  level: 0,
413
422
  onKeyDown: handleKeyDown,
414
423
  onClick: composeEventHandlers([rest?.onClick, handleOnClick]),
415
- onBlur: !enableDialogElement ? handleBlur : () => {},
424
+ onBlur: handleBlur,
416
425
  className: modalClasses,
417
426
  role: "presentation",
418
427
  ref: ref
@@ -19,8 +19,8 @@ import { match } from '../../internal/keyboard/match.js';
19
19
  let didWarnAboutDeprecation = false;
20
20
  process.env.NODE_ENV !== 'production';
21
21
  class ModalWrapper extends React.Component {
22
- constructor() {
23
- super(...arguments);
22
+ constructor(...args) {
23
+ super(...args);
24
24
  _defineProperty(this, "triggerButton", /*#__PURE__*/React.createRef());
25
25
  _defineProperty(this, "modal", /*#__PURE__*/React.createRef());
26
26
  _defineProperty(this, "state", {
@@ -17,7 +17,7 @@ import { sortingPropTypes } from './MultiSelectPropTypes.js';
17
17
  import ListBox from '../ListBox/index.js';
18
18
  import ListBoxSelection from '../ListBox/next/ListBoxSelection.js';
19
19
  import ListBoxTrigger from '../ListBox/next/ListBoxTrigger.js';
20
- import { Escape, Space, Enter, Delete, Tab, Home, End } from '../../internal/keyboard/keys.js';
20
+ import { Space, Enter, Delete, Escape, Tab, Home, End } from '../../internal/keyboard/keys.js';
21
21
  import { match } from '../../internal/keyboard/match.js';
22
22
  import { defaultItemToString } from './tools/itemToString.js';
23
23
  import mergeRefs from '../../tools/mergeRefs.js';
@@ -61,48 +61,47 @@ const {
61
61
  * ends up just being defined as "string".)
62
62
  */
63
63
 
64
- const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSelect(_ref, ref) {
65
- let {
66
- autoAlign = false,
67
- className: containerClassName,
68
- clearSelectionDescription = 'Total items selected: ',
69
- clearSelectionText = 'To clear selection, press Delete or Backspace',
70
- compareItems = defaultCompareItems,
71
- decorator,
72
- direction = 'bottom',
73
- disabled = false,
74
- downshiftProps,
75
- filterItems = defaultFilterItems,
76
- helperText,
77
- hideLabel,
78
- id,
79
- initialSelectedItems = [],
80
- invalid,
81
- invalidText,
82
- items,
83
- itemToElement: ItemToElement,
84
- // needs to be capitalized for react to render it correctly
85
- itemToString = defaultItemToString,
86
- light,
87
- locale = 'en',
88
- onInputValueChange,
89
- open = false,
90
- onChange,
91
- onMenuChange,
92
- placeholder,
93
- readOnly,
94
- titleText,
95
- type,
96
- selectionFeedback = 'top-after-reopen',
97
- selectedItems: selected,
98
- size: size$1,
99
- sortItems = defaultSortItems,
100
- translateWithId,
101
- useTitleInItem,
102
- warn,
103
- warnText,
104
- slug
105
- } = _ref;
64
+ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSelect({
65
+ autoAlign = false,
66
+ className: containerClassName,
67
+ clearSelectionDescription = 'Total items selected: ',
68
+ clearSelectionText = 'To clear selection, press Delete or Backspace',
69
+ compareItems = defaultCompareItems,
70
+ decorator,
71
+ direction = 'bottom',
72
+ disabled = false,
73
+ downshiftProps,
74
+ filterItems = defaultFilterItems,
75
+ helperText,
76
+ hideLabel,
77
+ id,
78
+ initialSelectedItems = [],
79
+ invalid,
80
+ invalidText,
81
+ items,
82
+ itemToElement: ItemToElement,
83
+ // needs to be capitalized for react to render it correctly
84
+ itemToString = defaultItemToString,
85
+ light,
86
+ locale = 'en',
87
+ onInputValueChange,
88
+ open = false,
89
+ onChange,
90
+ onMenuChange,
91
+ placeholder,
92
+ readOnly,
93
+ titleText,
94
+ type,
95
+ selectionFeedback = 'top-after-reopen',
96
+ selectedItems: selected,
97
+ size: size$1,
98
+ sortItems = defaultSortItems,
99
+ translateWithId,
100
+ useTitleInItem,
101
+ warn,
102
+ warnText,
103
+ slug
104
+ }, ref) {
106
105
  const {
107
106
  isFluid
108
107
  } = useContext(FormContext);
@@ -138,11 +137,10 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
138
137
  middleware: [flip({
139
138
  crossAxis: false
140
139
  }), size({
141
- apply(_ref2) {
142
- let {
143
- rects,
144
- elements
145
- } = _ref2;
140
+ apply({
141
+ rects,
142
+ elements
143
+ }) {
146
144
  Object.assign(elements.floating.style, {
147
145
  width: `${rects.reference.width}px`
148
146
  });
@@ -250,6 +248,27 @@ const FilterableMultiSelect = /*#__PURE__*/forwardRef(function FilterableMultiSe
250
248
  onMenuChange?.(isOpen);
251
249
  }
252
250
  }, [isOpen, onMenuChange, open]);
251
+ useEffect(() => {
252
+ const handleClickOutside = event => {
253
+ const target = event.target;
254
+ const wrapper = document.getElementById(id)?.closest(`.${prefix}--multi-select__wrapper`);
255
+
256
+ // If click is outside our component and menu is open or input is focused
257
+ if (wrapper && !wrapper.contains(target)) {
258
+ if (isOpen || inputFocused) {
259
+ setIsOpen(false);
260
+ setInputFocused(false);
261
+ setInputValue('');
262
+ }
263
+ }
264
+ };
265
+ if (inputFocused || isOpen) {
266
+ document.addEventListener('mousedown', handleClickOutside);
267
+ }
268
+ return () => {
269
+ document.removeEventListener('mousedown', handleClickOutside);
270
+ };
271
+ }, [isOpen, inputFocused]);
253
272
  const {
254
273
  getToggleButtonProps,
255
274
  getLabelProps,
@@ -58,46 +58,45 @@ const defaultItemToString = item => {
58
58
  }
59
59
  return '';
60
60
  };
61
- const MultiSelect = /*#__PURE__*/React.forwardRef((_ref, ref) => {
62
- let {
63
- autoAlign = false,
64
- className: containerClassName,
65
- decorator,
66
- id,
67
- items,
68
- itemToElement,
69
- itemToString = defaultItemToString,
70
- titleText = false,
71
- hideLabel,
72
- helperText,
73
- label,
74
- type = 'default',
75
- size: size$1,
76
- disabled = false,
77
- initialSelectedItems = [],
78
- sortItems = defaultSortItems,
79
- compareItems = defaultCompareItems,
80
- clearSelectionText = 'To clear selection, press Delete or Backspace',
81
- clearAnnouncement = 'all items have been cleared',
82
- clearSelectionDescription = 'Total items selected: ',
83
- light,
84
- invalid,
85
- invalidText,
86
- warn,
87
- warnText,
88
- useTitleInItem,
89
- translateWithId,
90
- downshiftProps,
91
- open = false,
92
- selectionFeedback = 'top-after-reopen',
93
- onChange,
94
- onMenuChange,
95
- direction = 'bottom',
96
- selectedItems: selected,
97
- readOnly,
98
- locale = 'en',
99
- slug
100
- } = _ref;
61
+ const MultiSelect = /*#__PURE__*/React.forwardRef(({
62
+ autoAlign = false,
63
+ className: containerClassName,
64
+ decorator,
65
+ id,
66
+ items,
67
+ itemToElement,
68
+ itemToString = defaultItemToString,
69
+ titleText = false,
70
+ hideLabel,
71
+ helperText,
72
+ label,
73
+ type = 'default',
74
+ size: size$1,
75
+ disabled = false,
76
+ initialSelectedItems = [],
77
+ sortItems = defaultSortItems,
78
+ compareItems = defaultCompareItems,
79
+ clearSelectionText = 'To clear selection, press Delete or Backspace',
80
+ clearAnnouncement = 'all items have been cleared',
81
+ clearSelectionDescription = 'Total items selected: ',
82
+ light,
83
+ invalid,
84
+ invalidText,
85
+ warn,
86
+ warnText,
87
+ useTitleInItem,
88
+ translateWithId,
89
+ downshiftProps,
90
+ open = false,
91
+ selectionFeedback = 'top-after-reopen',
92
+ onChange,
93
+ onMenuChange,
94
+ direction = 'bottom',
95
+ selectedItems: selected,
96
+ readOnly,
97
+ locale = 'en',
98
+ slug
99
+ }, ref) => {
101
100
  const filteredItems = useMemo(() => {
102
101
  return items.filter(item => {
103
102
  if (typeof item === 'object' && item !== null) {
@@ -142,11 +141,10 @@ const MultiSelect = /*#__PURE__*/React.forwardRef((_ref, ref) => {
142
141
  middleware: [autoAlign && flip({
143
142
  crossAxis: false
144
143
  }), size({
145
- apply(_ref2) {
146
- let {
147
- rects,
148
- elements
149
- } = _ref2;
144
+ apply({
145
+ rects,
146
+ elements
147
+ }) {
150
148
  Object.assign(elements.floating.style, {
151
149
  width: `${rects.reference.width}px`
152
150
  });
@@ -16,25 +16,21 @@
16
16
  * @returns {number} A negative number if itemA comes before itemB, a positive
17
17
  * number if itemA comes after itemB, or 0 if they are equal.
18
18
  */
19
- const defaultCompareItems = (itemA, itemB, _ref) => {
20
- let {
21
- locale
22
- } = _ref;
23
- return itemA.localeCompare(itemB, locale, {
24
- numeric: true
25
- });
26
- };
19
+ const defaultCompareItems = (itemA, itemB, {
20
+ locale
21
+ }) => itemA.localeCompare(itemB, locale, {
22
+ numeric: true
23
+ });
27
24
 
28
25
  /**
29
26
  * Default sorting algorithm for options in a selection control
30
27
  */
31
- const defaultSortItems = (items, _ref2) => {
32
- let {
33
- selectedItems = [],
34
- itemToString,
35
- compareItems,
36
- locale = 'en'
37
- } = _ref2;
28
+ const defaultSortItems = (items, {
29
+ selectedItems = [],
30
+ itemToString,
31
+ compareItems,
32
+ locale = 'en'
33
+ }) => {
38
34
  return items.sort((itemA, itemB) => {
39
35
  // Always place "select all" option at the beginning
40
36
  if (itemA.isSelectAll) return -1;