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

Sign up to get free protection for your applications and to get access to all the features.
Files changed (685) hide show
  1. package/README.md +19 -17
  2. package/css/index-full-carbon.css +946 -325
  3. package/css/index-full-carbon.css.map +1 -1
  4. package/css/index-full-carbon.min.css +4 -6
  5. package/css/index-full-carbon.min.css.map +1 -1
  6. package/css/index-without-carbon-released-only.css +137 -147
  7. package/css/index-without-carbon-released-only.css.map +1 -1
  8. package/css/index-without-carbon-released-only.min.css +2 -4
  9. package/css/index-without-carbon-released-only.min.css.map +1 -1
  10. package/css/index-without-carbon.css +163 -163
  11. package/css/index-without-carbon.css.map +1 -1
  12. package/css/index-without-carbon.min.css +4 -6
  13. package/css/index-without-carbon.min.css.map +1 -1
  14. package/css/index.css +398 -207
  15. package/css/index.css.map +1 -1
  16. package/css/index.min.css +3 -5
  17. package/css/index.min.css.map +1 -1
  18. package/es/components/APIKeyModal/APIKeyDownloader.js +29 -41
  19. package/es/components/APIKeyModal/APIKeyModal.js +101 -185
  20. package/es/components/APIKeyModal/index.js +1 -0
  21. package/es/components/AboutModal/AboutModal.js +46 -59
  22. package/es/components/AboutModal/index.js +1 -0
  23. package/es/components/ActionBar/ActionBar.js +65 -68
  24. package/es/components/ActionBar/ActionBarItem.js +21 -22
  25. package/es/components/ActionBar/ActionBarOverflowItems.js +12 -12
  26. package/es/components/ActionBar/index.js +1 -0
  27. package/es/components/ActionSet/ActionSet.js +32 -42
  28. package/es/components/ActionSet/actions.js +1 -2
  29. package/es/components/ActionSet/index.js +1 -0
  30. package/es/components/AddSelect/AddSelect.js +3 -4
  31. package/es/components/AddSelect/AddSelectBody.js +75 -102
  32. package/es/components/AddSelect/AddSelectBreadcrumbs.js +3 -4
  33. package/es/components/AddSelect/AddSelectColumn.js +32 -50
  34. package/es/components/AddSelect/AddSelectFilter.js +22 -35
  35. package/es/components/AddSelect/AddSelectFormControl.js +7 -17
  36. package/es/components/AddSelect/AddSelectList.js +6 -7
  37. package/es/components/AddSelect/AddSelectMetaPanel.js +4 -5
  38. package/es/components/AddSelect/AddSelectRow.js +25 -39
  39. package/es/components/AddSelect/AddSelectSidebar.js +15 -22
  40. package/es/components/AddSelect/AddSelectSort.js +9 -8
  41. package/es/components/AddSelect/add-select-utils.js +2 -23
  42. package/es/components/AddSelect/hooks/useFocus.js +3 -7
  43. package/es/components/AddSelect/hooks/useItemSort.js +7 -8
  44. package/es/components/AddSelect/hooks/useParentSelect.js +4 -6
  45. package/es/components/AddSelect/hooks/usePath.js +7 -22
  46. package/es/components/AddSelect/index.js +1 -0
  47. package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +67 -90
  48. package/es/components/BreadcrumbWithOverflow/index.js +2 -0
  49. package/es/components/ButtonMenu/ButtonMenu.js +35 -34
  50. package/es/components/ButtonMenu/ButtonMenuItem.js +10 -6
  51. package/es/components/ButtonMenu/index.js +1 -0
  52. package/es/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +35 -53
  53. package/es/components/ButtonSetWithOverflow/index.js +1 -0
  54. package/es/components/Card/Card.js +55 -73
  55. package/es/components/Card/CardFooter.js +19 -18
  56. package/es/components/Card/CardHeader.js +13 -13
  57. package/es/components/Card/index.js +1 -0
  58. package/es/components/Cascade/Cascade.js +5 -14
  59. package/es/components/ComboButton/ComboButton.js +24 -35
  60. package/es/components/ComboButton/ComboButtonItem/index.js +4 -8
  61. package/es/components/ComboButton/index.js +1 -0
  62. package/es/components/CreateFullPage/CreateFullPage.js +65 -87
  63. package/es/components/CreateFullPage/CreateFullPageStep.js +28 -40
  64. package/es/components/CreateFullPage/index.js +1 -0
  65. package/es/components/CreateInfluencer/CreateInfluencer.js +14 -15
  66. package/es/components/CreateInfluencer/index.js +1 -0
  67. package/es/components/CreateModal/CreateModal.js +19 -31
  68. package/es/components/CreateModal/index.js +2 -0
  69. package/es/components/CreateSidePanel/CreateSidePanel.js +24 -37
  70. package/es/components/CreateSidePanel/index.js +1 -0
  71. package/es/components/CreateTearsheet/CreateTearsheet.js +66 -91
  72. package/es/components/CreateTearsheet/CreateTearsheetDivider.js +4 -4
  73. package/es/components/CreateTearsheet/CreateTearsheetStep.js +31 -42
  74. package/es/components/CreateTearsheet/index.js +1 -0
  75. package/es/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +47 -67
  76. package/es/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +41 -57
  77. package/es/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +30 -39
  78. package/es/components/CreateTearsheetNarrow/index.js +1 -0
  79. package/es/components/DataSpreadsheet/DataSpreadsheet.js +136 -224
  80. package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +62 -113
  81. package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +25 -56
  82. package/es/components/DataSpreadsheet/hooks/index.js +1 -0
  83. package/es/components/DataSpreadsheet/hooks/useMoveActiveCell.js +6 -5
  84. package/es/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +23 -44
  85. package/es/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +5 -5
  86. package/es/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +18 -30
  87. package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +10 -14
  88. package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +34 -54
  89. package/es/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +10 -10
  90. package/es/components/DataSpreadsheet/index.js +1 -0
  91. package/es/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +4 -8
  92. package/es/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +3 -4
  93. package/es/components/DataSpreadsheet/utils/createActiveCellFn.js +15 -19
  94. package/es/components/DataSpreadsheet/utils/createCellSelectionArea.js +15 -17
  95. package/es/components/DataSpreadsheet/utils/generateData.js +4 -13
  96. package/es/components/DataSpreadsheet/utils/getCellSize.js +1 -6
  97. package/es/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +1 -0
  98. package/es/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +7 -9
  99. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +20 -34
  100. package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +20 -30
  101. package/es/components/DataSpreadsheet/utils/handleCellDeletion.js +6 -8
  102. package/es/components/DataSpreadsheet/utils/handleEditSubmit.js +13 -20
  103. package/es/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +22 -44
  104. package/es/components/DataSpreadsheet/utils/handleMultipleKeys.js +40 -75
  105. package/es/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +6 -8
  106. package/es/components/DataSpreadsheet/utils/removeCellSelections.js +6 -8
  107. package/es/components/DataSpreadsheet/utils/selectAllCells.js +7 -11
  108. package/es/components/Datagrid/Datagrid/Datagrid.js +13 -13
  109. package/es/components/Datagrid/Datagrid/DatagridBody.js +4 -10
  110. package/es/components/Datagrid/Datagrid/DatagridContent.js +38 -51
  111. package/es/components/Datagrid/Datagrid/DatagridEmptyBody.js +10 -12
  112. package/es/components/Datagrid/Datagrid/DatagridExpandedRow.js +4 -6
  113. package/es/components/Datagrid/Datagrid/DatagridHead.js +6 -6
  114. package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +1 -7
  115. package/es/components/Datagrid/Datagrid/DatagridRefBody.js +5 -8
  116. package/es/components/Datagrid/Datagrid/DatagridRow.js +6 -22
  117. package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +13 -23
  118. package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +29 -41
  119. package/es/components/Datagrid/Datagrid/DatagridSimpleBody.js +2 -7
  120. package/es/components/Datagrid/Datagrid/DatagridToolbar.js +27 -40
  121. package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +14 -25
  122. package/es/components/Datagrid/Datagrid/DraggableElement.js +75 -86
  123. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +3 -4
  124. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +6 -10
  125. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +15 -25
  126. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +52 -69
  127. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +12 -15
  128. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +6 -12
  129. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +1 -1
  130. package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +1 -0
  131. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +61 -87
  132. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +73 -89
  133. package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +8 -16
  134. package/es/components/Datagrid/Datagrid/addons/Filtering/constants.js +4 -5
  135. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +1 -0
  136. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +39 -64
  137. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +3 -8
  138. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +8 -12
  139. package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +2 -4
  140. package/es/components/Datagrid/Datagrid/addons/Filtering/utils.js +8 -14
  141. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +11 -12
  142. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +57 -109
  143. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +7 -21
  144. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +1 -1
  145. package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +9 -14
  146. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +2 -3
  147. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +29 -63
  148. package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +14 -21
  149. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +8 -12
  150. package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +18 -27
  151. package/es/components/Datagrid/Datagrid/addons/RowSize/index.js +1 -0
  152. package/es/components/Datagrid/Datagrid/index.js +1 -0
  153. package/es/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +10 -0
  154. package/es/components/Datagrid/Datagrid.stories/common.js +2 -11
  155. package/es/components/Datagrid/common-column-ids.js +1 -0
  156. package/es/components/Datagrid/index.js +1 -0
  157. package/es/components/Datagrid/useActionsColumn.js +21 -39
  158. package/es/components/Datagrid/useColumnCenterAlign.js +0 -8
  159. package/es/components/Datagrid/useColumnOrder.js +1 -0
  160. package/es/components/Datagrid/useColumnRightAlign.js +0 -8
  161. package/es/components/Datagrid/useCustomizeColumns.js +5 -13
  162. package/es/components/Datagrid/useDatagrid.js +0 -7
  163. package/es/components/Datagrid/useDefaultStringRenderer.js +0 -9
  164. package/es/components/Datagrid/useDisableSelectRows.js +2 -10
  165. package/es/components/Datagrid/useEditableCell.js +1 -2
  166. package/es/components/Datagrid/useExpandedRow.js +5 -15
  167. package/es/components/Datagrid/useFiltering.js +9 -19
  168. package/es/components/Datagrid/useFlexResize.js +0 -7
  169. package/es/components/Datagrid/useFloatingScroll.js +9 -22
  170. package/es/components/Datagrid/useInfiniteScroll.js +7 -16
  171. package/es/components/Datagrid/useInlineEdit.js +2 -10
  172. package/es/components/Datagrid/useNestedRowExpander.js +0 -6
  173. package/es/components/Datagrid/useNestedRows.js +1 -10
  174. package/es/components/Datagrid/useOnRowClick.js +4 -11
  175. package/es/components/Datagrid/useParentDimensions.js +6 -16
  176. package/es/components/Datagrid/useResizeTable.js +1 -7
  177. package/es/components/Datagrid/useRowExpander.js +0 -5
  178. package/es/components/Datagrid/useRowIsMouseOver.js +6 -15
  179. package/es/components/Datagrid/useRowRenderer.js +0 -5
  180. package/es/components/Datagrid/useRowSize.js +8 -20
  181. package/es/components/Datagrid/useSelectAllToggle.js +14 -27
  182. package/es/components/Datagrid/useSelectRows.js +15 -34
  183. package/es/components/Datagrid/useSkeletonRows.js +1 -6
  184. package/es/components/Datagrid/useSortableColumns.js +3 -25
  185. package/es/components/Datagrid/useStickyColumn.js +5 -37
  186. package/es/components/Datagrid/utils/DatagridActions.js +19 -29
  187. package/es/components/Datagrid/utils/DatagridPagination.js +5 -6
  188. package/es/components/Datagrid/utils/Wrapper.js +1 -1
  189. package/es/components/Datagrid/utils/getArgTypes.js +1 -0
  190. package/es/components/Datagrid/utils/getAutoSizedColumnWidth.js +1 -3
  191. package/es/components/Datagrid/utils/getInlineEditColumns.js +1 -3
  192. package/es/components/Datagrid/utils/makeData.js +3 -18
  193. package/es/components/EditFullPage/EditFullPage.js +27 -20
  194. package/es/components/EditFullPage/index.js +1 -0
  195. package/es/components/EditInPlace/EditInPlace.js +33 -71
  196. package/es/components/EditInPlace/index.js +1 -0
  197. package/es/components/EditSidePanel/EditSidePanel.js +38 -51
  198. package/es/components/EditSidePanel/index.js +1 -0
  199. package/es/components/EditTearsheet/EditTearsheet.js +35 -45
  200. package/es/components/EditTearsheet/EditTearsheetForm.js +19 -25
  201. package/es/components/EditTearsheet/index.js +1 -0
  202. package/es/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +37 -49
  203. package/es/components/EditTearsheetNarrow/EditTearsheetNarrow.js +27 -20
  204. package/es/components/EditTearsheetNarrow/index.js +1 -0
  205. package/es/components/EditUpdateCards/EditUpdateCards.js +33 -35
  206. package/es/components/EditUpdateCards/index.js +1 -0
  207. package/es/components/EmptyStates/EmptyState.js +33 -36
  208. package/es/components/EmptyStates/EmptyStateContent.js +19 -18
  209. package/es/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +28 -26
  210. package/es/components/EmptyStates/ErrorEmptyState/index.js +1 -0
  211. package/es/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +28 -26
  212. package/es/components/EmptyStates/NoDataEmptyState/index.js +1 -0
  213. package/es/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +28 -26
  214. package/es/components/EmptyStates/NoTagsEmptyState/index.js +1 -0
  215. package/es/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +28 -26
  216. package/es/components/EmptyStates/NotFoundEmptyState/index.js +1 -0
  217. package/es/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +28 -26
  218. package/es/components/EmptyStates/NotificationsEmptyState/index.js +1 -0
  219. package/es/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +28 -26
  220. package/es/components/EmptyStates/UnauthorizedEmptyState/index.js +1 -0
  221. package/es/components/EmptyStates/assets/ErrorIllustration.js +7 -6
  222. package/es/components/EmptyStates/assets/NoDataIllustration.js +7 -6
  223. package/es/components/EmptyStates/assets/NoTagsIllustration.js +7 -6
  224. package/es/components/EmptyStates/assets/NotFoundIllustration.js +7 -6
  225. package/es/components/EmptyStates/assets/NotificationsIllustration.js +7 -6
  226. package/es/components/EmptyStates/assets/UnauthorizedIllustration.js +7 -6
  227. package/es/components/EmptyStates/index.js +1 -0
  228. package/es/components/ExampleComponent/ExampleComponent.js +44 -57
  229. package/es/components/ExampleComponent/ExampleDeprecatedComponent.js +7 -3
  230. package/es/components/ExampleComponent/index.js +1 -0
  231. package/es/components/ExampleComponent/useExample.js +12 -14
  232. package/es/components/ExportModal/ExportModal.js +41 -80
  233. package/es/components/ExportModal/index.js +1 -0
  234. package/es/components/ExpressiveCard/ExpressiveCard.js +3 -20
  235. package/es/components/ExpressiveCard/index.js +1 -0
  236. package/es/components/FilterSummary/FilterSummary.js +8 -8
  237. package/es/components/HTTPErrors/HTTPError403/HTTPError403.js +16 -18
  238. package/es/components/HTTPErrors/HTTPError403/index.js +1 -0
  239. package/es/components/HTTPErrors/HTTPError404/HTTPError404.js +16 -18
  240. package/es/components/HTTPErrors/HTTPError404/index.js +1 -0
  241. package/es/components/HTTPErrors/HTTPErrorContent.js +15 -18
  242. package/es/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +16 -18
  243. package/es/components/HTTPErrors/HTTPErrorOther/index.js +1 -0
  244. package/es/components/HTTPErrors/assets/HTTPErrorSvg403.js +6 -3
  245. package/es/components/HTTPErrors/assets/HTTPErrorSvg404.js +6 -3
  246. package/es/components/HTTPErrors/assets/HTTPErrorSvgOther.js +6 -3
  247. package/es/components/HTTPErrors/index.js +1 -0
  248. package/es/components/ImportModal/ImportModal.js +82 -137
  249. package/es/components/ImportModal/index.js +1 -0
  250. package/es/components/MultiAddSelect/MultiAddSelect.js +1 -23
  251. package/es/components/MultiAddSelect/index.js +1 -0
  252. package/es/components/NotificationsPanel/NotificationsPanel.js +85 -126
  253. package/es/components/NotificationsPanel/NotificationsPanel_data.js +1 -0
  254. package/es/components/NotificationsPanel/index.js +1 -0
  255. package/es/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +1 -2
  256. package/es/components/NotificationsPanel/utils.js +13 -19
  257. package/es/components/OptionsTile/OptionsTile.js +60 -89
  258. package/es/components/OptionsTile/index.js +1 -0
  259. package/es/components/PageHeader/PageHeader.js +119 -187
  260. package/es/components/PageHeader/PageHeaderDemo.data.js +0 -1
  261. package/es/components/PageHeader/PageHeaderTitle.js +18 -23
  262. package/es/components/PageHeader/PageHeaderUtils.js +18 -45
  263. package/es/components/PageHeader/index.js +1 -0
  264. package/es/components/ProductiveCard/ProductiveCard.js +7 -24
  265. package/es/components/ProductiveCard/index.js +1 -0
  266. package/es/components/RemoveModal/RemoveModal.js +26 -49
  267. package/es/components/RemoveModal/index.js +1 -0
  268. package/es/components/Saving/Saving.js +15 -30
  269. package/es/components/Saving/index.js +1 -0
  270. package/es/components/SidePanel/SidePanel.js +105 -151
  271. package/es/components/SidePanel/constants.js +1 -0
  272. package/es/components/SidePanel/index.js +1 -0
  273. package/es/components/SidePanel/motion/variants.js +1 -0
  274. package/es/components/SingleAddSelect/SingleAddSelect.js +1 -14
  275. package/es/components/SingleAddSelect/index.js +1 -0
  276. package/es/components/StatusIcon/StatusIcon.js +5 -12
  277. package/es/components/StatusIcon/index.js +1 -0
  278. package/es/components/TagSet/TagSet.js +57 -90
  279. package/es/components/TagSet/TagSetModal.js +19 -30
  280. package/es/components/TagSet/TagSetOverflow.js +14 -23
  281. package/es/components/TagSet/constants.js +1 -0
  282. package/es/components/TagSet/index.js +1 -0
  283. package/es/components/Tearsheet/Tearsheet.js +26 -35
  284. package/es/components/Tearsheet/TearsheetNarrow.js +22 -26
  285. package/es/components/Tearsheet/TearsheetShell.js +80 -91
  286. package/es/components/Tearsheet/index.js +1 -0
  287. package/es/components/Toolbar/Toolbar.js +13 -27
  288. package/es/components/Toolbar/ToolbarButton.js +8 -14
  289. package/es/components/Toolbar/ToolbarGroup.js +4 -6
  290. package/es/components/Toolbar/index.js +1 -0
  291. package/es/components/UserProfileImage/UserProfileImage.js +26 -40
  292. package/es/components/UserProfileImage/index.js +2 -0
  293. package/es/components/WebTerminal/WebTerminal.js +44 -54
  294. package/es/components/WebTerminal/WebTerminalContentWrapper.js +14 -11
  295. package/es/components/WebTerminal/hooks/index.js +8 -7
  296. package/es/components/WebTerminal/index.js +1 -0
  297. package/es/components/WebTerminal/preview-components/Navigation.js +2 -4
  298. package/es/components/WebTerminal/preview-components/documentationLinks.js +1 -0
  299. package/es/components/_Canary/Canary.js +13 -13
  300. package/es/components/_Canary/index.js +1 -0
  301. package/es/components/index.js +1 -0
  302. package/es/global/js/hooks/index.js +1 -0
  303. package/es/global/js/hooks/useActiveElement.js +4 -6
  304. package/es/global/js/hooks/useClickOutside.js +1 -1
  305. package/es/global/js/hooks/useControllableState.js +14 -23
  306. package/es/global/js/hooks/useCreateComponentFocus.js +16 -22
  307. package/es/global/js/hooks/useCreateComponentStepChange.js +94 -131
  308. package/es/global/js/hooks/usePreviousValue.js +2 -1
  309. package/es/global/js/hooks/useResetCreateComponent.js +11 -10
  310. package/es/global/js/hooks/useResizeObserver.js +14 -19
  311. package/es/global/js/hooks/useRetrieveStepData.js +7 -10
  312. package/es/global/js/hooks/useValidCreateStepCount.js +2 -1
  313. package/es/global/js/hooks/useWindowResize.js +8 -16
  314. package/es/global/js/hooks/useWindowScroll.js +4 -15
  315. package/es/global/js/package-settings.js +5 -14
  316. package/es/global/js/utils/ClickListener.js +5 -10
  317. package/es/global/js/utils/DisplayBox.js +3 -2
  318. package/es/global/js/utils/Wrap.js +14 -17
  319. package/es/global/js/utils/deepCloneObject.js +5 -8
  320. package/es/global/js/utils/devtools.js +1 -4
  321. package/es/global/js/utils/getBezierValues.js +1 -2
  322. package/es/global/js/utils/getFocusableElements.js +1 -1
  323. package/es/global/js/utils/getNumberOfHiddenSteps.js +1 -1
  324. package/es/global/js/utils/getScrollbarWidth.js +1 -0
  325. package/es/global/js/utils/keyboardNavigation.js +7 -5
  326. package/es/global/js/utils/lastIndexInArray.js +0 -2
  327. package/es/global/js/utils/motionConstants.js +2 -3
  328. package/es/global/js/utils/pconsole.js +1 -3
  329. package/es/global/js/utils/props-helper.js +19 -35
  330. package/es/global/js/utils/rangeWithCallback.js +1 -0
  331. package/es/global/js/utils/scrollableAncestor.js +6 -9
  332. package/es/global/js/utils/story-helper.js +31 -11
  333. package/es/global/js/utils/test-helper.js +39 -59
  334. package/es/global/js/utils/unwrap-if-fragment.js +9 -17
  335. package/es/global/js/utils/uuidv4.js +1 -2
  336. package/es/global/js/utils/uuidv4.spec.js +1 -1
  337. package/es/global/js/utils/wait.js +1 -1
  338. package/es/global/js/utils/wrapFocus.js +8 -14
  339. package/es/index.js +1 -0
  340. package/es/settings.js +22 -23
  341. package/lib/components/APIKeyModal/APIKeyDownloader.js +29 -54
  342. package/lib/components/APIKeyModal/APIKeyModal.js +106 -207
  343. package/lib/components/APIKeyModal/index.js +0 -1
  344. package/lib/components/AboutModal/AboutModal.js +48 -74
  345. package/lib/components/AboutModal/index.js +0 -1
  346. package/lib/components/ActionBar/ActionBar.js +66 -83
  347. package/lib/components/ActionBar/ActionBarItem.js +23 -29
  348. package/lib/components/ActionBar/ActionBarOverflowItems.js +10 -22
  349. package/lib/components/ActionBar/index.js +0 -2
  350. package/lib/components/ActionSet/ActionSet.js +37 -52
  351. package/lib/components/ActionSet/actions.js +1 -5
  352. package/lib/components/ActionSet/index.js +0 -1
  353. package/lib/components/AddSelect/AddSelect.js +8 -17
  354. package/lib/components/AddSelect/AddSelectBody.js +80 -129
  355. package/lib/components/AddSelect/AddSelectBreadcrumbs.js +3 -14
  356. package/lib/components/AddSelect/AddSelectColumn.js +37 -72
  357. package/lib/components/AddSelect/AddSelectFilter.js +27 -51
  358. package/lib/components/AddSelect/AddSelectFormControl.js +7 -27
  359. package/lib/components/AddSelect/AddSelectList.js +11 -22
  360. package/lib/components/AddSelect/AddSelectMetaPanel.js +4 -18
  361. package/lib/components/AddSelect/AddSelectRow.js +25 -55
  362. package/lib/components/AddSelect/AddSelectSidebar.js +20 -33
  363. package/lib/components/AddSelect/AddSelectSort.js +9 -19
  364. package/lib/components/AddSelect/add-select-utils.js +2 -33
  365. package/lib/components/AddSelect/hooks/useFocus.js +3 -10
  366. package/lib/components/AddSelect/hooks/useItemSort.js +7 -13
  367. package/lib/components/AddSelect/hooks/useParentSelect.js +4 -9
  368. package/lib/components/AddSelect/hooks/usePath.js +12 -24
  369. package/lib/components/AddSelect/index.js +0 -1
  370. package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +68 -103
  371. package/lib/components/BreadcrumbWithOverflow/index.js +0 -1
  372. package/lib/components/ButtonMenu/ButtonMenu.js +36 -38
  373. package/lib/components/ButtonMenu/ButtonMenuItem.js +9 -10
  374. package/lib/components/ButtonMenu/index.js +0 -2
  375. package/lib/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +39 -72
  376. package/lib/components/ButtonSetWithOverflow/index.js +0 -1
  377. package/lib/components/Card/Card.js +58 -85
  378. package/lib/components/Card/CardFooter.js +19 -28
  379. package/lib/components/Card/CardHeader.js +13 -23
  380. package/lib/components/Card/index.js +0 -3
  381. package/lib/components/Cascade/Cascade.js +10 -31
  382. package/lib/components/Cascade/index.js +0 -1
  383. package/lib/components/ComboButton/ComboButton.js +29 -49
  384. package/lib/components/ComboButton/ComboButtonItem/index.js +2 -10
  385. package/lib/components/ComboButton/index.js +0 -2
  386. package/lib/components/CreateFullPage/CreateFullPage.js +69 -105
  387. package/lib/components/CreateFullPage/CreateFullPageStep.js +33 -56
  388. package/lib/components/CreateFullPage/index.js +0 -2
  389. package/lib/components/CreateInfluencer/CreateInfluencer.js +13 -24
  390. package/lib/components/CreateInfluencer/index.js +0 -1
  391. package/lib/components/CreateModal/CreateModal.js +24 -39
  392. package/lib/components/CreateModal/index.js +0 -1
  393. package/lib/components/CreateSidePanel/CreateSidePanel.js +26 -46
  394. package/lib/components/CreateSidePanel/index.js +0 -1
  395. package/lib/components/CreateTearsheet/CreateTearsheet.js +71 -111
  396. package/lib/components/CreateTearsheet/CreateTearsheetDivider.js +9 -14
  397. package/lib/components/CreateTearsheet/CreateTearsheetStep.js +36 -58
  398. package/lib/components/CreateTearsheet/index.js +0 -3
  399. package/lib/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +53 -80
  400. package/lib/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +41 -71
  401. package/lib/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +33 -47
  402. package/lib/components/CreateTearsheetNarrow/index.js +0 -1
  403. package/lib/components/DataSpreadsheet/DataSpreadsheet.js +138 -254
  404. package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +67 -136
  405. package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +30 -76
  406. package/lib/components/DataSpreadsheet/hooks/index.js +0 -7
  407. package/lib/components/DataSpreadsheet/hooks/useMoveActiveCell.js +4 -7
  408. package/lib/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +23 -48
  409. package/lib/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +5 -9
  410. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +18 -37
  411. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +7 -18
  412. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +39 -62
  413. package/lib/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +8 -14
  414. package/lib/components/DataSpreadsheet/index.js +0 -1
  415. package/lib/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +1 -9
  416. package/lib/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +3 -7
  417. package/lib/components/DataSpreadsheet/utils/createActiveCellFn.js +15 -23
  418. package/lib/components/DataSpreadsheet/utils/createCellSelectionArea.js +15 -22
  419. package/lib/components/DataSpreadsheet/utils/generateData.js +4 -16
  420. package/lib/components/DataSpreadsheet/utils/getCellSize.js +1 -8
  421. package/lib/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +1 -2
  422. package/lib/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +7 -12
  423. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +25 -39
  424. package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +20 -33
  425. package/lib/components/DataSpreadsheet/utils/handleCellDeletion.js +6 -12
  426. package/lib/components/DataSpreadsheet/utils/handleEditSubmit.js +16 -25
  427. package/lib/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +22 -50
  428. package/lib/components/DataSpreadsheet/utils/handleMultipleKeys.js +45 -85
  429. package/lib/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +6 -12
  430. package/lib/components/DataSpreadsheet/utils/removeCellSelections.js +4 -10
  431. package/lib/components/DataSpreadsheet/utils/selectAllCells.js +12 -17
  432. package/lib/components/Datagrid/Datagrid/Datagrid.js +18 -28
  433. package/lib/components/Datagrid/Datagrid/DatagridBody.js +5 -16
  434. package/lib/components/Datagrid/Datagrid/DatagridContent.js +38 -76
  435. package/lib/components/Datagrid/Datagrid/DatagridEmptyBody.js +10 -18
  436. package/lib/components/Datagrid/Datagrid/DatagridExpandedRow.js +4 -10
  437. package/lib/components/Datagrid/Datagrid/DatagridHead.js +6 -9
  438. package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +2 -15
  439. package/lib/components/Datagrid/Datagrid/DatagridRefBody.js +12 -15
  440. package/lib/components/Datagrid/Datagrid/DatagridRow.js +14 -31
  441. package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +21 -36
  442. package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +33 -55
  443. package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.js +9 -15
  444. package/lib/components/Datagrid/Datagrid/DatagridToolbar.js +27 -53
  445. package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +21 -39
  446. package/lib/components/Datagrid/Datagrid/DraggableElement.js +76 -99
  447. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +3 -13
  448. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +11 -21
  449. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +15 -38
  450. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +57 -83
  451. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +12 -27
  452. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +10 -19
  453. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +1 -5
  454. package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +0 -3
  455. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +61 -104
  456. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +73 -109
  457. package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +9 -25
  458. package/lib/components/Datagrid/Datagrid/addons/Filtering/constants.js +4 -6
  459. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +0 -5
  460. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +46 -76
  461. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useInitialStateFromFilters.js +4 -12
  462. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +6 -15
  463. package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +1 -6
  464. package/lib/components/Datagrid/Datagrid/addons/Filtering/index.js +0 -4
  465. package/lib/components/Datagrid/Datagrid/addons/Filtering/motion/variants.js +0 -3
  466. package/lib/components/Datagrid/Datagrid/addons/Filtering/utils.js +8 -16
  467. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +11 -20
  468. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/index.js +0 -1
  469. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +62 -130
  470. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/index.js +0 -1
  471. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +12 -33
  472. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +1 -3
  473. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/index.js +0 -1
  474. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +14 -19
  475. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +2 -5
  476. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +34 -71
  477. package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +14 -27
  478. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +13 -27
  479. package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +18 -38
  480. package/lib/components/Datagrid/Datagrid/addons/RowSize/index.js +0 -2
  481. package/lib/components/Datagrid/Datagrid/index.js +0 -1
  482. package/lib/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +10 -0
  483. package/lib/components/Datagrid/Datagrid.stories/common.js +2 -17
  484. package/lib/components/Datagrid/Datagrid.stories/index.js +0 -5
  485. package/lib/components/Datagrid/common-column-ids.js +1 -1
  486. package/lib/components/Datagrid/index.js +0 -22
  487. package/lib/components/Datagrid/useActionsColumn.js +28 -46
  488. package/lib/components/Datagrid/useColumnCenterAlign.js +7 -15
  489. package/lib/components/Datagrid/useColumnOrder.js +0 -2
  490. package/lib/components/Datagrid/useColumnRightAlign.js +7 -15
  491. package/lib/components/Datagrid/useCustomizeColumns.js +12 -21
  492. package/lib/components/Datagrid/useDatagrid.js +7 -21
  493. package/lib/components/Datagrid/useDefaultStringRenderer.js +7 -16
  494. package/lib/components/Datagrid/useDisableSelectRows.js +2 -11
  495. package/lib/components/Datagrid/useEditableCell.js +1 -4
  496. package/lib/components/Datagrid/useExpandedRow.js +12 -21
  497. package/lib/components/Datagrid/useFiltering.js +16 -25
  498. package/lib/components/Datagrid/useFlexResize.js +0 -9
  499. package/lib/components/Datagrid/useFloatingScroll.js +10 -27
  500. package/lib/components/Datagrid/useInfiniteScroll.js +8 -22
  501. package/lib/components/Datagrid/useInlineEdit.js +2 -19
  502. package/lib/components/Datagrid/useNestedRowExpander.js +1 -14
  503. package/lib/components/Datagrid/useNestedRows.js +2 -15
  504. package/lib/components/Datagrid/useOnRowClick.js +4 -12
  505. package/lib/components/Datagrid/useParentDimensions.js +7 -18
  506. package/lib/components/Datagrid/useResizeTable.js +2 -8
  507. package/lib/components/Datagrid/useRowExpander.js +1 -12
  508. package/lib/components/Datagrid/useRowIsMouseOver.js +12 -20
  509. package/lib/components/Datagrid/useRowRenderer.js +1 -7
  510. package/lib/components/Datagrid/useRowSize.js +14 -25
  511. package/lib/components/Datagrid/useSelectAllToggle.js +15 -38
  512. package/lib/components/Datagrid/useSelectRows.js +22 -51
  513. package/lib/components/Datagrid/useSkeletonRows.js +1 -8
  514. package/lib/components/Datagrid/useSortableColumns.js +8 -35
  515. package/lib/components/Datagrid/useStickyColumn.js +11 -45
  516. package/lib/components/Datagrid/utils/DatagridActions.js +19 -44
  517. package/lib/components/Datagrid/utils/DatagridPagination.js +5 -11
  518. package/lib/components/Datagrid/utils/Wrapper.js +1 -5
  519. package/lib/components/Datagrid/utils/getArgTypes.js +1 -1
  520. package/lib/components/Datagrid/utils/getAutoSizedColumnWidth.js +1 -6
  521. package/lib/components/Datagrid/utils/getInlineEditColumns.js +1 -9
  522. package/lib/components/Datagrid/utils/makeData.js +8 -28
  523. package/lib/components/EditFullPage/EditFullPage.js +30 -26
  524. package/lib/components/EditFullPage/index.js +0 -1
  525. package/lib/components/EditInPlace/EditInPlace.js +36 -89
  526. package/lib/components/EditInPlace/index.js +0 -1
  527. package/lib/components/EditSidePanel/EditSidePanel.js +40 -59
  528. package/lib/components/EditSidePanel/index.js +0 -1
  529. package/lib/components/EditTearsheet/EditTearsheet.js +39 -61
  530. package/lib/components/EditTearsheet/EditTearsheetForm.js +24 -39
  531. package/lib/components/EditTearsheet/index.js +0 -2
  532. package/lib/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +37 -62
  533. package/lib/components/EditTearsheetNarrow/EditTearsheetNarrow.js +30 -26
  534. package/lib/components/EditTearsheetNarrow/index.js +0 -1
  535. package/lib/components/EditUpdateCards/EditUpdateCards.js +35 -41
  536. package/lib/components/EditUpdateCards/index.js +0 -1
  537. package/lib/components/EmptyStates/EmptyState.js +36 -49
  538. package/lib/components/EmptyStates/EmptyStateContent.js +21 -27
  539. package/lib/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +31 -39
  540. package/lib/components/EmptyStates/ErrorEmptyState/index.js +0 -1
  541. package/lib/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +31 -39
  542. package/lib/components/EmptyStates/NoDataEmptyState/index.js +0 -1
  543. package/lib/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +31 -39
  544. package/lib/components/EmptyStates/NoTagsEmptyState/index.js +0 -1
  545. package/lib/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +31 -39
  546. package/lib/components/EmptyStates/NotFoundEmptyState/index.js +0 -1
  547. package/lib/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +31 -39
  548. package/lib/components/EmptyStates/NotificationsEmptyState/index.js +0 -1
  549. package/lib/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +31 -39
  550. package/lib/components/EmptyStates/UnauthorizedEmptyState/index.js +0 -1
  551. package/lib/components/EmptyStates/assets/ErrorIllustration.js +10 -13
  552. package/lib/components/EmptyStates/assets/NoDataIllustration.js +10 -13
  553. package/lib/components/EmptyStates/assets/NoTagsIllustration.js +10 -13
  554. package/lib/components/EmptyStates/assets/NotFoundIllustration.js +10 -13
  555. package/lib/components/EmptyStates/assets/NotificationsIllustration.js +10 -13
  556. package/lib/components/EmptyStates/assets/UnauthorizedIllustration.js +10 -13
  557. package/lib/components/EmptyStates/index.js +0 -7
  558. package/lib/components/ExampleComponent/ExampleComponent.js +46 -69
  559. package/lib/components/ExampleComponent/ExampleDeprecatedComponent.js +7 -9
  560. package/lib/components/ExampleComponent/index.js +0 -1
  561. package/lib/components/ExampleComponent/useExample.js +13 -18
  562. package/lib/components/ExportModal/ExportModal.js +46 -96
  563. package/lib/components/ExportModal/index.js +0 -1
  564. package/lib/components/ExpressiveCard/ExpressiveCard.js +3 -32
  565. package/lib/components/ExpressiveCard/index.js +0 -1
  566. package/lib/components/FilterSummary/FilterSummary.js +9 -18
  567. package/lib/components/FilterSummary/index.js +0 -2
  568. package/lib/components/HTTPErrors/HTTPError403/HTTPError403.js +19 -27
  569. package/lib/components/HTTPErrors/HTTPError403/index.js +0 -1
  570. package/lib/components/HTTPErrors/HTTPError404/HTTPError404.js +19 -27
  571. package/lib/components/HTTPErrors/HTTPError404/index.js +0 -1
  572. package/lib/components/HTTPErrors/HTTPErrorContent.js +17 -24
  573. package/lib/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +19 -27
  574. package/lib/components/HTTPErrors/HTTPErrorOther/index.js +0 -1
  575. package/lib/components/HTTPErrors/assets/HTTPErrorSvg403.js +6 -7
  576. package/lib/components/HTTPErrors/assets/HTTPErrorSvg404.js +6 -7
  577. package/lib/components/HTTPErrors/assets/HTTPErrorSvgOther.js +6 -7
  578. package/lib/components/HTTPErrors/index.js +0 -3
  579. package/lib/components/ImportModal/ImportModal.js +87 -155
  580. package/lib/components/ImportModal/index.js +0 -1
  581. package/lib/components/MultiAddSelect/MultiAddSelect.js +1 -34
  582. package/lib/components/MultiAddSelect/index.js +0 -1
  583. package/lib/components/NotificationsPanel/NotificationsPanel.js +87 -143
  584. package/lib/components/NotificationsPanel/NotificationsPanel_data.js +1 -4
  585. package/lib/components/NotificationsPanel/index.js +0 -1
  586. package/lib/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +1 -4
  587. package/lib/components/NotificationsPanel/utils.js +13 -21
  588. package/lib/components/OptionsTile/OptionsTile.js +62 -106
  589. package/lib/components/OptionsTile/index.js +0 -1
  590. package/lib/components/PageHeader/PageHeader.js +122 -214
  591. package/lib/components/PageHeader/PageHeaderDemo.data.js +0 -3
  592. package/lib/components/PageHeader/PageHeaderTitle.js +17 -35
  593. package/lib/components/PageHeader/PageHeaderUtils.js +23 -59
  594. package/lib/components/PageHeader/index.js +0 -1
  595. package/lib/components/ProductiveCard/ProductiveCard.js +12 -38
  596. package/lib/components/ProductiveCard/index.js +0 -1
  597. package/lib/components/RemoveModal/RemoveModal.js +31 -66
  598. package/lib/components/RemoveModal/index.js +0 -1
  599. package/lib/components/Saving/Saving.js +20 -44
  600. package/lib/components/Saving/index.js +0 -1
  601. package/lib/components/SidePanel/SidePanel.js +109 -174
  602. package/lib/components/SidePanel/constants.js +1 -1
  603. package/lib/components/SidePanel/index.js +0 -1
  604. package/lib/components/SidePanel/motion/variants.js +1 -2
  605. package/lib/components/SingleAddSelect/SingleAddSelect.js +1 -26
  606. package/lib/components/SingleAddSelect/index.js +0 -1
  607. package/lib/components/StatusIcon/StatusIcon.js +11 -25
  608. package/lib/components/StatusIcon/index.js +0 -1
  609. package/lib/components/TagSet/TagSet.js +61 -110
  610. package/lib/components/TagSet/TagSetModal.js +23 -46
  611. package/lib/components/TagSet/TagSetOverflow.js +19 -42
  612. package/lib/components/TagSet/constants.js +1 -0
  613. package/lib/components/TagSet/index.js +0 -1
  614. package/lib/components/Tearsheet/Tearsheet.js +29 -44
  615. package/lib/components/Tearsheet/TearsheetNarrow.js +25 -35
  616. package/lib/components/Tearsheet/TearsheetShell.js +82 -113
  617. package/lib/components/Tearsheet/index.js +0 -2
  618. package/lib/components/Toolbar/Toolbar.js +18 -41
  619. package/lib/components/Toolbar/ToolbarButton.js +13 -27
  620. package/lib/components/Toolbar/ToolbarGroup.js +8 -16
  621. package/lib/components/Toolbar/index.js +0 -3
  622. package/lib/components/UserProfileImage/UserProfileImage.js +28 -48
  623. package/lib/components/UserProfileImage/index.js +0 -1
  624. package/lib/components/WebTerminal/WebTerminal.js +46 -70
  625. package/lib/components/WebTerminal/WebTerminalContentWrapper.js +17 -20
  626. package/lib/components/WebTerminal/hooks/index.js +8 -19
  627. package/lib/components/WebTerminal/index.js +0 -3
  628. package/lib/components/WebTerminal/preview-components/Navigation.js +2 -9
  629. package/lib/components/WebTerminal/preview-components/documentationLinks.js +1 -0
  630. package/lib/components/WebTerminal/preview-components/index.js +0 -2
  631. package/lib/components/_Canary/Canary.js +14 -17
  632. package/lib/components/_Canary/index.js +0 -1
  633. package/lib/components/index.js +0 -37
  634. package/lib/global/js/hooks/index.js +0 -11
  635. package/lib/global/js/hooks/useActiveElement.js +4 -10
  636. package/lib/global/js/hooks/useClickOutside.js +1 -4
  637. package/lib/global/js/hooks/useControllableState.js +12 -26
  638. package/lib/global/js/hooks/useCreateComponentFocus.js +14 -27
  639. package/lib/global/js/hooks/useCreateComponentStepChange.js +94 -136
  640. package/lib/global/js/hooks/usePreviousValue.js +0 -3
  641. package/lib/global/js/hooks/useResetCreateComponent.js +9 -13
  642. package/lib/global/js/hooks/useResizeObserver.js +15 -23
  643. package/lib/global/js/hooks/useRetrieveStepData.js +5 -12
  644. package/lib/global/js/hooks/useValidCreateStepCount.js +0 -3
  645. package/lib/global/js/hooks/useWindowResize.js +14 -22
  646. package/lib/global/js/hooks/useWindowScroll.js +5 -20
  647. package/lib/global/js/package-settings.js +10 -18
  648. package/lib/global/js/utils/ClickListener.js +3 -16
  649. package/lib/global/js/utils/DisplayBox.js +3 -9
  650. package/lib/global/js/utils/Wrap.js +16 -22
  651. package/lib/global/js/utils/deepCloneObject.js +5 -11
  652. package/lib/global/js/utils/devtools.js +1 -6
  653. package/lib/global/js/utils/getBezierValues.js +1 -5
  654. package/lib/global/js/utils/getFocusableElements.js +1 -4
  655. package/lib/global/js/utils/getNumberOfHiddenSteps.js +1 -3
  656. package/lib/global/js/utils/getScrollbarWidth.js +1 -2
  657. package/lib/global/js/utils/keyboardNavigation.js +7 -6
  658. package/lib/global/js/utils/lastIndexInArray.js +0 -4
  659. package/lib/global/js/utils/motionConstants.js +1 -5
  660. package/lib/global/js/utils/pconsole.js +1 -7
  661. package/lib/global/js/utils/props-helper.js +21 -58
  662. package/lib/global/js/utils/rangeWithCallback.js +1 -2
  663. package/lib/global/js/utils/scrollableAncestor.js +6 -13
  664. package/lib/global/js/utils/story-helper.js +31 -26
  665. package/lib/global/js/utils/test-helper.js +39 -87
  666. package/lib/global/js/utils/unwrap-if-fragment.js +8 -20
  667. package/lib/global/js/utils/uuidv4.js +1 -3
  668. package/lib/global/js/utils/uuidv4.spec.js +1 -3
  669. package/lib/global/js/utils/wait.js +1 -2
  670. package/lib/global/js/utils/wrapFocus.js +6 -16
  671. package/lib/index.js +0 -3
  672. package/lib/settings.js +22 -33
  673. package/package.json +25 -24
  674. package/scss/components/AboutModal/_about-modal.scss +3 -18
  675. package/scss/components/AboutModal/_storybook-styles.scss +10 -3
  676. package/scss/components/ActionSet/_action-set.scss +15 -5
  677. package/scss/components/AddSelect/_add-select.scss +21 -30
  678. package/scss/components/Datagrid/_storybook-styles.scss +1 -1
  679. package/scss/components/Datagrid/styles/_datagrid.scss +6 -6
  680. package/scss/components/Datagrid/styles/_useInlineEdit.scss +12 -4
  681. package/scss/components/EditTearsheet/_edit-tearsheet.scss +6 -4
  682. package/scss/components/EmptyStates/_empty-state.scss +20 -0
  683. package/scss/components/PageHeader/_page-header.scss +6 -2
  684. package/scss/components/SidePanel/_side-panel.scss +1 -4
  685. package/scss/components/TagSet/_tag-set.scss +1 -1
@@ -1,17 +1,15 @@
1
1
  import _extends from "@babel/runtime/helpers/extends";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
3
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
-
5
4
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
6
-
7
5
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
8
-
9
6
  /**
10
7
  * Copyright IBM Corp. 2022, 2022
11
8
  *
12
9
  * This source code is licensed under the Apache-2.0 license found in the
13
10
  * LICENSE file in the root directory of this source tree.
14
11
  */
12
+
15
13
  import React, { forwardRef, useEffect, useState } from 'react';
16
14
  import PropTypes from 'prop-types';
17
15
  import cx from 'classnames';
@@ -27,49 +25,44 @@ import { useSpreadsheetMouseMove } from './hooks';
27
25
  var blockClass = "".concat(pkg.prefix, "--data-spreadsheet");
28
26
  export var DataSpreadsheetHeader = /*#__PURE__*/forwardRef(function (_ref, ref) {
29
27
  var activeCellCoordinates = _ref.activeCellCoordinates,
30
- cellSize = _ref.cellSize,
31
- columns = _ref.columns,
32
- currentMatcher = _ref.currentMatcher,
33
- defaultColumn = _ref.defaultColumn,
34
- headerGroups = _ref.headerGroups,
35
- scrollBarSize = _ref.scrollBarSize,
36
- selectionAreas = _ref.selectionAreas,
37
- setActiveCellCoordinates = _ref.setActiveCellCoordinates,
38
- setCurrentMatcher = _ref.setCurrentMatcher,
39
- setSelectionAreas = _ref.setSelectionAreas,
40
- setSelectionAreaData = _ref.setSelectionAreaData,
41
- rows = _ref.rows,
42
- totalVisibleColumns = _ref.totalVisibleColumns,
43
- updateActiveCellCoordinates = _ref.updateActiveCellCoordinates,
44
- setHeaderCellHoldActive = _ref.setHeaderCellHoldActive,
45
- headerCellHoldActive = _ref.headerCellHoldActive,
46
- selectAllAriaLabel = _ref.selectAllAriaLabel,
47
- visibleColumns = _ref.visibleColumns;
48
-
28
+ cellSize = _ref.cellSize,
29
+ columns = _ref.columns,
30
+ currentMatcher = _ref.currentMatcher,
31
+ defaultColumn = _ref.defaultColumn,
32
+ headerGroups = _ref.headerGroups,
33
+ scrollBarSize = _ref.scrollBarSize,
34
+ selectionAreas = _ref.selectionAreas,
35
+ setActiveCellCoordinates = _ref.setActiveCellCoordinates,
36
+ setCurrentMatcher = _ref.setCurrentMatcher,
37
+ setSelectionAreas = _ref.setSelectionAreas,
38
+ setSelectionAreaData = _ref.setSelectionAreaData,
39
+ rows = _ref.rows,
40
+ totalVisibleColumns = _ref.totalVisibleColumns,
41
+ updateActiveCellCoordinates = _ref.updateActiveCellCoordinates,
42
+ setHeaderCellHoldActive = _ref.setHeaderCellHoldActive,
43
+ headerCellHoldActive = _ref.headerCellHoldActive,
44
+ selectAllAriaLabel = _ref.selectAllAriaLabel,
45
+ visibleColumns = _ref.visibleColumns;
49
46
  var _useState = useState(0),
50
- _useState2 = _slicedToArray(_useState, 2),
51
- scrollBarSizeValue = _useState2[0],
52
- setScrollBarSizeValue = _useState2[1];
53
-
47
+ _useState2 = _slicedToArray(_useState, 2),
48
+ scrollBarSizeValue = _useState2[0],
49
+ setScrollBarSizeValue = _useState2[1];
54
50
  var _useState3 = useState(false),
55
- _useState4 = _slicedToArray(_useState3, 2),
56
- selectedHeaderReorderActive = _useState4[0],
57
- setSelectedHeaderReorderActive = _useState4[1];
58
-
51
+ _useState4 = _slicedToArray(_useState3, 2),
52
+ selectedHeaderReorderActive = _useState4[0],
53
+ setSelectedHeaderReorderActive = _useState4[1];
59
54
  var previousState = usePreviousValue({
60
55
  cellSize: cellSize
61
56
  });
62
57
  useEffect(function () {
63
58
  if ((previousState === null || previousState === void 0 ? void 0 : previousState.cellSize) !== cellSize) {
64
59
  var _ref$current;
65
-
66
60
  var scrollContainer = ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.querySelector(".".concat(blockClass, "__list--container"));
67
61
  var hasScrollBar = (scrollContainer === null || scrollContainer === void 0 ? void 0 : scrollContainer.scrollHeight) > (scrollContainer === null || scrollContainer === void 0 ? void 0 : scrollContainer.clientHeight);
68
62
  var scrollBarValue = hasScrollBar ? 0 : scrollBarSize;
69
63
  setScrollBarSizeValue(scrollBarValue);
70
64
  }
71
65
  }, [cellSize, ref, scrollBarSize, previousState === null || previousState === void 0 ? void 0 : previousState.cellSize]);
72
-
73
66
  var handleColumnHeaderClick = function handleColumnHeaderClick(index) {
74
67
  return function (event) {
75
68
  var isHoldingCommandKey = event.metaKey || event.ctrlKey;
@@ -91,7 +84,6 @@ export var DataSpreadsheetHeader = /*#__PURE__*/forwardRef(function (_ref, ref)
91
84
  });
92
85
  };
93
86
  };
94
-
95
87
  var handleSelectAllClick = function handleSelectAllClick() {
96
88
  selectAllCells({
97
89
  ref: ref,
@@ -103,16 +95,13 @@ export var DataSpreadsheetHeader = /*#__PURE__*/forwardRef(function (_ref, ref)
103
95
  updateActiveCellCoordinates: updateActiveCellCoordinates
104
96
  });
105
97
  };
106
-
107
98
  var handleHeaderMouseDown = function handleHeaderMouseDown(index) {
108
99
  return function (event) {
109
100
  var _selectionAreaToClone;
110
-
111
101
  if (event.shiftKey) {
112
102
  // Remove columns, need to call handleHeaderCellSelection
113
103
  return;
114
104
  }
115
-
116
105
  setSelectedHeaderReorderActive(true);
117
106
  var selectionAreaToClone = selectionAreas.filter(function (item) {
118
107
  return (item === null || item === void 0 ? void 0 : item.matcher) === currentMatcher;
@@ -138,7 +127,6 @@ export var DataSpreadsheetHeader = /*#__PURE__*/forwardRef(function (_ref, ref)
138
127
  setHeaderCellHoldActive(true);
139
128
  };
140
129
  };
141
-
142
130
  useSpreadsheetMouseMove({
143
131
  ref: ref,
144
132
  headerCellHoldActive: headerCellHoldActive,
@@ -181,7 +169,6 @@ export var DataSpreadsheetHeader = /*#__PURE__*/forwardRef(function (_ref, ref)
181
169
  className: cx("".concat(blockClass, "__th"), "".concat(blockClass, "--interactive-cell-element"), "".concat(blockClass, "__th--select-all"), _defineProperty({}, "".concat(blockClass, "__th--active-header"), (activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) === 'header' && (activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) === 'header'))
182
170
  }, "\xA0")), headerGroup.headers.map(function (column, index) {
183
171
  var _cx2;
184
-
185
172
  var selectedHeader = checkSelectedHeaderCell(index, selectionAreas, 'column', rows);
186
173
  return /*#__PURE__*/React.createElement("div", _extends({
187
174
  key: "column_".concat(index),
@@ -215,22 +202,18 @@ DataSpreadsheetHeader.propTypes = {
215
202
  row: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
216
203
  column: PropTypes.oneOfType([PropTypes.number, PropTypes.string])
217
204
  }),
218
-
219
205
  /**
220
206
  * Specifies the cell height
221
207
  */
222
208
  cellSize: PropTypes.oneOf(['xs', 'sm', 'md', 'lg']),
223
-
224
209
  /**
225
210
  * All of the spreadsheet columns
226
211
  */
227
212
  columns: PropTypes.array,
228
-
229
213
  /**
230
214
  * uuid that corresponds to the current selection area
231
215
  */
232
216
  currentMatcher: PropTypes.string,
233
-
234
217
  /**
235
218
  * Default spreadsheet sizing values
236
219
  */
@@ -239,73 +222,59 @@ DataSpreadsheetHeader.propTypes = {
239
222
  rowHeaderWidth: PropTypes.number,
240
223
  width: PropTypes.number
241
224
  }),
242
-
243
225
  /**
244
226
  * Whether or not a click/hold is active on a header cell
245
227
  */
246
228
  headerCellHoldActive: PropTypes.bool,
247
-
248
229
  /**
249
230
  * Headers provided from useTable hook
250
231
  */
251
232
  headerGroups: PropTypes.arrayOf(PropTypes.object),
252
-
253
233
  /**
254
234
  * All of the spreadsheet row data
255
235
  */
256
236
  rows: PropTypes.arrayOf(PropTypes.object),
257
-
258
237
  /**
259
238
  * The scrollbar width
260
239
  */
261
240
  scrollBarSize: PropTypes.number,
262
-
263
241
  /**
264
242
  * The aria label applied to the Select all button
265
243
  */
266
244
  selectAllAriaLabel: PropTypes.string.isRequired,
267
-
268
245
  /**
269
246
  * All of the cell selection area items
270
247
  */
271
248
  selectionAreas: PropTypes.arrayOf(PropTypes.object),
272
-
273
249
  /**
274
250
  * Setter fn for activeCellCoordinates value
275
251
  */
276
252
  setActiveCellCoordinates: PropTypes.func,
277
-
278
253
  /**
279
254
  * Setter fn for currentMatcher value
280
255
  */
281
256
  setCurrentMatcher: PropTypes.func,
282
-
283
257
  /**
284
258
  * Setter fn for header cell hold active value
285
259
  */
286
260
  setHeaderCellHoldActive: PropTypes.func,
287
-
288
261
  /**
289
262
  * Setter fn for selectionAreaData state value
290
263
  */
291
264
  setSelectionAreaData: PropTypes.func,
292
-
293
265
  /**
294
266
  * Setter fn for selectionAreas value
295
267
  */
296
268
  setSelectionAreas: PropTypes.func,
297
-
298
269
  /**
299
270
  * The total number of columns to be initially visible, additional columns will be rendered and
300
271
  * visible via horizontal scrollbar
301
272
  */
302
273
  totalVisibleColumns: PropTypes.number,
303
-
304
274
  /**
305
275
  * Function used to update the active cell coordinates
306
276
  */
307
277
  updateActiveCellCoordinates: PropTypes.func,
308
-
309
278
  /**
310
279
  * Array of visible columns provided by react-table useTable hook
311
280
  */
@@ -4,6 +4,7 @@
4
4
  * This source code is licensed under the Apache-2.0 license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
+
7
8
  export { useMoveActiveCell } from './useMoveActiveCell';
8
9
  export { useMultipleKeyTracking } from './useMultipleKeyTracking';
9
10
  export { useResetSpreadsheetFocus } from './useResetSpreadsheetFocus';
@@ -4,18 +4,19 @@
4
4
  * This source code is licensed under the Apache-2.0 license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
- import { useEffect } from 'react'; // Moves the placement of the active cell
8
7
 
8
+ import { useEffect } from 'react';
9
+
10
+ // Moves the placement of the active cell
9
11
  export var useMoveActiveCell = function useMoveActiveCell(_ref) {
10
12
  var spreadsheetRef = _ref.spreadsheetRef,
11
- activeCellCoordinates = _ref.activeCellCoordinates,
12
- containerHasFocus = _ref.containerHasFocus,
13
- createActiveCell = _ref.createActiveCell;
13
+ activeCellCoordinates = _ref.activeCellCoordinates,
14
+ containerHasFocus = _ref.containerHasFocus,
15
+ createActiveCell = _ref.createActiveCell;
14
16
  useEffect(function () {
15
17
  var activeCellPlacementElement = spreadsheetRef === null || spreadsheetRef === void 0 ? void 0 : spreadsheetRef.current.querySelector("[data-row-index=\"".concat(activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row, "\"][data-column-index=\"").concat(activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column, "\"]"));
16
18
  var shouldPlaceActiveCellInHeader = (activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) === 'header' && true;
17
19
  var selectAllElement = spreadsheetRef === null || spreadsheetRef === void 0 ? void 0 : spreadsheetRef.current.querySelector("[data-row-index=\"header\"][data-column-index=\"header\"]");
18
-
19
20
  if (containerHasFocus) {
20
21
  createActiveCell({
21
22
  placementElement: activeCellCoordinates ? activeCellPlacementElement : selectAllElement,
@@ -1,66 +1,56 @@
1
1
  import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
2
2
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
-
4
3
  /**
5
4
  * Copyright IBM Corp. 2022, 2022
6
5
  *
7
6
  * This source code is licensed under the Apache-2.0 license found in the
8
7
  * LICENSE file in the root directory of this source tree.
9
8
  */
9
+
10
10
  import { useEffect, useState } from 'react';
11
11
  import { usePreviousValue } from '../../../global/js/hooks';
12
12
  import { includesResourceKey } from '../utils/handleMultipleKeys';
13
-
14
13
  var hasFocus = function hasFocus() {
15
14
  return typeof document !== 'undefined' && document.hasFocus();
16
15
  };
17
-
18
16
  export var useMultipleKeyTracking = function useMultipleKeyTracking(_ref) {
19
17
  var ref = _ref.ref,
20
- containerHasFocus = _ref.containerHasFocus,
21
- isEditing = _ref.isEditing;
22
-
18
+ containerHasFocus = _ref.containerHasFocus,
19
+ isEditing = _ref.isEditing;
23
20
  var _useState = useState(''),
24
- _useState2 = _slicedToArray(_useState, 2),
25
- usingMac = _useState2[0],
26
- setUsingMac = _useState2[1];
27
-
21
+ _useState2 = _slicedToArray(_useState, 2),
22
+ usingMac = _useState2[0],
23
+ setUsingMac = _useState2[1];
28
24
  var _useState3 = useState(hasFocus),
29
- _useState4 = _slicedToArray(_useState3, 2),
30
- windowFocused = _useState4[0],
31
- setWindowFocused = _useState4[1];
32
-
25
+ _useState4 = _slicedToArray(_useState3, 2),
26
+ windowFocused = _useState4[0],
27
+ setWindowFocused = _useState4[1];
33
28
  var _useState5 = useState([]),
34
- _useState6 = _slicedToArray(_useState5, 2),
35
- keysPressedList = _useState6[0],
36
- setKeysPressedList = _useState6[1];
37
-
29
+ _useState6 = _slicedToArray(_useState5, 2),
30
+ keysPressedList = _useState6[0],
31
+ setKeysPressedList = _useState6[1];
38
32
  var previousState = usePreviousValue({
39
33
  isEditing: isEditing,
40
34
  windowFocused: windowFocused,
41
35
  containerHasFocus: containerHasFocus
42
- }); // useEffect to check for window focus, if window loses focus
43
- // we need to clear out the keysPressedList
36
+ });
44
37
 
38
+ // useEffect to check for window focus, if window loses focus
39
+ // we need to clear out the keysPressedList
45
40
  useEffect(function () {
46
41
  var userAgentString = window.navigator.userAgent;
47
-
48
42
  if (userAgentString.includes('Macintosh')) {
49
43
  setUsingMac(true);
50
44
  } else {
51
45
  setUsingMac(false);
52
46
  }
53
-
54
47
  setWindowFocused(hasFocus());
55
-
56
48
  var onWindowFocus = function onWindowFocus() {
57
49
  return setWindowFocused(true);
58
50
  };
59
-
60
51
  var onWindowBlur = function onWindowBlur() {
61
52
  return setWindowFocused(false);
62
53
  };
63
-
64
54
  window.addEventListener('focus', onWindowFocus);
65
55
  window.addEventListener('blur', onWindowBlur);
66
56
  return function () {
@@ -76,57 +66,46 @@ export var useMultipleKeyTracking = function useMultipleKeyTracking(_ref) {
76
66
  // Prevent multiple keys of the same type being added to our keysPressedList array
77
67
  if (keysPressedList.includes(event.code)) {
78
68
  return;
79
- } // Because keyup events are lost when using the Command key
69
+ }
70
+ // Because keyup events are lost when using the Command key
80
71
  // we need to remove the previously pressed keys so that we
81
72
  // do not have keys in the pressed list that should not be
82
-
83
-
84
73
  if (includesResourceKey(keysPressedList, usingMac) && keysPressedList.length > 1) {
85
74
  var clonedKeys = _toConsumableArray(keysPressedList);
86
-
87
75
  var filteredClonedKeys = clonedKeys.filter(function (item) {
88
76
  return item === 'MetaLeft' || item === 'MetaRight';
89
77
  });
90
78
  filteredClonedKeys.push(event.code);
91
79
  return setKeysPressedList(_toConsumableArray(new Set(filteredClonedKeys)));
92
80
  }
93
-
94
81
  var tempKeys = _toConsumableArray(keysPressedList);
95
-
96
82
  tempKeys.push(event.code);
97
83
  setKeysPressedList(_toConsumableArray(new Set(tempKeys)));
98
- } // If keyup, we will remove the key from the keysPressedList array
99
-
100
-
84
+ }
85
+ // If keyup, we will remove the key from the keysPressedList array
101
86
  if (event.type === 'keyup') {
102
87
  var _tempKeys = _toConsumableArray(keysPressedList);
103
-
104
88
  var filteredClone = _tempKeys.filter(function (item) {
105
89
  return item !== event.code;
106
- }); // Keyup events are lost on all other keys if a Meta key is used
90
+ });
91
+ // Keyup events are lost on all other keys if a Meta key is used
107
92
  // so to work around this behavior, we empty out all other keys
108
93
  // from the keysPressedList array if we detect a Meta keyup event
109
-
110
-
111
94
  if (event.code === 'MetaLeft' || event.code === 'MetaRight') {
112
95
  return setKeysPressedList([]);
113
96
  }
114
-
115
97
  setKeysPressedList(_toConsumableArray(new Set(filteredClone)));
116
98
  }
117
99
  };
118
100
  }
119
-
120
101
  if (previousState !== null && previousState !== void 0 && previousState.windowFocused && !windowFocused) {
121
102
  setKeysPressedList([]);
122
- } // Remove handlers if the spreadsheet container loses focus
103
+ }
104
+ // Remove handlers if the spreadsheet container loses focus
123
105
  // or is currently in edit mode
124
-
125
-
126
106
  if (ref && !containerHasFocus || isEditing) {
127
107
  ref.current.onkeydown = undefined;
128
108
  ref.current.onkeyup = undefined;
129
-
130
109
  if (!(previousState !== null && previousState !== void 0 && previousState.isEditing) && isEditing || previousState !== null && previousState !== void 0 && previousState.containerHasFocus && !containerHasFocus) {
131
110
  setKeysPressedList([]);
132
111
  }
@@ -4,21 +4,21 @@
4
4
  * This source code is licensed under the Apache-2.0 license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
+
7
8
  import { useEffect } from 'react';
8
9
  import { pkg } from '../../../settings';
9
10
  export var useResetSpreadsheetFocus = function useResetSpreadsheetFocus(_ref) {
10
11
  var _ref$blockClass = _ref.blockClass,
11
- blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
12
- focusedElement = _ref.focusedElement,
13
- removeActiveCell = _ref.removeActiveCell,
14
- setContainerHasFocus = _ref.setContainerHasFocus;
12
+ blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
13
+ focusedElement = _ref.focusedElement,
14
+ removeActiveCell = _ref.removeActiveCell,
15
+ setContainerHasFocus = _ref.setContainerHasFocus;
15
16
  // Reset everything when spreadsheet loses focus
16
17
  useEffect(function () {
17
18
  if (!focusedElement.classList.contains("".concat(blockClass, "--interactive-cell-element"))) {
18
19
  setContainerHasFocus(false);
19
20
  removeActiveCell();
20
21
  }
21
-
22
22
  if (focusedElement.classList.contains(blockClass) || focusedElement.classList.contains("".concat(blockClass, "--interactive-cell-element"))) {
23
23
  setContainerHasFocus(true);
24
24
  }
@@ -1,33 +1,31 @@
1
1
  import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
-
3
2
  /**
4
3
  * Copyright IBM Corp. 2022, 2022
5
4
  *
6
5
  * This source code is licensed under the Apache-2.0 license found in the
7
6
  * LICENSE file in the root directory of this source tree.
8
7
  */
8
+
9
9
  import { useEffect, useState } from 'react';
10
10
  import { px } from '@carbon/layout';
11
11
  import { pkg } from '../../../settings';
12
12
  import { usePreviousValue } from '../../../global/js/hooks';
13
13
  export var useSpreadsheetEdit = function useSpreadsheetEdit(_ref) {
14
14
  var isEditing = _ref.isEditing,
15
- rows = _ref.rows,
16
- activeCellCoordinates = _ref.activeCellCoordinates,
17
- activeCellRef = _ref.activeCellRef,
18
- cellEditorRef = _ref.cellEditorRef,
19
- cellEditorRulerRef = _ref.cellEditorRulerRef,
20
- visibleColumns = _ref.visibleColumns,
21
- defaultColumn = _ref.defaultColumn,
22
- cellEditorValue = _ref.cellEditorValue,
23
- _ref$blockClass = _ref.blockClass,
24
- blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass;
25
-
15
+ rows = _ref.rows,
16
+ activeCellCoordinates = _ref.activeCellCoordinates,
17
+ activeCellRef = _ref.activeCellRef,
18
+ cellEditorRef = _ref.cellEditorRef,
19
+ cellEditorRulerRef = _ref.cellEditorRulerRef,
20
+ visibleColumns = _ref.visibleColumns,
21
+ defaultColumn = _ref.defaultColumn,
22
+ cellEditorValue = _ref.cellEditorValue,
23
+ _ref$blockClass = _ref.blockClass,
24
+ blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass;
26
25
  var _useState = useState(null),
27
- _useState2 = _slicedToArray(_useState, 2),
28
- nextIndex = _useState2[0],
29
- setNextIndex = _useState2[1];
30
-
26
+ _useState2 = _slicedToArray(_useState, 2),
27
+ nextIndex = _useState2[0],
28
+ setNextIndex = _useState2[1];
31
29
  var previousState = usePreviousValue({
32
30
  nextIndex: nextIndex
33
31
  });
@@ -39,10 +37,8 @@ export var useSpreadsheetEdit = function useSpreadsheetEdit(_ref) {
39
37
  useEffect(function () {
40
38
  var rulerWidth = cellEditorRulerRef.current.offsetWidth;
41
39
  var cellEditorCurrentWidth = parseInt(cellEditorRef.current.style.width);
42
-
43
40
  if (isEditing) {
44
41
  var _rows$activeCellCoord, _cellProps$column, _cellEditorRef$curren;
45
-
46
42
  var cellProps = (_rows$activeCellCoord = rows[activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row]) === null || _rows$activeCellCoord === void 0 ? void 0 : _rows$activeCellCoord.cells[activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column];
47
43
  var activeCellLeftPosition = activeCellRef === null || activeCellRef === void 0 ? void 0 : activeCellRef.current.style.left;
48
44
  var activeCellTopPosition = activeCellRef === null || activeCellRef === void 0 ? void 0 : activeCellRef.current.style.top;
@@ -51,36 +47,30 @@ export var useSpreadsheetEdit = function useSpreadsheetEdit(_ref) {
51
47
  cellEditorRef.current.style.display = 'block';
52
48
  cellEditorRef.current.style.height = activeCellRef === null || activeCellRef === void 0 ? void 0 : activeCellRef.current.style.height;
53
49
  cellEditorRef.current.style.paddingTop = "".concat((parseInt(activeCellRef === null || activeCellRef === void 0 ? void 0 : activeCellRef.current.style.height) - 16) / 2 - 1, "px"); // calculate paddingTop based on cellHeight which could be variable depending on the cellSize prop
54
-
55
50
  cellEditorRef.current.style.textAlign = (cellProps === null || cellProps === void 0 ? void 0 : (_cellProps$column = cellProps.column) === null || _cellProps$column === void 0 ? void 0 : _cellProps$column.placement) === 'right' ? 'right' : 'left';
56
51
  (_cellEditorRef$curren = cellEditorRef.current) === null || _cellEditorRef$curren === void 0 ? void 0 : _cellEditorRef$curren.focus();
57
-
58
52
  if (rulerWidth < cellEditorCurrentWidth) {
59
53
  var _visibleColumns$nextI;
60
-
61
- var currentColumnWidth = ((_visibleColumns$nextI = visibleColumns[nextIndex]) === null || _visibleColumns$nextI === void 0 ? void 0 : _visibleColumns$nextI.width) || (defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.width); // If the contents of the cell editor is deleted past the point of the next column
62
-
54
+ var currentColumnWidth = ((_visibleColumns$nextI = visibleColumns[nextIndex]) === null || _visibleColumns$nextI === void 0 ? void 0 : _visibleColumns$nextI.width) || (defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.width);
55
+ // If the contents of the cell editor is deleted past the point of the next column
63
56
  if (rulerWidth < cellEditorCurrentWidth - currentColumnWidth) {
64
57
  cellEditorRef.current.style.width = px(parseInt(cellEditorRef.current.style.width) - currentColumnWidth);
65
58
  setNextIndex(function (prev) {
66
59
  if (prev === 0) {
67
60
  return prev;
68
61
  }
69
-
70
62
  return prev - 1;
71
63
  });
72
- } // Decrease cell editor width by increment of current column width
73
-
64
+ }
65
+ // Decrease cell editor width by increment of current column width
74
66
  }
75
67
 
76
68
  if (rulerWidth >= cellEditorCurrentWidth) {
77
69
  var _visibleColumns;
78
-
79
70
  setNextIndex(function (prev) {
80
71
  if (prev === visibleColumns.length - 1) {
81
72
  return prev;
82
73
  }
83
-
84
74
  return prev + 1;
85
75
  });
86
76
  var onLastColumnIndex = nextIndex + 1 === visibleColumns.length;
@@ -94,7 +84,6 @@ export var useSpreadsheetEdit = function useSpreadsheetEdit(_ref) {
94
84
  // Cell editor has reached max height, we need to add the scrolling back.
95
85
  // We also need to subtract 1 to account for the fact that the cell editor
96
86
  // is placed one pixel below the cell being edited to account for the border
97
-
98
87
  if (cellEditorRef.current.clientHeight === totalCellEditorMaxHeight - 1) {
99
88
  cellEditorRef.current.style.overflow = 'auto';
100
89
  } else {
@@ -102,7 +91,6 @@ export var useSpreadsheetEdit = function useSpreadsheetEdit(_ref) {
102
91
  }
103
92
  }
104
93
  }
105
-
106
94
  if (!isEditing) {
107
95
  cellEditorRef.current.style.overflow = 'hidden';
108
96
  cellEditorRef.current.style.display = 'none';
@@ -4,26 +4,26 @@
4
4
  * This source code is licensed under the Apache-2.0 license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
+
7
8
  import { useEffect } from 'react';
8
9
  import { px } from '@carbon/layout';
9
10
  import { pkg } from '../../../settings';
10
- import { moveColumnIndicatorLine } from '../utils/moveColumnIndicatorLine'; // Used specifically for reordering columns, will move the position of the
11
- // cloned selection area to follow the position of the cursor
11
+ import { moveColumnIndicatorLine } from '../utils/moveColumnIndicatorLine';
12
12
 
13
+ // Used specifically for reordering columns, will move the position of the
14
+ // cloned selection area to follow the position of the cursor
13
15
  export var useSpreadsheetMouseMove = function useSpreadsheetMouseMove(_ref) {
14
16
  var ref = _ref.ref,
15
- _ref$blockClass = _ref.blockClass,
16
- blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
17
- headerCellHoldActive = _ref.headerCellHoldActive,
18
- defaultColumn = _ref.defaultColumn;
17
+ _ref$blockClass = _ref.blockClass,
18
+ blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
19
+ headerCellHoldActive = _ref.headerCellHoldActive,
20
+ defaultColumn = _ref.defaultColumn;
19
21
  useEffect(function () {
20
22
  var handleMouseMove = function handleMouseMove(event) {
21
23
  var clonedSelectionElement = ref.current.querySelector(".".concat(blockClass, "__selection-area--element-cloned"));
22
-
23
24
  if (clonedSelectionElement) {
24
25
  ref.current.addEventListener('mousemove', handleMouseMove);
25
26
  }
26
-
27
27
  var spreadsheetCoords = ref.current.getBoundingClientRect();
28
28
  var listContainer = ref.current.querySelector(".".concat(blockClass, "__list--container"));
29
29
  var scrollAmount = listContainer.scrollLeft;
@@ -39,22 +39,18 @@ export var useSpreadsheetMouseMove = function useSpreadsheetMouseMove(_ref) {
39
39
  var offsetXValue = clonedSelectionElement === null || clonedSelectionElement === void 0 ? void 0 : clonedSelectionElement.getAttribute('data-clone-offset-x');
40
40
  var totalSpreadsheetScrollingWidth = listContainer.scrollWidth;
41
41
  var clonedSelectionWidth = clonedSelectionElement.offsetWidth;
42
- var clonePlacement = Math.max(xPositionRelativeToSpreadsheet - offsetXValue, defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.rowHeaderWidth); // Moves the position of the cloned selection area to follow mouse, and
42
+ var clonePlacement = Math.max(xPositionRelativeToSpreadsheet - offsetXValue, defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.rowHeaderWidth);
43
+ // Moves the position of the cloned selection area to follow mouse, and
43
44
  // add the amount horizontally scrolled
44
-
45
45
  clonedSelectionElement.style.left = px(totalSpreadsheetScrollingWidth - clonedSelectionWidth >= clonePlacement ? clonePlacement + scrollAmount : totalSpreadsheetScrollingWidth - clonedSelectionWidth);
46
46
  };
47
-
48
47
  if (headerCellHoldActive) {
49
48
  ref.current.addEventListener('mousemove', handleMouseMove);
50
49
  }
51
-
52
50
  var spreadsheetRef = ref.current;
53
-
54
51
  if (!headerCellHoldActive) {
55
52
  spreadsheetRef === null || spreadsheetRef === void 0 ? void 0 : spreadsheetRef.removeEventListener('mousemove', handleMouseMove);
56
53
  }
57
-
58
54
  return function () {
59
55
  spreadsheetRef === null || spreadsheetRef === void 0 ? void 0 : spreadsheetRef.removeEventListener('mousemove', handleMouseMove);
60
56
  };