@carbon/ibm-products 2.0.0-rc.3 → 2.0.0-rc.32

Sign up to get free protection for your applications and to get access to all the features.
Files changed (766) hide show
  1. package/README.md +46 -21
  2. package/css/config.css +3 -0
  3. package/css/config.css.map +1 -0
  4. package/css/index-full-carbon.css +6711 -4153
  5. package/css/index-full-carbon.css.map +1 -1
  6. package/css/index-full-carbon.min.css +6 -10
  7. package/css/index-full-carbon.min.css.map +1 -1
  8. package/css/index-without-carbon-released-only.css +853 -698
  9. package/css/index-without-carbon-released-only.css.map +1 -1
  10. package/css/index-without-carbon-released-only.min.css +2 -10
  11. package/css/index-without-carbon-released-only.min.css.map +1 -1
  12. package/css/index-without-carbon.css +1080 -1011
  13. package/css/index-without-carbon.css.map +1 -1
  14. package/css/index-without-carbon.min.css +6 -10
  15. package/css/index-without-carbon.min.css.map +1 -1
  16. package/css/index.css +1524 -1091
  17. package/css/index.css.map +1 -1
  18. package/css/index.min.css +6 -10
  19. package/css/index.min.css.map +1 -1
  20. package/es/components/APIKeyModal/APIKeyDownloader.js +29 -41
  21. package/es/components/APIKeyModal/APIKeyModal.js +101 -185
  22. package/es/components/APIKeyModal/index.js +1 -0
  23. package/es/components/AboutModal/AboutModal.js +76 -111
  24. package/es/components/AboutModal/index.js +1 -0
  25. package/es/components/ActionBar/ActionBar.js +71 -90
  26. package/es/components/ActionBar/ActionBarItem.js +21 -22
  27. package/es/components/ActionBar/ActionBarOverflowItems.js +13 -12
  28. package/es/components/ActionBar/index.js +1 -0
  29. package/es/components/ActionSet/ActionSet.js +36 -42
  30. package/es/components/ActionSet/actions.js +1 -2
  31. package/es/components/ActionSet/index.js +1 -0
  32. package/es/components/AddSelect/AddSelect.js +9 -7
  33. package/es/components/AddSelect/AddSelectBody.js +119 -119
  34. package/es/components/AddSelect/AddSelectBreadcrumbs.js +10 -9
  35. package/es/components/AddSelect/AddSelectColumn.js +44 -56
  36. package/es/components/AddSelect/AddSelectFilter.js +32 -43
  37. package/es/components/AddSelect/AddSelectFormControl.js +82 -0
  38. package/es/components/AddSelect/AddSelectList.js +31 -218
  39. package/es/components/AddSelect/AddSelectMetaPanel.js +10 -5
  40. package/es/components/AddSelect/AddSelectRow.js +206 -0
  41. package/es/components/AddSelect/AddSelectSidebar.js +19 -23
  42. package/es/components/AddSelect/AddSelectSort.js +10 -8
  43. package/es/components/AddSelect/add-select-utils.js +10 -24
  44. package/es/components/AddSelect/hooks/useFocus.js +31 -0
  45. package/es/components/AddSelect/hooks/useItemSort.js +13 -8
  46. package/es/components/AddSelect/hooks/useParentSelect.js +10 -6
  47. package/es/components/AddSelect/hooks/usePath.js +27 -21
  48. package/es/components/AddSelect/index.js +2 -1
  49. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +75 -104
  50. package/es/components/BreadcrumbWithOverflow/index.js +2 -0
  51. package/es/components/ButtonMenu/ButtonMenu.js +39 -37
  52. package/es/components/ButtonMenu/ButtonMenuItem.js +10 -6
  53. package/es/components/ButtonMenu/index.js +1 -0
  54. package/es/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +42 -64
  55. package/es/components/ButtonSetWithOverflow/index.js +1 -0
  56. package/es/components/Card/Card.js +64 -80
  57. package/es/components/Card/CardFooter.js +21 -20
  58. package/es/components/Card/CardHeader.js +15 -15
  59. package/es/components/Card/index.js +1 -0
  60. package/es/components/Cascade/Cascade.js +5 -14
  61. package/es/components/ComboButton/ComboButton.js +24 -35
  62. package/es/components/ComboButton/ComboButtonItem/index.js +4 -8
  63. package/es/components/ComboButton/index.js +1 -0
  64. package/es/components/CreateFullPage/CreateFullPage.js +80 -90
  65. package/es/components/CreateFullPage/CreateFullPageStep.js +44 -49
  66. package/es/components/CreateFullPage/index.js +1 -0
  67. package/es/components/CreateInfluencer/CreateInfluencer.js +14 -15
  68. package/es/components/CreateInfluencer/index.js +1 -0
  69. package/es/components/CreateModal/CreateModal.js +19 -31
  70. package/es/components/CreateModal/index.js +2 -0
  71. package/es/components/CreateSidePanel/CreateSidePanel.js +24 -37
  72. package/es/components/CreateSidePanel/index.js +1 -0
  73. package/es/components/CreateTearsheet/CreateTearsheet.js +80 -91
  74. package/es/components/CreateTearsheet/CreateTearsheetDivider.js +4 -4
  75. package/es/components/CreateTearsheet/CreateTearsheetStep.js +39 -50
  76. package/es/components/CreateTearsheet/index.js +1 -0
  77. package/es/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +60 -84
  78. package/es/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +50 -70
  79. package/es/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +32 -41
  80. package/es/components/CreateTearsheetNarrow/index.js +1 -0
  81. package/es/components/DataSpreadsheet/DataSpreadsheet.js +139 -229
  82. package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +62 -113
  83. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +25 -56
  84. package/es/components/DataSpreadsheet/hooks/index.js +1 -0
  85. package/es/components/DataSpreadsheet/hooks/useMoveActiveCell.js +6 -5
  86. package/es/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +23 -44
  87. package/es/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +5 -5
  88. package/es/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +18 -30
  89. package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +10 -14
  90. package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +34 -54
  91. package/es/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +10 -10
  92. package/es/components/DataSpreadsheet/index.js +1 -0
  93. package/es/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +4 -8
  94. package/es/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +3 -4
  95. package/es/components/DataSpreadsheet/utils/createActiveCellFn.js +15 -19
  96. package/es/components/DataSpreadsheet/utils/createCellSelectionArea.js +15 -17
  97. package/es/components/DataSpreadsheet/utils/generateData.js +4 -13
  98. package/es/components/DataSpreadsheet/utils/getCellSize.js +1 -6
  99. package/es/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +1 -0
  100. package/es/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +7 -9
  101. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +20 -34
  102. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +20 -30
  103. package/es/components/DataSpreadsheet/utils/handleCellDeletion.js +18 -9
  104. package/es/components/DataSpreadsheet/utils/handleEditSubmit.js +13 -20
  105. package/es/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +22 -44
  106. package/es/components/DataSpreadsheet/utils/handleMultipleKeys.js +40 -75
  107. package/es/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +6 -8
  108. package/es/components/DataSpreadsheet/utils/removeCellSelections.js +6 -8
  109. package/es/components/DataSpreadsheet/utils/selectAllCells.js +7 -11
  110. package/es/components/Datagrid/Datagrid/Datagrid.js +21 -17
  111. package/es/components/Datagrid/Datagrid/DatagridBody.js +4 -10
  112. package/es/components/Datagrid/Datagrid/DatagridContent.js +89 -57
  113. package/es/components/Datagrid/Datagrid/DatagridEmptyBody.js +29 -26
  114. package/es/components/Datagrid/Datagrid/DatagridExpandedRow.js +4 -6
  115. package/es/components/Datagrid/Datagrid/DatagridHead.js +7 -8
  116. package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +8 -13
  117. package/es/components/Datagrid/Datagrid/DatagridRefBody.js +8 -9
  118. package/es/components/Datagrid/Datagrid/DatagridRow.js +76 -28
  119. package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +29 -24
  120. package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +47 -44
  121. package/es/components/Datagrid/Datagrid/DatagridSimpleBody.js +6 -10
  122. package/es/components/Datagrid/Datagrid/DatagridToolbar.js +37 -46
  123. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +53 -31
  124. package/es/components/Datagrid/Datagrid/DraggableElement.js +82 -89
  125. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +10 -14
  126. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +18 -21
  127. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +37 -85
  128. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +176 -0
  129. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +109 -0
  130. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +51 -0
  131. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +1 -1
  132. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +2 -1
  133. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +244 -0
  134. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +269 -0
  135. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +83 -0
  136. package/es/components/Datagrid/Datagrid/addons/Filtering/constants.js +27 -0
  137. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +11 -0
  138. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +299 -0
  139. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +21 -0
  140. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +34 -0
  141. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +23 -0
  142. package/es/components/Datagrid/Datagrid/addons/Filtering/index.js +9 -0
  143. package/es/components/Datagrid/Datagrid/addons/Filtering/motion/variants.js +55 -0
  144. package/es/components/Datagrid/Datagrid/addons/Filtering/utils.js +84 -0
  145. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +11 -12
  146. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +73 -118
  147. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +7 -21
  148. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +1 -1
  149. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +9 -14
  150. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +2 -3
  151. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +29 -64
  152. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +14 -21
  153. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +35 -33
  154. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +19 -27
  155. package/es/components/Datagrid/Datagrid/addons/RowSize/index.js +1 -0
  156. package/es/components/Datagrid/Datagrid/index.js +1 -0
  157. package/es/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +10 -0
  158. package/es/components/Datagrid/Datagrid.stories/common.js +2 -11
  159. package/es/components/Datagrid/Datagrid.stories/index.js +0 -1
  160. package/es/components/Datagrid/common-column-ids.js +1 -0
  161. package/es/components/Datagrid/index.js +10 -7
  162. package/es/components/Datagrid/useActionsColumn.js +42 -32
  163. package/es/components/Datagrid/useColumnCenterAlign.js +0 -8
  164. package/es/components/Datagrid/useColumnOrder.js +1 -0
  165. package/es/components/Datagrid/useColumnRightAlign.js +0 -8
  166. package/es/components/Datagrid/useCustomizeColumns.js +11 -19
  167. package/es/components/Datagrid/useDatagrid.js +0 -7
  168. package/es/components/Datagrid/useDefaultStringRenderer.js +1 -10
  169. package/es/components/Datagrid/useDisableSelectRows.js +2 -10
  170. package/es/components/Datagrid/useEditableCell.js +12 -0
  171. package/es/components/Datagrid/useExpandedRow.js +5 -15
  172. package/es/components/Datagrid/useFiltering.js +91 -0
  173. package/es/components/Datagrid/useFlexResize.js +0 -7
  174. package/es/components/Datagrid/useFloatingScroll.js +9 -22
  175. package/es/components/Datagrid/useInfiniteScroll.js +15 -17
  176. package/es/components/Datagrid/useInlineEdit.js +17 -20
  177. package/es/components/Datagrid/useNestedRowExpander.js +7 -8
  178. package/es/components/Datagrid/useNestedRows.js +13 -12
  179. package/es/components/Datagrid/useOnRowClick.js +16 -13
  180. package/es/components/Datagrid/useParentDimensions.js +9 -17
  181. package/es/components/Datagrid/useResizeTable.js +1 -7
  182. package/es/components/Datagrid/useRowExpander.js +11 -8
  183. package/es/components/Datagrid/useRowIsMouseOver.js +6 -15
  184. package/es/components/Datagrid/useRowRenderer.js +0 -5
  185. package/es/components/Datagrid/useRowSize.js +8 -20
  186. package/es/components/Datagrid/useSelectAllToggle.js +27 -24
  187. package/es/components/Datagrid/useSelectRows.js +30 -31
  188. package/es/components/Datagrid/useSkeletonRows.js +1 -6
  189. package/es/components/Datagrid/useSortableColumns.js +33 -39
  190. package/es/components/Datagrid/useStickyColumn.js +21 -36
  191. package/es/components/Datagrid/utils/DatagridActions.js +166 -79
  192. package/es/components/Datagrid/utils/DatagridPagination.js +5 -6
  193. package/es/components/Datagrid/utils/Wrapper.js +1 -1
  194. package/es/components/Datagrid/utils/getArgTypes.js +10 -0
  195. package/es/components/Datagrid/utils/getAutoSizedColumnWidth.js +27 -0
  196. package/es/components/Datagrid/utils/getInlineEditColumns.js +8 -4
  197. package/es/components/Datagrid/utils/makeData.js +23 -30
  198. package/es/components/EditFullPage/EditFullPage.js +27 -20
  199. package/es/components/EditFullPage/index.js +1 -0
  200. package/es/components/EditInPlace/EditInPlace.js +303 -0
  201. package/es/components/{InlineEdit → EditInPlace}/index.js +2 -1
  202. package/es/components/EditSidePanel/EditSidePanel.js +38 -51
  203. package/es/components/EditSidePanel/index.js +1 -0
  204. package/es/components/EditTearsheet/EditTearsheet.js +35 -45
  205. package/es/components/EditTearsheet/EditTearsheetForm.js +19 -25
  206. package/es/components/EditTearsheet/index.js +1 -0
  207. package/es/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +37 -49
  208. package/es/components/EditTearsheetNarrow/EditTearsheetNarrow.js +27 -20
  209. package/es/components/EditTearsheetNarrow/index.js +1 -0
  210. package/es/components/EditUpdateCards/EditUpdateCards.js +142 -0
  211. package/es/components/EditUpdateCards/index.js +8 -0
  212. package/es/components/EmptyStates/EmptyState.js +33 -36
  213. package/es/components/EmptyStates/EmptyStateContent.js +19 -18
  214. package/es/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +28 -26
  215. package/es/components/EmptyStates/ErrorEmptyState/index.js +1 -0
  216. package/es/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +28 -26
  217. package/es/components/EmptyStates/NoDataEmptyState/index.js +1 -0
  218. package/es/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +28 -26
  219. package/es/components/EmptyStates/NoTagsEmptyState/index.js +1 -0
  220. package/es/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +28 -26
  221. package/es/components/EmptyStates/NotFoundEmptyState/index.js +1 -0
  222. package/es/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +28 -26
  223. package/es/components/EmptyStates/NotificationsEmptyState/index.js +1 -0
  224. package/es/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +28 -26
  225. package/es/components/EmptyStates/UnauthorizedEmptyState/index.js +1 -0
  226. package/es/components/EmptyStates/assets/ErrorIllustration.js +7 -6
  227. package/es/components/EmptyStates/assets/NoDataIllustration.js +7 -6
  228. package/es/components/EmptyStates/assets/NoTagsIllustration.js +7 -6
  229. package/es/components/EmptyStates/assets/NotFoundIllustration.js +7 -6
  230. package/es/components/EmptyStates/assets/NotificationsIllustration.js +7 -6
  231. package/es/components/EmptyStates/assets/UnauthorizedIllustration.js +7 -6
  232. package/es/components/EmptyStates/index.js +1 -0
  233. package/es/components/ExampleComponent/ExampleComponent.js +69 -48
  234. package/es/components/ExampleComponent/ExampleDeprecatedComponent.js +28 -0
  235. package/es/components/ExampleComponent/index.js +1 -0
  236. package/es/components/ExampleComponent/useExample.js +49 -0
  237. package/es/components/ExportModal/ExportModal.js +41 -80
  238. package/es/components/ExportModal/index.js +1 -0
  239. package/es/components/ExpressiveCard/ExpressiveCard.js +6 -23
  240. package/es/components/ExpressiveCard/index.js +1 -0
  241. package/es/components/FilterSummary/FilterSummary.js +54 -0
  242. package/es/components/FilterSummary/index.js +7 -0
  243. package/es/components/HTTPErrors/HTTPError403/HTTPError403.js +16 -18
  244. package/es/components/HTTPErrors/HTTPError403/index.js +1 -0
  245. package/es/components/HTTPErrors/HTTPError404/HTTPError404.js +16 -18
  246. package/es/components/HTTPErrors/HTTPError404/index.js +1 -0
  247. package/es/components/HTTPErrors/HTTPErrorContent.js +15 -18
  248. package/es/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +16 -18
  249. package/es/components/HTTPErrors/HTTPErrorOther/index.js +1 -0
  250. package/es/components/HTTPErrors/assets/HTTPErrorSvg403.js +6 -3
  251. package/es/components/HTTPErrors/assets/HTTPErrorSvg404.js +6 -3
  252. package/es/components/HTTPErrors/assets/HTTPErrorSvgOther.js +6 -3
  253. package/es/components/HTTPErrors/index.js +1 -0
  254. package/es/components/ImportModal/ImportModal.js +82 -137
  255. package/es/components/ImportModal/index.js +1 -0
  256. package/es/components/MultiAddSelect/MultiAddSelect.js +14 -29
  257. package/es/components/MultiAddSelect/index.js +7 -0
  258. package/es/components/NotificationsPanel/NotificationsPanel.js +85 -126
  259. package/es/components/NotificationsPanel/NotificationsPanel_data.js +1 -0
  260. package/es/components/NotificationsPanel/index.js +1 -0
  261. package/es/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +1 -2
  262. package/es/components/NotificationsPanel/utils.js +13 -19
  263. package/es/components/OptionsTile/OptionsTile.js +73 -86
  264. package/es/components/OptionsTile/index.js +1 -0
  265. package/es/components/PageHeader/PageHeader.js +159 -225
  266. package/es/components/PageHeader/PageHeaderDemo.data.js +0 -1
  267. package/es/components/PageHeader/PageHeaderTitle.js +35 -39
  268. package/es/components/PageHeader/PageHeaderUtils.js +18 -45
  269. package/es/components/PageHeader/index.js +1 -0
  270. package/es/components/ProductiveCard/ProductiveCard.js +10 -27
  271. package/es/components/ProductiveCard/index.js +1 -0
  272. package/es/components/RemoveModal/RemoveModal.js +41 -47
  273. package/es/components/RemoveModal/index.js +1 -0
  274. package/es/components/Saving/Saving.js +15 -30
  275. package/es/components/Saving/index.js +1 -0
  276. package/es/components/SidePanel/SidePanel.js +166 -213
  277. package/es/components/SidePanel/constants.js +1 -0
  278. package/es/components/SidePanel/index.js +1 -0
  279. package/es/components/SidePanel/motion/variants.js +46 -0
  280. package/es/components/SingleAddSelect/SingleAddSelect.js +7 -14
  281. package/es/components/SingleAddSelect/index.js +7 -0
  282. package/es/components/StatusIcon/StatusIcon.js +5 -12
  283. package/es/components/StatusIcon/index.js +1 -0
  284. package/es/components/TagSet/TagSet.js +62 -97
  285. package/es/components/TagSet/TagSetModal.js +19 -30
  286. package/es/components/TagSet/TagSetOverflow.js +14 -23
  287. package/es/components/TagSet/constants.js +1 -0
  288. package/es/components/TagSet/index.js +1 -0
  289. package/es/components/Tearsheet/Tearsheet.js +37 -36
  290. package/es/components/Tearsheet/TearsheetNarrow.js +26 -25
  291. package/es/components/Tearsheet/TearsheetShell.js +92 -102
  292. package/es/components/Tearsheet/index.js +1 -0
  293. package/es/components/Toolbar/Toolbar.js +13 -27
  294. package/es/components/Toolbar/ToolbarButton.js +8 -14
  295. package/es/components/Toolbar/ToolbarGroup.js +4 -6
  296. package/es/components/Toolbar/index.js +1 -0
  297. package/es/components/UserProfileImage/UserProfileImage.js +26 -40
  298. package/es/components/UserProfileImage/index.js +2 -0
  299. package/es/components/WebTerminal/WebTerminal.js +44 -54
  300. package/es/components/WebTerminal/WebTerminalContentWrapper.js +14 -11
  301. package/es/components/WebTerminal/hooks/index.js +8 -7
  302. package/es/components/WebTerminal/index.js +1 -0
  303. package/es/components/WebTerminal/preview-components/Navigation.js +2 -4
  304. package/es/components/WebTerminal/preview-components/documentationLinks.js +1 -0
  305. package/es/components/_Canary/Canary.js +13 -13
  306. package/es/components/_Canary/index.js +1 -0
  307. package/es/components/index.js +6 -5
  308. package/es/global/js/hooks/index.js +3 -1
  309. package/es/global/js/hooks/useActiveElement.js +4 -6
  310. package/es/global/js/hooks/useClickOutside.js +1 -1
  311. package/es/global/js/hooks/useControllableState.js +74 -0
  312. package/es/global/js/hooks/useCreateComponentFocus.js +35 -13
  313. package/es/global/js/hooks/useCreateComponentStepChange.js +94 -131
  314. package/es/global/js/hooks/usePreviousValue.js +2 -1
  315. package/es/global/js/hooks/useResetCreateComponent.js +16 -11
  316. package/es/global/js/hooks/useResizeObserver.js +74 -0
  317. package/es/global/js/hooks/useRetrieveStepData.js +7 -10
  318. package/es/global/js/hooks/useValidCreateStepCount.js +2 -1
  319. package/es/global/js/hooks/useWindowResize.js +14 -16
  320. package/es/global/js/hooks/useWindowScroll.js +10 -14
  321. package/es/global/js/package-settings.js +32 -19
  322. package/es/global/js/utils/ClickListener.js +5 -10
  323. package/es/global/js/utils/DisplayBox.js +3 -2
  324. package/es/global/js/utils/Wrap.js +14 -17
  325. package/es/global/js/utils/deepCloneObject.js +5 -8
  326. package/es/global/js/utils/devtools.js +1 -4
  327. package/es/global/js/utils/getBezierValues.js +19 -0
  328. package/es/global/js/utils/getFocusableElements.js +1 -1
  329. package/es/global/js/utils/getNumberOfHiddenSteps.js +19 -0
  330. package/es/global/js/utils/getScrollbarWidth.js +1 -0
  331. package/es/global/js/utils/keyboardNavigation.js +7 -5
  332. package/es/global/js/utils/lastIndexInArray.js +0 -2
  333. package/es/global/js/utils/motionConstants.js +44 -0
  334. package/es/global/js/utils/pconsole.js +1 -3
  335. package/es/global/js/utils/props-helper.js +19 -35
  336. package/es/global/js/utils/rangeWithCallback.js +1 -0
  337. package/es/global/js/utils/scrollableAncestor.js +6 -9
  338. package/es/global/js/utils/story-helper.js +39 -10
  339. package/es/global/js/utils/test-helper.js +71 -59
  340. package/es/global/js/utils/unwrap-if-fragment.js +9 -17
  341. package/es/global/js/utils/uuidv4.js +1 -2
  342. package/es/global/js/utils/uuidv4.spec.js +1 -1
  343. package/es/global/js/utils/wait.js +1 -1
  344. package/es/global/js/utils/wrapFocus.js +8 -14
  345. package/es/index.js +1 -0
  346. package/es/settings.js +48 -29
  347. package/lib/components/APIKeyModal/APIKeyDownloader.js +29 -54
  348. package/lib/components/APIKeyModal/APIKeyModal.js +106 -207
  349. package/lib/components/APIKeyModal/index.js +0 -1
  350. package/lib/components/AboutModal/AboutModal.js +79 -128
  351. package/lib/components/AboutModal/index.js +0 -1
  352. package/lib/components/ActionBar/ActionBar.js +73 -106
  353. package/lib/components/ActionBar/ActionBarItem.js +23 -29
  354. package/lib/components/ActionBar/ActionBarOverflowItems.js +11 -22
  355. package/lib/components/ActionBar/index.js +0 -2
  356. package/lib/components/ActionSet/ActionSet.js +41 -52
  357. package/lib/components/ActionSet/actions.js +1 -5
  358. package/lib/components/ActionSet/index.js +0 -1
  359. package/lib/components/AddSelect/AddSelect.js +13 -19
  360. package/lib/components/AddSelect/AddSelectBody.js +121 -147
  361. package/lib/components/AddSelect/AddSelectBreadcrumbs.js +10 -19
  362. package/lib/components/AddSelect/AddSelectColumn.js +47 -76
  363. package/lib/components/AddSelect/AddSelectFilter.js +35 -57
  364. package/lib/components/AddSelect/AddSelectFormControl.js +90 -0
  365. package/lib/components/AddSelect/AddSelectList.js +30 -232
  366. package/lib/components/AddSelect/AddSelectMetaPanel.js +9 -17
  367. package/lib/components/AddSelect/AddSelectRow.js +217 -0
  368. package/lib/components/AddSelect/AddSelectSidebar.js +23 -33
  369. package/lib/components/AddSelect/AddSelectSort.js +10 -19
  370. package/lib/components/AddSelect/add-select-utils.js +10 -34
  371. package/lib/components/AddSelect/hooks/useFocus.js +39 -0
  372. package/lib/components/AddSelect/hooks/useItemSort.js +12 -12
  373. package/lib/components/AddSelect/hooks/useParentSelect.js +9 -8
  374. package/lib/components/AddSelect/hooks/usePath.js +26 -23
  375. package/lib/components/AddSelect/index.js +0 -1
  376. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +75 -116
  377. package/lib/components/BreadcrumbWithOverflow/index.js +0 -1
  378. package/lib/components/ButtonMenu/ButtonMenu.js +40 -41
  379. package/lib/components/ButtonMenu/ButtonMenuItem.js +9 -10
  380. package/lib/components/ButtonMenu/index.js +0 -2
  381. package/lib/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +46 -83
  382. package/lib/components/ButtonSetWithOverflow/index.js +0 -1
  383. package/lib/components/Card/Card.js +66 -91
  384. package/lib/components/Card/CardFooter.js +21 -30
  385. package/lib/components/Card/CardHeader.js +15 -25
  386. package/lib/components/Card/index.js +0 -3
  387. package/lib/components/Cascade/Cascade.js +10 -31
  388. package/lib/components/Cascade/index.js +0 -1
  389. package/lib/components/ComboButton/ComboButton.js +29 -49
  390. package/lib/components/ComboButton/ComboButtonItem/index.js +2 -10
  391. package/lib/components/ComboButton/index.js +0 -2
  392. package/lib/components/CreateFullPage/CreateFullPage.js +83 -107
  393. package/lib/components/CreateFullPage/CreateFullPageStep.js +47 -63
  394. package/lib/components/CreateFullPage/index.js +0 -2
  395. package/lib/components/CreateInfluencer/CreateInfluencer.js +13 -24
  396. package/lib/components/CreateInfluencer/index.js +0 -1
  397. package/lib/components/CreateModal/CreateModal.js +24 -39
  398. package/lib/components/CreateModal/index.js +0 -1
  399. package/lib/components/CreateSidePanel/CreateSidePanel.js +26 -46
  400. package/lib/components/CreateSidePanel/index.js +0 -1
  401. package/lib/components/CreateTearsheet/CreateTearsheet.js +85 -110
  402. package/lib/components/CreateTearsheet/CreateTearsheetDivider.js +9 -14
  403. package/lib/components/CreateTearsheet/CreateTearsheetStep.js +43 -65
  404. package/lib/components/CreateTearsheet/index.js +0 -3
  405. package/lib/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +65 -96
  406. package/lib/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +50 -84
  407. package/lib/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +35 -49
  408. package/lib/components/CreateTearsheetNarrow/index.js +0 -1
  409. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +141 -259
  410. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +67 -136
  411. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +30 -76
  412. package/lib/components/DataSpreadsheet/hooks/index.js +0 -7
  413. package/lib/components/DataSpreadsheet/hooks/useMoveActiveCell.js +4 -7
  414. package/lib/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +23 -48
  415. package/lib/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +5 -9
  416. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +18 -37
  417. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +7 -18
  418. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +39 -62
  419. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +8 -14
  420. package/lib/components/DataSpreadsheet/index.js +0 -1
  421. package/lib/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +1 -9
  422. package/lib/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +3 -7
  423. package/lib/components/DataSpreadsheet/utils/createActiveCellFn.js +15 -23
  424. package/lib/components/DataSpreadsheet/utils/createCellSelectionArea.js +15 -22
  425. package/lib/components/DataSpreadsheet/utils/generateData.js +4 -16
  426. package/lib/components/DataSpreadsheet/utils/getCellSize.js +1 -8
  427. package/lib/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +1 -2
  428. package/lib/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +7 -12
  429. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +25 -39
  430. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +20 -33
  431. package/lib/components/DataSpreadsheet/utils/handleCellDeletion.js +18 -13
  432. package/lib/components/DataSpreadsheet/utils/handleEditSubmit.js +16 -25
  433. package/lib/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +22 -50
  434. package/lib/components/DataSpreadsheet/utils/handleMultipleKeys.js +45 -85
  435. package/lib/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +6 -12
  436. package/lib/components/DataSpreadsheet/utils/removeCellSelections.js +4 -10
  437. package/lib/components/DataSpreadsheet/utils/selectAllCells.js +12 -17
  438. package/lib/components/Datagrid/Datagrid/Datagrid.js +26 -31
  439. package/lib/components/Datagrid/Datagrid/DatagridBody.js +5 -16
  440. package/lib/components/Datagrid/Datagrid/DatagridContent.js +89 -80
  441. package/lib/components/Datagrid/Datagrid/DatagridEmptyBody.js +28 -31
  442. package/lib/components/Datagrid/Datagrid/DatagridExpandedRow.js +4 -10
  443. package/lib/components/Datagrid/Datagrid/DatagridHead.js +6 -11
  444. package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +8 -20
  445. package/lib/components/Datagrid/Datagrid/DatagridRefBody.js +15 -16
  446. package/lib/components/Datagrid/Datagrid/DatagridRow.js +85 -46
  447. package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +40 -32
  448. package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +45 -50
  449. package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.js +12 -17
  450. package/lib/components/Datagrid/Datagrid/DatagridToolbar.js +37 -59
  451. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +58 -40
  452. package/lib/components/Datagrid/Datagrid/DraggableElement.js +82 -101
  453. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +10 -23
  454. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +18 -25
  455. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +36 -99
  456. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +184 -0
  457. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +117 -0
  458. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +61 -0
  459. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +1 -5
  460. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +3 -6
  461. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +255 -0
  462. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +280 -0
  463. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +96 -0
  464. package/lib/components/Datagrid/Datagrid/addons/Filtering/constants.js +45 -0
  465. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +34 -0
  466. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +309 -0
  467. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +30 -0
  468. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +41 -0
  469. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +30 -0
  470. package/lib/components/Datagrid/Datagrid/addons/Filtering/index.js +33 -0
  471. package/lib/components/Datagrid/Datagrid/addons/Filtering/motion/variants.js +64 -0
  472. package/lib/components/Datagrid/Datagrid/addons/Filtering/utils.js +91 -0
  473. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +11 -20
  474. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/index.js +0 -1
  475. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +80 -140
  476. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/index.js +0 -1
  477. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +12 -33
  478. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +1 -3
  479. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/index.js +0 -1
  480. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +14 -19
  481. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +2 -5
  482. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +34 -72
  483. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +14 -27
  484. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +34 -41
  485. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +19 -38
  486. package/lib/components/Datagrid/Datagrid/addons/RowSize/index.js +0 -2
  487. package/lib/components/Datagrid/Datagrid/index.js +0 -1
  488. package/lib/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +10 -0
  489. package/lib/components/Datagrid/Datagrid.stories/common.js +2 -17
  490. package/lib/components/Datagrid/Datagrid.stories/index.js +0 -13
  491. package/lib/components/Datagrid/common-column-ids.js +1 -1
  492. package/lib/components/Datagrid/index.js +22 -20
  493. package/lib/components/Datagrid/useActionsColumn.js +49 -38
  494. package/lib/components/Datagrid/useColumnCenterAlign.js +7 -15
  495. package/lib/components/Datagrid/useColumnOrder.js +0 -2
  496. package/lib/components/Datagrid/useColumnRightAlign.js +7 -15
  497. package/lib/components/Datagrid/useCustomizeColumns.js +17 -26
  498. package/lib/components/Datagrid/useDatagrid.js +7 -21
  499. package/lib/components/Datagrid/useDefaultStringRenderer.js +8 -17
  500. package/lib/components/Datagrid/useDisableSelectRows.js +2 -11
  501. package/lib/components/Datagrid/useEditableCell.js +20 -0
  502. package/lib/components/Datagrid/useExpandedRow.js +12 -21
  503. package/lib/components/Datagrid/useFiltering.js +98 -0
  504. package/lib/components/Datagrid/useFlexResize.js +0 -9
  505. package/lib/components/Datagrid/useFloatingScroll.js +10 -27
  506. package/lib/components/Datagrid/useInfiniteScroll.js +15 -21
  507. package/lib/components/Datagrid/useInlineEdit.js +20 -26
  508. package/lib/components/Datagrid/useNestedRowExpander.js +7 -14
  509. package/lib/components/Datagrid/useNestedRows.js +14 -16
  510. package/lib/components/Datagrid/useOnRowClick.js +16 -14
  511. package/lib/components/Datagrid/useParentDimensions.js +10 -19
  512. package/lib/components/Datagrid/useResizeTable.js +2 -8
  513. package/lib/components/Datagrid/useRowExpander.js +12 -11
  514. package/lib/components/Datagrid/useRowIsMouseOver.js +12 -20
  515. package/lib/components/Datagrid/useRowRenderer.js +1 -7
  516. package/lib/components/Datagrid/useRowSize.js +14 -25
  517. package/lib/components/Datagrid/useSelectAllToggle.js +31 -31
  518. package/lib/components/Datagrid/useSelectRows.js +40 -44
  519. package/lib/components/Datagrid/useSkeletonRows.js +1 -8
  520. package/lib/components/Datagrid/useSortableColumns.js +33 -41
  521. package/lib/components/Datagrid/useStickyColumn.js +26 -42
  522. package/lib/components/Datagrid/utils/DatagridActions.js +168 -88
  523. package/lib/components/Datagrid/utils/DatagridPagination.js +5 -11
  524. package/lib/components/Datagrid/utils/Wrapper.js +1 -5
  525. package/lib/components/Datagrid/utils/getArgTypes.js +10 -1
  526. package/lib/components/Datagrid/utils/getAutoSizedColumnWidth.js +35 -0
  527. package/lib/components/Datagrid/utils/getInlineEditColumns.js +8 -10
  528. package/lib/components/Datagrid/utils/makeData.js +29 -41
  529. package/lib/components/EditFullPage/EditFullPage.js +30 -26
  530. package/lib/components/EditFullPage/index.js +0 -1
  531. package/lib/components/EditInPlace/EditInPlace.js +312 -0
  532. package/lib/components/{InlineEdit → EditInPlace}/index.js +3 -4
  533. package/lib/components/EditSidePanel/EditSidePanel.js +40 -59
  534. package/lib/components/EditSidePanel/index.js +0 -1
  535. package/lib/components/EditTearsheet/EditTearsheet.js +39 -61
  536. package/lib/components/EditTearsheet/EditTearsheetForm.js +24 -39
  537. package/lib/components/EditTearsheet/index.js +0 -2
  538. package/lib/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +37 -62
  539. package/lib/components/EditTearsheetNarrow/EditTearsheetNarrow.js +30 -26
  540. package/lib/components/EditTearsheetNarrow/index.js +0 -1
  541. package/lib/components/EditUpdateCards/EditUpdateCards.js +146 -0
  542. package/lib/components/EditUpdateCards/index.js +12 -0
  543. package/lib/components/EmptyStates/EmptyState.js +36 -49
  544. package/lib/components/EmptyStates/EmptyStateContent.js +21 -27
  545. package/lib/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +31 -39
  546. package/lib/components/EmptyStates/ErrorEmptyState/index.js +0 -1
  547. package/lib/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +31 -39
  548. package/lib/components/EmptyStates/NoDataEmptyState/index.js +0 -1
  549. package/lib/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +31 -39
  550. package/lib/components/EmptyStates/NoTagsEmptyState/index.js +0 -1
  551. package/lib/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +31 -39
  552. package/lib/components/EmptyStates/NotFoundEmptyState/index.js +0 -1
  553. package/lib/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +31 -39
  554. package/lib/components/EmptyStates/NotificationsEmptyState/index.js +0 -1
  555. package/lib/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +31 -39
  556. package/lib/components/EmptyStates/UnauthorizedEmptyState/index.js +0 -1
  557. package/lib/components/EmptyStates/assets/ErrorIllustration.js +10 -13
  558. package/lib/components/EmptyStates/assets/NoDataIllustration.js +10 -13
  559. package/lib/components/EmptyStates/assets/NoTagsIllustration.js +10 -13
  560. package/lib/components/EmptyStates/assets/NotFoundIllustration.js +10 -13
  561. package/lib/components/EmptyStates/assets/NotificationsIllustration.js +10 -13
  562. package/lib/components/EmptyStates/assets/UnauthorizedIllustration.js +10 -13
  563. package/lib/components/EmptyStates/index.js +0 -7
  564. package/lib/components/ExampleComponent/ExampleComponent.js +75 -55
  565. package/lib/components/ExampleComponent/ExampleDeprecatedComponent.js +36 -0
  566. package/lib/components/ExampleComponent/index.js +0 -1
  567. package/lib/components/ExampleComponent/useExample.js +58 -0
  568. package/lib/components/ExportModal/ExportModal.js +46 -96
  569. package/lib/components/ExportModal/index.js +0 -1
  570. package/lib/components/ExpressiveCard/ExpressiveCard.js +6 -35
  571. package/lib/components/ExpressiveCard/index.js +0 -1
  572. package/lib/components/FilterSummary/FilterSummary.js +63 -0
  573. package/lib/components/FilterSummary/index.js +13 -0
  574. package/lib/components/HTTPErrors/HTTPError403/HTTPError403.js +19 -27
  575. package/lib/components/HTTPErrors/HTTPError403/index.js +0 -1
  576. package/lib/components/HTTPErrors/HTTPError404/HTTPError404.js +19 -27
  577. package/lib/components/HTTPErrors/HTTPError404/index.js +0 -1
  578. package/lib/components/HTTPErrors/HTTPErrorContent.js +17 -24
  579. package/lib/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +19 -27
  580. package/lib/components/HTTPErrors/HTTPErrorOther/index.js +0 -1
  581. package/lib/components/HTTPErrors/assets/HTTPErrorSvg403.js +6 -7
  582. package/lib/components/HTTPErrors/assets/HTTPErrorSvg404.js +6 -7
  583. package/lib/components/HTTPErrors/assets/HTTPErrorSvgOther.js +6 -7
  584. package/lib/components/HTTPErrors/index.js +0 -3
  585. package/lib/components/ImportModal/ImportModal.js +87 -155
  586. package/lib/components/ImportModal/index.js +0 -1
  587. package/lib/components/MultiAddSelect/MultiAddSelect.js +13 -39
  588. package/lib/components/MultiAddSelect/index.js +0 -1
  589. package/lib/components/NotificationsPanel/NotificationsPanel.js +87 -143
  590. package/lib/components/NotificationsPanel/NotificationsPanel_data.js +1 -4
  591. package/lib/components/NotificationsPanel/index.js +0 -1
  592. package/lib/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +1 -4
  593. package/lib/components/NotificationsPanel/utils.js +13 -21
  594. package/lib/components/OptionsTile/OptionsTile.js +74 -101
  595. package/lib/components/OptionsTile/index.js +0 -1
  596. package/lib/components/PageHeader/PageHeader.js +162 -252
  597. package/lib/components/PageHeader/PageHeaderDemo.data.js +0 -3
  598. package/lib/components/PageHeader/PageHeaderTitle.js +35 -52
  599. package/lib/components/PageHeader/PageHeaderUtils.js +23 -59
  600. package/lib/components/PageHeader/index.js +0 -1
  601. package/lib/components/ProductiveCard/ProductiveCard.js +15 -41
  602. package/lib/components/ProductiveCard/index.js +0 -1
  603. package/lib/components/RemoveModal/RemoveModal.js +45 -63
  604. package/lib/components/RemoveModal/index.js +0 -1
  605. package/lib/components/Saving/Saving.js +20 -44
  606. package/lib/components/Saving/index.js +0 -1
  607. package/lib/components/SidePanel/SidePanel.js +169 -233
  608. package/lib/components/SidePanel/constants.js +1 -1
  609. package/lib/components/SidePanel/index.js +0 -1
  610. package/lib/components/SidePanel/motion/variants.js +54 -0
  611. package/lib/components/SingleAddSelect/SingleAddSelect.js +6 -25
  612. package/lib/components/SingleAddSelect/index.js +0 -1
  613. package/lib/components/StatusIcon/StatusIcon.js +11 -25
  614. package/lib/components/StatusIcon/index.js +0 -1
  615. package/lib/components/TagSet/TagSet.js +66 -117
  616. package/lib/components/TagSet/TagSetModal.js +23 -46
  617. package/lib/components/TagSet/TagSetOverflow.js +19 -42
  618. package/lib/components/TagSet/constants.js +1 -0
  619. package/lib/components/TagSet/index.js +0 -1
  620. package/lib/components/Tearsheet/Tearsheet.js +39 -44
  621. package/lib/components/Tearsheet/TearsheetNarrow.js +29 -34
  622. package/lib/components/Tearsheet/TearsheetShell.js +93 -123
  623. package/lib/components/Tearsheet/index.js +0 -2
  624. package/lib/components/Toolbar/Toolbar.js +18 -41
  625. package/lib/components/Toolbar/ToolbarButton.js +13 -27
  626. package/lib/components/Toolbar/ToolbarGroup.js +8 -16
  627. package/lib/components/Toolbar/index.js +0 -3
  628. package/lib/components/UserProfileImage/UserProfileImage.js +28 -48
  629. package/lib/components/UserProfileImage/index.js +0 -1
  630. package/lib/components/WebTerminal/WebTerminal.js +46 -70
  631. package/lib/components/WebTerminal/WebTerminalContentWrapper.js +17 -20
  632. package/lib/components/WebTerminal/hooks/index.js +8 -19
  633. package/lib/components/WebTerminal/index.js +0 -3
  634. package/lib/components/WebTerminal/preview-components/Navigation.js +2 -9
  635. package/lib/components/WebTerminal/preview-components/documentationLinks.js +1 -0
  636. package/lib/components/WebTerminal/preview-components/index.js +0 -2
  637. package/lib/components/_Canary/Canary.js +14 -17
  638. package/lib/components/_Canary/index.js +0 -1
  639. package/lib/components/index.js +33 -52
  640. package/lib/global/js/hooks/index.js +8 -11
  641. package/lib/global/js/hooks/useActiveElement.js +4 -10
  642. package/lib/global/js/hooks/useClickOutside.js +1 -4
  643. package/lib/global/js/hooks/useControllableState.js +80 -0
  644. package/lib/global/js/hooks/useCreateComponentFocus.js +35 -17
  645. package/lib/global/js/hooks/useCreateComponentStepChange.js +94 -136
  646. package/lib/global/js/hooks/usePreviousValue.js +0 -3
  647. package/lib/global/js/hooks/useResetCreateComponent.js +14 -13
  648. package/lib/global/js/hooks/useResizeObserver.js +83 -0
  649. package/lib/global/js/hooks/useRetrieveStepData.js +5 -12
  650. package/lib/global/js/hooks/useValidCreateStepCount.js +0 -3
  651. package/lib/global/js/hooks/useWindowResize.js +14 -22
  652. package/lib/global/js/hooks/useWindowScroll.js +10 -19
  653. package/lib/global/js/package-settings.js +37 -23
  654. package/lib/global/js/utils/ClickListener.js +3 -16
  655. package/lib/global/js/utils/DisplayBox.js +3 -9
  656. package/lib/global/js/utils/Wrap.js +16 -22
  657. package/lib/global/js/utils/deepCloneObject.js +5 -11
  658. package/lib/global/js/utils/devtools.js +1 -6
  659. package/lib/global/js/utils/getBezierValues.js +25 -0
  660. package/lib/global/js/utils/getFocusableElements.js +1 -4
  661. package/lib/global/js/utils/getNumberOfHiddenSteps.js +26 -0
  662. package/lib/global/js/utils/getScrollbarWidth.js +1 -2
  663. package/lib/global/js/utils/keyboardNavigation.js +7 -6
  664. package/lib/global/js/utils/lastIndexInArray.js +0 -4
  665. package/lib/global/js/utils/motionConstants.js +51 -0
  666. package/lib/global/js/utils/pconsole.js +1 -7
  667. package/lib/global/js/utils/props-helper.js +21 -58
  668. package/lib/global/js/utils/rangeWithCallback.js +1 -2
  669. package/lib/global/js/utils/scrollableAncestor.js +6 -13
  670. package/lib/global/js/utils/story-helper.js +41 -25
  671. package/lib/global/js/utils/test-helper.js +74 -88
  672. package/lib/global/js/utils/unwrap-if-fragment.js +8 -20
  673. package/lib/global/js/utils/uuidv4.js +1 -3
  674. package/lib/global/js/utils/uuidv4.spec.js +1 -3
  675. package/lib/global/js/utils/wait.js +1 -2
  676. package/lib/global/js/utils/wrapFocus.js +6 -16
  677. package/lib/index.js +0 -3
  678. package/lib/settings.js +49 -38
  679. package/package.json +29 -27
  680. package/scss/components/AboutModal/_about-modal.scss +26 -60
  681. package/scss/components/AboutModal/_storybook-styles.scss +18 -5
  682. package/scss/components/ActionBar/_action-bar.scss +0 -4
  683. package/scss/components/ActionSet/_action-set.scss +28 -10
  684. package/scss/components/AddSelect/_add-select.scss +44 -72
  685. package/scss/components/AddSelect/_index.scss +1 -1
  686. package/scss/components/AddSelect/_storybook-styles.scss +1 -1
  687. package/scss/components/BreadcrumbWithOverflow/_breadcrumb-with-overflow.scss +10 -1
  688. package/scss/components/Card/_card.scss +13 -6
  689. package/scss/components/CreateFullPage/_create-full-page.scss +5 -10
  690. package/scss/components/CreateTearsheet/_create-tearsheet.scss +8 -3
  691. package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +1 -1
  692. package/scss/components/Datagrid/_datagrid.scss +0 -1
  693. package/scss/components/Datagrid/_storybook-styles.scss +21 -0
  694. package/scss/components/Datagrid/styles/_datagrid.scss +131 -29
  695. package/scss/components/Datagrid/styles/_draggableElement.scss +27 -12
  696. package/scss/components/Datagrid/styles/_index.scss +9 -8
  697. package/scss/components/Datagrid/styles/_useExpandedRow.scss +20 -2
  698. package/scss/components/Datagrid/styles/_useInlineEdit.scss +36 -9
  699. package/scss/components/Datagrid/styles/_useNestedRows.scss +36 -0
  700. package/scss/components/Datagrid/styles/_useSelectAllToggle.scss +23 -15
  701. package/scss/components/Datagrid/styles/_useSortableColumns.scss +40 -18
  702. package/scss/components/Datagrid/styles/_useStickyColumn.scss +3 -3
  703. package/scss/components/Datagrid/styles/addons/_CustomizeColumnsTearsheet.scss +82 -0
  704. package/scss/components/Datagrid/styles/addons/_FilterFlyout.scss +87 -0
  705. package/scss/components/Datagrid/styles/addons/_FilterPanel.scss +129 -0
  706. package/scss/components/Datagrid/styles/addons/_RowSizeDropdown.scss +19 -7
  707. package/scss/components/EditInPlace/_carbon-imports.scss +9 -0
  708. package/scss/components/EditInPlace/_edit-in-place.scss +164 -0
  709. package/scss/components/{InlineEdit → EditInPlace}/_index-with-carbon.scss +1 -1
  710. package/scss/components/EditInPlace/_index.scss +10 -0
  711. package/scss/components/{InlineEdit → EditInPlace}/_storybook-styles.scss +3 -15
  712. package/scss/components/EditTearsheet/_edit-tearsheet.scss +6 -4
  713. package/scss/components/EditUpdateCards/_carbon-imports.scss +9 -0
  714. package/scss/components/EditUpdateCards/_edit-update-cards.scss +85 -0
  715. package/scss/components/{InlineEdit/_carbon-imports.scss → EditUpdateCards/_index-with-carbon.scss} +3 -0
  716. package/scss/components/{InlineEdit → EditUpdateCards}/_index.scss +1 -1
  717. package/scss/components/EditUpdateCards/_storybook-styles.scss +55 -0
  718. package/scss/components/EmptyStates/_empty-state.scss +29 -6
  719. package/scss/components/ExportModal/_export-modal.scss +0 -4
  720. package/scss/components/ExpressiveCard/_expressive-card.scss +1 -1
  721. package/scss/components/FilterSummary/_filter-summary.scss +21 -0
  722. package/scss/components/{ModifiedTabs → FilterSummary}/_index.scss +4 -2
  723. package/scss/components/{ModifiedTabs/_index-with-carbon.scss → FilterSummary/_storybook-styles.scss} +8 -3
  724. package/scss/components/HTTPErrors/_http-errors.scss +8 -4
  725. package/scss/components/MultiAddSelect/_multi-add-select.scss +8 -1
  726. package/scss/components/MultiAddSelect/_storybook-styles.scss +1 -1
  727. package/scss/components/OptionsTile/_options-tile.scss +10 -3
  728. package/scss/components/PageHeader/_page-header.scss +9 -12
  729. package/scss/components/ProductiveCard/_productive-card.scss +31 -2
  730. package/scss/components/SidePanel/_side-panel.scss +10 -97
  731. package/scss/components/SidePanel/_storybook-styles.scss +6 -1
  732. package/scss/components/SingleAddSelect/_carbon-imports.scss +1 -1
  733. package/scss/components/SingleAddSelect/_index-with-carbon.scss +1 -1
  734. package/scss/components/SingleAddSelect/_index.scss +7 -0
  735. package/scss/components/SingleAddSelect/_single-add-select.scss +8 -1
  736. package/scss/components/SingleAddSelect/_storybook-styles.scss +1 -1
  737. package/scss/components/TagSet/_tag-set.scss +1 -0
  738. package/scss/components/Tearsheet/_carbon-imports.scss +2 -1
  739. package/scss/components/Tearsheet/_tearsheet.scss +10 -5
  740. package/scss/components/UserProfileImage/_user-profile-image.scss +5 -0
  741. package/scss/components/_index-released-only-with-carbon.scss +3 -1
  742. package/scss/components/_index-released-only.scss +3 -1
  743. package/scss/components/_index-with-carbon.scss +2 -2
  744. package/scss/components/_index.scss +3 -2
  745. package/scss/config.scss +1 -0
  746. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsModal.js +0 -194
  747. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ModalWrapper.js +0 -63
  748. package/es/components/Datagrid/Datagrid.stories/LeftPanelStory.js +0 -6
  749. package/es/components/InlineEdit/InlineEdit.js +0 -447
  750. package/es/components/ModifiedTabs/ModifiedTabLabelNew.js +0 -34
  751. package/es/components/ModifiedTabs/ModifiedTabLabelWithClose.js +0 -47
  752. package/es/components/ModifiedTabs/ModifiedTabs.js +0 -141
  753. package/es/components/ModifiedTabs/index.js +0 -1
  754. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsModal.js +0 -209
  755. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ModalWrapper.js +0 -74
  756. package/lib/components/Datagrid/Datagrid.stories/LeftPanelStory.js +0 -13
  757. package/lib/components/InlineEdit/InlineEdit.js +0 -464
  758. package/lib/components/ModifiedTabs/ModifiedTabLabelNew.js +0 -50
  759. package/lib/components/ModifiedTabs/ModifiedTabLabelWithClose.js +0 -63
  760. package/lib/components/ModifiedTabs/ModifiedTabs.js +0 -164
  761. package/lib/components/ModifiedTabs/index.js +0 -13
  762. package/scss/components/Datagrid/styles/addons/_CustomizeColumnsModal.scss +0 -91
  763. package/scss/components/InlineEdit/_inline-edit.scss +0 -355
  764. package/scss/components/ModifiedTabs/_carbon-imports.scss +0 -10
  765. package/scss/components/ModifiedTabs/_modified-tabs.scss +0 -89
  766. package/scss/components/ModifiedTabs/_storybook-styles.scss +0 -6
@@ -1,99 +1,81 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
5
  Object.defineProperty(exports, "__esModule", {
8
6
  value: true
9
7
  });
10
8
  exports.BreadcrumbWithOverflow = void 0;
11
-
12
9
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
-
14
10
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
15
-
16
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
-
18
12
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
19
-
20
13
  var _react = _interopRequireWildcard(require("react"));
21
-
22
14
  var _propTypes = _interopRequireDefault(require("prop-types"));
23
-
24
15
  var _classnames = _interopRequireDefault(require("classnames"));
25
-
26
- var _reactResizeDetector = require("react-resize-detector");
27
-
16
+ var _useResizeObserver = require("../../global/js/hooks/useResizeObserver");
28
17
  var _react2 = require("@carbon/react");
29
-
30
18
  var _settings = require("../../settings");
31
-
32
19
  var _icons = require("@carbon/react/icons");
33
-
34
20
  var _uuidv = _interopRequireDefault(require("../../global/js/utils/uuidv4"));
35
-
36
21
  require("../../global/js/utils/props-helper");
37
-
38
22
  var _excluded = ["breadcrumbs", "className", "maxVisible", "noTrailingSlash", "overflowAriaLabel"],
39
- _excluded2 = ["label", "key", "title", "id"],
40
- _excluded3 = ["className", "key", "label", "title"];
41
-
23
+ _excluded2 = ["label", "key", "title", "id"],
24
+ _excluded3 = ["className", "key", "label", "title"]; //
25
+ // Copyright IBM Corp. 2020, 2023
26
+ //
27
+ // This source code is licensed under the Apache-2.0 license found in the
28
+ // LICENSE file in the root directory of this source tree.
29
+ //
30
+ // Import portions of React that are needed.
31
+ // Other standard imports.
32
+ // Carbon and package components we use.
42
33
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
43
-
44
34
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
45
-
46
35
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
47
-
48
36
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
49
-
50
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
51
-
37
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
52
38
  // The block part of our conventional BEM class names (blockClass__E--M).
53
39
  var blockClass = "".concat(_settings.pkg.prefix, "--breadcrumb-with-overflow");
54
- var componentName = 'BreadcrumbWithOverflow'; // NOTE: the component SCSS is not imported here: it is rolled up separately.
40
+ var componentName = 'BreadcrumbWithOverflow';
41
+
42
+ // NOTE: the component SCSS is not imported here: it is rolled up separately.
55
43
 
56
44
  /**
57
45
  * The BreadcrumbWithOverflow is used internally by the PageHeader to wrap BreadcrumbItems.
58
46
  */
59
-
60
47
  var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
61
48
  var _backItem, _backItem2, _backItem3;
62
-
63
49
  var breadcrumbs = _ref.breadcrumbs,
64
- className = _ref.className,
65
- maxVisible = _ref.maxVisible,
66
- noTrailingSlash = _ref.noTrailingSlash,
67
- overflowAriaLabel = _ref.overflowAriaLabel,
68
- other = (0, _objectWithoutProperties2.default)(_ref, _excluded);
50
+ className = _ref.className,
51
+ maxVisible = _ref.maxVisible,
52
+ noTrailingSlash = _ref.noTrailingSlash,
53
+ overflowAriaLabel = _ref.overflowAriaLabel,
54
+ other = (0, _objectWithoutProperties2.default)(_ref, _excluded);
69
55
  var carbonPrefix = (0, _react2.usePrefix)();
70
-
71
56
  var _useState = (0, _react.useState)(3),
72
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
73
- displayCount = _useState2[0],
74
- setDisplayCount = _useState2[1];
75
-
57
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
58
+ displayCount = _useState2[0],
59
+ setDisplayCount = _useState2[1];
76
60
  var _useState3 = (0, _react.useState)([]),
77
- _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
78
- displayedBreadcrumbItems = _useState4[0],
79
- setDisplayedBreadcrumbItems = _useState4[1];
80
-
61
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
62
+ displayedBreadcrumbItems = _useState4[0],
63
+ setDisplayedBreadcrumbItems = _useState4[1];
81
64
  var breadcrumbItemWithOverflow = (0, _react.useRef)(null);
82
65
  var sizingContainerRef = (0, _react.useRef)(null);
83
66
  var internalId = (0, _react.useRef)((0, _uuidv.default)());
84
-
85
67
  var _useState5 = (0, _react.useState)([]),
86
- _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
87
- hiddenSizingItems = _useState6[0],
88
- setHiddenSizingItems = _useState6[1]; // eslint-disable-next-line react/prop-types
89
-
68
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
69
+ hiddenSizingItems = _useState6[0],
70
+ setHiddenSizingItems = _useState6[1];
90
71
 
72
+ // eslint-disable-next-line react/prop-types
91
73
  var BreadcrumbOverflowMenu = function BreadcrumbOverflowMenu(_ref2) {
92
74
  var overflowItems = _ref2.overflowItems;
93
75
  return /*#__PURE__*/_react.default.createElement(_react2.BreadcrumbItem, {
94
76
  key: "breadcrumb-overflow-".concat(internalId.current)
95
77
  }, /*#__PURE__*/_react.default.createElement(_react2.OverflowMenu, {
96
- ariaLabel: overflowAriaLabel,
78
+ "aria-label": overflowAriaLabel,
97
79
  iconDescription: overflowAriaLabel // also needs setting to avoid a11y "Accessible name does not match or contain the visible label text"
98
80
  ,
99
81
  renderIcon: function renderIcon(props) {
@@ -103,7 +85,8 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
103
85
  },
104
86
  className: "".concat(blockClass, "__overflow-menu"),
105
87
  menuOptionsClass: "".concat(blockClass, "__overflow-menu-options")
106
- }, // eslint-disable-next-line react/prop-types
88
+ },
89
+ // eslint-disable-next-line react/prop-types
107
90
  overflowItems.map(function (item, index) {
108
91
  return /*#__PURE__*/_react.default.createElement(_react2.OverflowMenuItem, {
109
92
  key: "breadcrumb-overflow-menu-item-".concat(internalId.current, "-").concat(index),
@@ -112,9 +95,9 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
112
95
  itemText: item.props.children
113
96
  });
114
97
  })));
115
- }; // create hidden sizing items
116
-
98
+ };
117
99
 
100
+ // create hidden sizing items
118
101
  (0, _react.useEffect)(function () {
119
102
  // Hidden action bar and items used to calculate sizes
120
103
  setHiddenSizingItems( /*#__PURE__*/_react.default.createElement("div", {
@@ -124,7 +107,7 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
124
107
  }, /*#__PURE__*/_react.default.createElement(_react2.Breadcrumb, null, /*#__PURE__*/_react.default.createElement(_react2.BreadcrumbItem, {
125
108
  key: "".concat(blockClass, "-hidden-overflow-").concat(internalId)
126
109
  }, /*#__PURE__*/_react.default.createElement(_react2.OverflowMenu, {
127
- ariaLabel: overflowAriaLabel,
110
+ "aria-label": overflowAriaLabel,
128
111
  renderIcon: function renderIcon(props) {
129
112
  return /*#__PURE__*/_react.default.createElement(_icons.OverflowMenuHorizontal, (0, _extends2.default)({
130
113
  size: 32
@@ -132,10 +115,10 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
132
115
  }
133
116
  })), breadcrumbs.map(function (_ref3) {
134
117
  var label = _ref3.label,
135
- key = _ref3.key,
136
- title = _ref3.title,
137
- id = _ref3.id,
138
- rest = (0, _objectWithoutProperties2.default)(_ref3, _excluded2);
118
+ key = _ref3.key,
119
+ title = _ref3.title,
120
+ id = _ref3.id,
121
+ rest = (0, _objectWithoutProperties2.default)(_ref3, _excluded2);
139
122
  return /*#__PURE__*/_react.default.createElement(_react2.BreadcrumbItem, (0, _extends2.default)({
140
123
  key: key
141
124
  }, rest, {
@@ -147,49 +130,48 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
147
130
  }, [breadcrumbs, overflowAriaLabel]);
148
131
  (0, _react.useEffect)(function () {
149
132
  // updates displayedBreadcrumbItems and overflowBreadcrumbItems based on displayCount and breadcrumbs
150
-
151
133
  /* istanbul ignore if */
152
134
  if (breadcrumbs.length === 0) {
153
135
  setDisplayedBreadcrumbItems([]);
154
136
  return;
155
137
  }
156
-
157
138
  var newDisplayedBreadcrumbItems = breadcrumbs.map(function (_ref4, index) {
158
139
  var className = _ref4.className,
159
- key = _ref4.key,
160
- label = _ref4.label,
161
- title = _ref4.title,
162
- rest = (0, _objectWithoutProperties2.default)(_ref4, _excluded3);
140
+ key = _ref4.key,
141
+ label = _ref4.label,
142
+ title = _ref4.title,
143
+ rest = (0, _objectWithoutProperties2.default)(_ref4, _excluded3);
163
144
  return /*#__PURE__*/_react.default.createElement(_react2.BreadcrumbItem, (0, _extends2.default)({
164
145
  key: key,
165
146
  className: index > 0 || displayCount > 1 ? (0, _classnames.default)([className, "".concat(blockClass, "__displayed-breadcrumb")]) : className,
166
147
  title: index + 1 === breadcrumbs.length ? title : null
167
148
  }, rest), label);
168
- }); // The breadcrumb has the form [first item] [overflow] [items 2...(n-1)] [last item].
149
+ });
150
+
151
+ // The breadcrumb has the form [first item] [overflow] [items 2...(n-1)] [last item].
169
152
  // The overflow is only shown if there isn't space to display all the items, and in that case:
170
153
  // * the last item is always displayed (even if there isn't really space for it -- it can contract to an ellipsis);
171
154
  // * the first item is the next to be displayed, if there's space once the last item and overflow are shown;
172
155
  // * any remaining space after the first item, last item and overflow are shown is used to show items (n-1), (n-2), (n-3), ..., until the space is used up ;
173
156
  // Note that displayCount (min 1) has been computed based on the available space and the above sequence.
174
-
175
157
  var overflowPosition = displayCount > 1 ? 1 : 0;
176
- var newOverflowBreadcrumbItems = newDisplayedBreadcrumbItems.splice(overflowPosition, breadcrumbs.length - displayCount); // if needed add overflow menu
158
+ var newOverflowBreadcrumbItems = newDisplayedBreadcrumbItems.splice(overflowPosition, breadcrumbs.length - displayCount);
177
159
 
160
+ // if needed add overflow menu
178
161
  if (newOverflowBreadcrumbItems.length) {
179
162
  newDisplayedBreadcrumbItems.splice(overflowPosition, 0, /*#__PURE__*/_react.default.createElement(BreadcrumbOverflowMenu, {
180
163
  overflowItems: newOverflowBreadcrumbItems,
181
164
  key: "displayed-breadcrumb-".concat(internalId, "-overflow")
182
165
  }));
183
166
  }
184
-
185
167
  setDisplayedBreadcrumbItems(newDisplayedBreadcrumbItems);
186
168
  }, [breadcrumbs, displayCount]);
187
-
188
169
  var checkFullyVisibleBreadcrumbItems = function checkFullyVisibleBreadcrumbItems() {
189
170
  var displayItemIndex = function displayItemIndex(itemCount, index) {
190
171
  // In this data set the overflow measuring item is [0]
191
172
  // so the first displayItem in the list is [1]
192
173
  // we never return 0;
174
+
193
175
  if (index === 0) {
194
176
  return itemCount - 1; // the last item in the list
195
177
  } else if (index === 1) {
@@ -207,14 +189,11 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
207
189
  var spaceAvailable = breadcrumbItemWithOverflow.current.offsetWidth; // not sure how to test resize
208
190
 
209
191
  /* istanbul ignore next */
210
-
211
192
  if (sizingContainerRef.current) {
212
193
  var sizingBreadcrumbItems = sizingContainerRef.current.querySelectorAll(".".concat(carbonPrefix, "--breadcrumb-item"));
213
194
  var breadcrumbWidthsIncludingMargin = [];
214
-
215
195
  var _iterator = _createForOfIteratorHelper(sizingBreadcrumbItems),
216
- _step;
217
-
196
+ _step;
218
197
  try {
219
198
  for (_iterator.s(); !(_step = _iterator.n()).done;) {
220
199
  var item = _step.value;
@@ -227,34 +206,33 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
227
206
  } finally {
228
207
  _iterator.f();
229
208
  }
230
-
231
209
  var overflowWidth = breadcrumbWidthsIncludingMargin[0];
232
-
233
210
  for (var i = 0; i < breadcrumbWidthsIncludingMargin.length - 1; i++) {
234
211
  // count used one less than length to account for the included overflow item
235
212
  var index = displayItemIndex(breadcrumbWidthsIncludingMargin.length, i);
236
-
237
213
  if (spaceAvailable >= breadcrumbWidthsIncludingMargin[index]) {
238
214
  spaceAvailable -= breadcrumbWidthsIncludingMargin[index];
239
215
  willFit += 1;
240
216
  } else {
241
217
  break;
242
218
  }
243
- } // if not enough space for all breadcrumb items
244
-
219
+ }
245
220
 
221
+ // if not enough space for all breadcrumb items
246
222
  if (willFit < breadcrumbWidthsIncludingMargin.length - 1) {
247
223
  // -1 for overflow item
224
+
248
225
  while (willFit > 0 && spaceAvailable < overflowWidth) {
249
- willFit -= 1; // Highly unlikely any useful breadcrumb-item is smaller than the overflow menu, but we loop anyway just in case
250
- // item removed is based on last item added which is the current value of willFit
226
+ willFit -= 1;
251
227
 
228
+ // Highly unlikely any useful breadcrumb-item is smaller than the overflow menu, but we loop anyway just in case
229
+
230
+ // item removed is based on last item added which is the current value of willFit
252
231
  var itemToRemove = displayItemIndex(breadcrumbWidthsIncludingMargin.length, willFit);
253
232
  spaceAvailable += breadcrumbWidthsIncludingMargin[itemToRemove];
254
233
  }
255
234
  }
256
235
  }
257
-
258
236
  if (willFit <= 1) {
259
237
  setDisplayCount(1);
260
238
  } else {
@@ -262,43 +240,29 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
262
240
  }
263
241
  }
264
242
  };
265
-
266
243
  (0, _react.useEffect)(function () {
267
- checkFullyVisibleBreadcrumbItems(); // eslint-disable-next-line react-hooks/exhaustive-deps
244
+ checkFullyVisibleBreadcrumbItems();
245
+ // eslint-disable-next-line react-hooks/exhaustive-deps
268
246
  }, [hiddenSizingItems, maxVisible]);
269
- /* istanbul ignore next */
270
- // not sure how to test resize
271
247
 
248
+ /* istanbul ignore next */ // not sure how to test resize
272
249
  var handleResize = function handleResize() {
273
- /* istanbul ignore next */
274
- // not sure how to test resize
275
- checkFullyVisibleBreadcrumbItems();
276
- };
277
- /* istanbul ignore next */
278
- // not sure how to test resize
279
-
280
-
281
- var handleBreadcrumbItemsResize = function handleBreadcrumbItemsResize() {
282
- /* istanbul ignore next */
283
- // not sure how to test resize
250
+ /* istanbul ignore next */ // not sure how to test resize
284
251
  checkFullyVisibleBreadcrumbItems();
285
252
  };
286
-
287
253
  var backItem = breadcrumbs[breadcrumbs.length - 1];
288
- /* istanbul ignore if */
289
- // not sure how to test media queries
290
-
254
+ /* istanbul ignore if */ // not sure how to test media queries
291
255
  if (backItem.isCurrentPage) {
292
256
  backItem = breadcrumbs[breadcrumbs.length - 2];
293
257
  }
294
258
 
295
- (0, _reactResizeDetector.useResizeDetector)({
296
- onResize: handleBreadcrumbItemsResize,
297
- targetRef: sizingContainerRef
259
+ // container resize
260
+ (0, _useResizeObserver.useResizeObserver)(sizingContainerRef, {
261
+ callback: handleResize
298
262
  });
299
- (0, _reactResizeDetector.useResizeDetector)({
300
- onResize: handleResize,
301
- targetRef: breadcrumbItemWithOverflow
263
+ // item resize
264
+ (0, _useResizeObserver.useResizeObserver)(breadcrumbItemWithOverflow, {
265
+ callback: handleResize
302
266
  });
303
267
  return /*#__PURE__*/_react.default.createElement("div", {
304
268
  className: (0, _classnames.default)(blockClass, className, (0, _defineProperty2.default)({}, "".concat(blockClass, "__with-items"), displayedBreadcrumbItems.length > 1)),
@@ -314,16 +278,19 @@ var BreadcrumbWithOverflow = function BreadcrumbWithOverflow(_ref) {
314
278
  href: backItem.href,
315
279
  renderIcon: function renderIcon() {
316
280
  return /*#__PURE__*/_react.default.createElement(_react2.IconButton, {
281
+ className: "".concat(blockClass, "__back__button"),
282
+ align: "right",
283
+ kind: "ghost",
317
284
  label: backItem.title || backItem.label,
318
- align: "right"
285
+ size: "sm"
319
286
  }, /*#__PURE__*/_react.default.createElement(_icons.ArrowLeft, {
320
287
  size: 16
321
288
  }));
322
289
  }
323
290
  })), displayedBreadcrumbItems)));
324
- }; // Return a placeholder if not released and not enabled by feature flag
325
-
291
+ };
326
292
 
293
+ // Return a placeholder if not released and not enabled by feature flag
327
294
  exports.BreadcrumbWithOverflow = BreadcrumbWithOverflow;
328
295
  exports.BreadcrumbWithOverflow = BreadcrumbWithOverflow = _settings.pkg.checkComponentEnabled(BreadcrumbWithOverflow, componentName);
329
296
  BreadcrumbWithOverflow.propTypes = {
@@ -332,22 +299,18 @@ BreadcrumbWithOverflow.propTypes = {
332
299
  * Optional string representing the link location for the BreadcrumbItem
333
300
  */
334
301
  href: _propTypes.default.string,
335
-
336
302
  /**
337
303
  * Provide if this breadcrumb item represents the current page
338
304
  */
339
305
  isCurrentPage: _propTypes.default.bool,
340
-
341
306
  /**
342
307
  * Key required to render array efficiently
343
308
  */
344
309
  key: _propTypes.default.string.isRequired,
345
-
346
310
  /**
347
311
  * Pass in content that will be inside of the BreadcrumbItem
348
312
  */
349
313
  label: _propTypes.default.node,
350
-
351
314
  /**
352
315
  * A string based alternative to the children, required only if children is not of type string.
353
316
  */
@@ -356,22 +319,18 @@ BreadcrumbWithOverflow.propTypes = {
356
319
  return typeof label !== 'string';
357
320
  })
358
321
  })),
359
-
360
322
  /**
361
323
  * className
362
324
  */
363
325
  className: _propTypes.default.string,
364
-
365
326
  /**
366
327
  * maxVisible: maximum visible breadcrumb-items before overflow is used (values less than 1 are treated as 1)
367
328
  */
368
329
  maxVisible: _propTypes.default.number,
369
-
370
330
  /**
371
331
  * noTrailing slash - same as for Carbon
372
332
  */
373
333
  noTrailingSlash: _propTypes.default.bool,
374
-
375
334
  /**
376
335
  * overflowAriaLabel label for open close button overflow used for breadcrumb items that do not fit.
377
336
  */
@@ -9,5 +9,4 @@ Object.defineProperty(exports, "BreadcrumbWithOverflow", {
9
9
  return _BreadcrumbWithOverflow.BreadcrumbWithOverflow;
10
10
  }
11
11
  });
12
-
13
12
  var _BreadcrumbWithOverflow = require("./BreadcrumbWithOverflow");
@@ -1,36 +1,39 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.ButtonMenu = void 0;
9
-
10
8
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
-
12
9
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
-
14
10
  var _react = _interopRequireDefault(require("react"));
15
-
16
11
  var _propTypes = _interopRequireDefault(require("prop-types"));
17
-
18
12
  var _classnames = _interopRequireDefault(require("classnames"));
19
-
20
13
  var _settings = require("../../settings");
21
-
22
14
  var _react2 = require("@carbon/react");
23
-
24
15
  var _excluded = ["children", "className", "iconDescription", "kind", "label", "menuAriaLabel", "menuOptionsClass", "renderIcon", "size"];
16
+ /**
17
+ * Copyright IBM Corp. 2021, 2023
18
+ *
19
+ * This source code is licensed under the Apache-2.0 license found in the
20
+ * LICENSE file in the root directory of this source tree.
21
+ */
22
+ // Import portions of React that are needed.
23
+ // Other standard imports.
24
+ // Carbon and package components we use.
25
25
  // The block part of our conventional BEM class names (blockClass__E--M).
26
26
  var blockClass = "".concat(_settings.pkg.prefix, "--button-menu");
27
- var componentName = 'ButtonMenu'; // NOTE: the component SCSS is not imported here: it is rolled up separately.
28
- // Default values for props
27
+ var componentName = 'ButtonMenu';
29
28
 
29
+ // NOTE: the component SCSS is not imported here: it is rolled up separately.
30
+
31
+ // Default values for props
30
32
  var defaults = {
31
33
  size: 'lg',
32
34
  kind: 'primary'
33
35
  };
36
+
34
37
  /**
35
38
  * Combining a standard button with an overflow menu, this component appears
36
39
  * as a button and has all the usual carbon Button props and rendering, but
@@ -38,27 +41,29 @@ var defaults = {
38
41
  * zero to many ButtonMenuItem, which is identical to the carbon
39
42
  * OverflowMenuItem component.
40
43
  */
41
-
42
44
  var ButtonMenu = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref) {
43
45
  var children = _ref.children,
44
- className = _ref.className,
45
- iconDescription = _ref.iconDescription,
46
- _ref$kind = _ref.kind,
47
- kind = _ref$kind === void 0 ? defaults.kind : _ref$kind,
48
- label = _ref.label,
49
- menuAriaLabel = _ref.menuAriaLabel,
50
- menuOptionsClass = _ref.menuOptionsClass,
51
- Icon = _ref.renderIcon,
52
- _ref$size = _ref.size,
53
- size = _ref$size === void 0 ? defaults.size : _ref$size,
54
- rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
46
+ className = _ref.className,
47
+ iconDescription = _ref.iconDescription,
48
+ _ref$kind = _ref.kind,
49
+ kind = _ref$kind === void 0 ? defaults.kind : _ref$kind,
50
+ label = _ref.label,
51
+ menuAriaLabel = _ref.menuAriaLabel,
52
+ menuOptionsClass = _ref.menuOptionsClass,
53
+ Icon = _ref.renderIcon,
54
+ _ref$size = _ref.size,
55
+ size = _ref$size === void 0 ? defaults.size : _ref$size,
56
+ rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
55
57
  var carbonPrefix = (0, _react2.usePrefix)();
56
58
  return /*#__PURE__*/_react.default.createElement(_react2.OverflowMenu, (0, _extends2.default)({}, rest, {
57
- className: (0, _classnames.default)(blockClass, // Apply the block class to the main HTML element
59
+ className: (0, _classnames.default)(blockClass,
60
+ // Apply the block class to the main HTML element
58
61
  className // Apply any supplied class names to the main HTML element.
59
62
  ),
60
- ariaLabel: menuAriaLabel,
63
+
64
+ "aria-label": menuAriaLabel,
61
65
  menuOptionsClass: (0, _classnames.default)("".concat(blockClass, "__options"), menuOptionsClass),
66
+ size: size,
62
67
  renderIcon: function renderIcon() {
63
68
  return /*#__PURE__*/_react.default.createElement("div", {
64
69
  className: (0, _classnames.default)(["".concat(blockClass, "__trigger"), "".concat(carbonPrefix, "--btn"), "".concat(carbonPrefix, "--btn--").concat(kind), "".concat(carbonPrefix, "--btn--").concat(size)])
@@ -70,65 +75,59 @@ var ButtonMenu = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref) {
70
75
  },
71
76
  innerRef: ref
72
77
  }), children);
73
- }); // Return a placeholder if not released and not enabled by feature flag
74
-
78
+ });
75
79
 
80
+ // Return a placeholder if not released and not enabled by feature flag
76
81
  exports.ButtonMenu = ButtonMenu;
77
- exports.ButtonMenu = ButtonMenu = _settings.pkg.checkComponentEnabled(ButtonMenu, componentName); // The display name of the component, used by React. Note that displayName
82
+ exports.ButtonMenu = ButtonMenu = _settings.pkg.checkComponentEnabled(ButtonMenu, componentName);
83
+
84
+ // The display name of the component, used by React. Note that displayName
78
85
  // is used in preference to relying on function.name.
86
+ ButtonMenu.displayName = componentName;
79
87
 
80
- ButtonMenu.displayName = componentName; // The types and DocGen commentary for the component props,
88
+ // The types and DocGen commentary for the component props,
81
89
  // in alphabetical order (for consistency).
82
90
  // See https://www.npmjs.com/package/prop-types#usage.
83
-
84
91
  ButtonMenu.propTypes = {
85
92
  /**
86
93
  * Provide the contents of the ButtonMenu. This should be one or more
87
94
  * ButtonMenuItem components.
88
95
  */
89
96
  children: _propTypes.default.arrayOf(_propTypes.default.element).isRequired,
90
-
91
97
  /**
92
98
  * Provide an optional class to be applied to the containing node.
93
99
  */
94
100
  className: _propTypes.default.string,
95
-
96
101
  /**
97
102
  * If specifying the `renderIcon` prop, provide a description for that icon that can
98
103
  * be read by screen readers
99
104
  */
100
105
  iconDescription: _react2.Button.propTypes.iconDescription,
101
-
102
106
  /**
103
107
  * The three types the menu button supports: primary, tertiary and ghost.
104
108
  */
105
109
  kind: _propTypes.default.oneOf(['primary', 'tertiary', 'ghost']),
106
-
107
110
  /**
108
111
  * The button label for the menu trigger.
109
112
  */
110
113
  label: _propTypes.default.node,
111
-
112
114
  /**
113
115
  * Provide the ariaLabel prop to be passed to the OverflowMenu. This is distinctly
114
116
  * separate from `label` to support icon only ButtonMenus
115
117
  */
116
118
  menuAriaLabel: _propTypes.default.string.isRequired,
117
-
118
119
  /**
119
120
  * class name applied to the overflow options
120
121
  */
121
122
  menuOptionsClass: _propTypes.default.string,
122
-
123
123
  /**
124
124
  * Optional prop to allow overriding the icon rendering.
125
125
  * Can be a React component class
126
126
  */
127
127
  renderIcon: _react2.Button.propTypes.renderIcon,
128
-
129
128
  /**
130
- * The size of the button for the menu trigger. The values can be any valid
131
- * value for the carbon Button component 'size' prop.
129
+ * The size of the button for the menu trigger.
130
+ * The menu button supports: sm, md, lg
132
131
  */
133
- size: _react2.Button.propTypes.size
132
+ size: _propTypes.default.oneOf(['sm', 'md', 'lg'])
134
133
  };
@@ -1,43 +1,42 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.ButtonMenuItem = void 0;
9
-
10
8
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
-
12
9
  var _react = _interopRequireDefault(require("react"));
13
-
14
10
  var _settings = require("../../settings");
15
-
16
11
  var _react2 = require("@carbon/react");
17
-
18
12
  /**
19
13
  * Copyright IBM Corp. 2021, 2021
20
14
  *
21
15
  * This source code is licensed under the Apache-2.0 license found in the
22
16
  * LICENSE file in the root directory of this source tree.
23
17
  */
18
+
24
19
  // Import portions of React that are needed.
20
+
25
21
  // Other standard imports.
22
+
26
23
  // Carbon and package components we use.
27
- var componentName = 'ButtonMenuItem'; // NOTE: the component SCSS is not imported here: it is rolled up separately.
24
+
25
+ var componentName = 'ButtonMenuItem';
26
+
27
+ // NOTE: the component SCSS is not imported here: it is rolled up separately.
28
28
 
29
29
  /**
30
30
  * A menu item to include in a button menu component. This component has the
31
31
  * same props and behaviors as carbon OverflowMenuItem.
32
32
  */
33
-
34
33
  var ButtonMenuItem = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {
35
34
  return /*#__PURE__*/_react.default.createElement(_react2.OverflowMenuItem, (0, _extends2.default)({}, props, {
36
35
  ref: ref
37
36
  }));
38
- }); // Return a placeholder if not released and not enabled by feature flag
39
-
37
+ });
40
38
 
39
+ // Return a placeholder if not released and not enabled by feature flag
41
40
  exports.ButtonMenuItem = ButtonMenuItem;
42
41
  exports.ButtonMenuItem = ButtonMenuItem = _settings.pkg.checkComponentEnabled(ButtonMenuItem, componentName);
43
42
  ButtonMenuItem.propTypes = _react2.OverflowMenuItem.propTypes;
@@ -15,7 +15,5 @@ Object.defineProperty(exports, "ButtonMenuItem", {
15
15
  return _ButtonMenuItem.ButtonMenuItem;
16
16
  }
17
17
  });
18
-
19
18
  var _ButtonMenu = require("./ButtonMenu");
20
-
21
19
  var _ButtonMenuItem = require("./ButtonMenuItem");