@carbon/ibm-products 2.0.0 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- package/LICENSE +201 -0
- package/README.md +1 -1
- package/css/config.css +3 -0
- package/css/config.css.map +1 -0
- package/css/index-full-carbon.css +34268 -0
- package/css/index-full-carbon.css.map +1 -0
- package/css/index-full-carbon.min.css +8 -0
- package/css/index-full-carbon.min.css.map +1 -0
- package/css/index-without-carbon-released-only.css +8698 -0
- package/css/index-without-carbon-released-only.css.map +1 -0
- package/css/index-without-carbon-released-only.min.css +4 -0
- package/css/index-without-carbon-released-only.min.css.map +1 -0
- package/css/index-without-carbon.css +14253 -0
- package/css/index-without-carbon.css.map +1 -0
- package/css/index-without-carbon.min.css +8 -0
- package/css/index-without-carbon.min.css.map +1 -0
- package/css/index.css +17293 -0
- package/css/index.css.map +1 -0
- package/css/index.min.css +8 -0
- package/css/index.min.css.map +1 -0
- package/es/components/APIKeyModal/APIKeyDownloader.js +91 -0
- package/es/components/APIKeyModal/APIKeyModal.js +510 -0
- package/es/components/APIKeyModal/index.js +8 -0
- package/es/components/AboutModal/AboutModal.js +194 -0
- package/es/components/AboutModal/index.js +8 -0
- package/es/components/ActionBar/ActionBar.js +258 -0
- package/es/components/ActionBar/ActionBarItem.js +96 -0
- package/es/components/ActionBar/ActionBarOverflowItems.js +74 -0
- package/es/components/ActionBar/index.js +9 -0
- package/es/components/ActionSet/ActionSet.js +200 -0
- package/es/components/ActionSet/actions.js +55 -0
- package/es/components/ActionSet/index.js +8 -0
- package/es/components/AddSelect/AddSelect.js +129 -0
- package/es/components/AddSelect/AddSelectBody.js +368 -0
- package/es/components/AddSelect/AddSelectBreadcrumbs.js +45 -0
- package/es/components/AddSelect/AddSelectColumn.js +241 -0
- package/es/components/AddSelect/AddSelectFilter.js +172 -0
- package/es/components/AddSelect/AddSelectFormControl.js +82 -0
- package/es/components/AddSelect/AddSelectList.js +55 -0
- package/es/components/AddSelect/AddSelectMetaPanel.js +65 -0
- package/es/components/AddSelect/AddSelectRow.js +206 -0
- package/es/components/AddSelect/AddSelectSidebar.js +121 -0
- package/es/components/AddSelect/AddSelectSort.js +77 -0
- package/es/components/AddSelect/add-select-utils.js +127 -0
- package/es/components/AddSelect/hooks/useFocus.js +31 -0
- package/es/components/AddSelect/hooks/useItemSort.js +25 -0
- package/es/components/AddSelect/hooks/useParentSelect.js +20 -0
- package/es/components/AddSelect/hooks/usePath.js +72 -0
- package/es/components/AddSelect/index.js +8 -0
- package/es/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +336 -0
- package/es/components/BreadcrumbWithOverflow/index.js +10 -0
- package/es/components/ButtonMenu/ButtonMenu.js +129 -0
- package/es/components/ButtonMenu/ButtonMenuItem.js +33 -0
- package/es/components/ButtonMenu/index.js +9 -0
- package/es/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +211 -0
- package/es/components/ButtonSetWithOverflow/index.js +8 -0
- package/es/components/Card/Card.js +264 -0
- package/es/components/Card/CardFooter.js +79 -0
- package/es/components/Card/CardHeader.js +74 -0
- package/es/components/Card/index.js +10 -0
- package/es/components/Cascade/Cascade.js +80 -0
- package/es/components/Cascade/index.js +1 -0
- package/es/components/ComboButton/ComboButton.js +101 -0
- package/es/components/ComboButton/ComboButtonItem/index.js +30 -0
- package/es/components/ComboButton/index.js +9 -0
- package/es/components/CreateFullPage/CreateFullPage.js +288 -0
- package/es/components/CreateFullPage/CreateFullPageStep.js +166 -0
- package/es/components/CreateFullPage/index.js +9 -0
- package/es/components/CreateInfluencer/CreateInfluencer.js +92 -0
- package/es/components/CreateInfluencer/index.js +8 -0
- package/es/components/CreateModal/CreateModal.js +137 -0
- package/es/components/CreateModal/index.js +10 -0
- package/es/components/CreateSidePanel/CreateSidePanel.js +156 -0
- package/es/components/CreateSidePanel/index.js +8 -0
- package/es/components/CreateTearsheet/CreateTearsheet.js +308 -0
- package/es/components/CreateTearsheet/CreateTearsheetDivider.js +33 -0
- package/es/components/CreateTearsheet/CreateTearsheetStep.js +174 -0
- package/es/components/CreateTearsheet/index.js +10 -0
- package/es/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +284 -0
- package/es/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +280 -0
- package/es/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +165 -0
- package/es/components/CreateTearsheetNarrow/index.js +8 -0
- package/es/components/DataSpreadsheet/DataSpreadsheet.js +883 -0
- package/es/components/DataSpreadsheet/DataSpreadsheetBody.js +551 -0
- package/es/components/DataSpreadsheet/DataSpreadsheetHeader.js +282 -0
- package/es/components/DataSpreadsheet/hooks/index.js +14 -0
- package/es/components/DataSpreadsheet/hooks/useMoveActiveCell.js +28 -0
- package/es/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +119 -0
- package/es/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +26 -0
- package/es/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +102 -0
- package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +58 -0
- package/es/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +164 -0
- package/es/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +41 -0
- package/es/components/DataSpreadsheet/index.js +8 -0
- package/es/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +30 -0
- package/es/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +29 -0
- package/es/components/DataSpreadsheet/utils/createActiveCellFn.js +54 -0
- package/es/components/DataSpreadsheet/utils/createCellSelectionArea.js +64 -0
- package/es/components/DataSpreadsheet/utils/generateData.js +52 -0
- package/es/components/DataSpreadsheet/utils/getCellSize.js +25 -0
- package/es/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +19 -0
- package/es/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +34 -0
- package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +107 -0
- package/es/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +98 -0
- package/es/components/DataSpreadsheet/utils/handleCellDeletion.js +40 -0
- package/es/components/DataSpreadsheet/utils/handleEditSubmit.js +80 -0
- package/es/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +158 -0
- package/es/components/DataSpreadsheet/utils/handleMultipleKeys.js +259 -0
- package/es/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +33 -0
- package/es/components/DataSpreadsheet/utils/removeCellSelections.js +28 -0
- package/es/components/DataSpreadsheet/utils/selectAllCells.js +49 -0
- package/es/components/Datagrid/Datagrid/Datagrid.js +63 -0
- package/es/components/Datagrid/Datagrid/DatagridBody.js +30 -0
- package/es/components/Datagrid/Datagrid/DatagridContent.js +181 -0
- package/es/components/Datagrid/Datagrid/DatagridEmptyBody.js +41 -0
- package/es/components/Datagrid/Datagrid/DatagridExpandedRow.js +32 -0
- package/es/components/Datagrid/Datagrid/DatagridHead.js +22 -0
- package/es/components/Datagrid/Datagrid/DatagridHeaderRow.js +52 -0
- package/es/components/Datagrid/Datagrid/DatagridRefBody.js +36 -0
- package/es/components/Datagrid/Datagrid/DatagridRow.js +118 -0
- package/es/components/Datagrid/Datagrid/DatagridSelectAll.js +62 -0
- package/es/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +140 -0
- package/es/components/Datagrid/Datagrid/DatagridSimpleBody.js +32 -0
- package/es/components/Datagrid/Datagrid/DatagridToolbar.js +142 -0
- package/es/components/Datagrid/Datagrid/DatagridVirtualBody.js +109 -0
- package/es/components/Datagrid/Datagrid/DraggableElement.js +177 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +39 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +52 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +117 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +176 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +109 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +51 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +13 -0
- package/es/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +10 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +242 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +265 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +83 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/constants.js +27 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +10 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +328 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +34 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +23 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/index.js +9 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/motion/variants.js +55 -0
- package/es/components/Datagrid/Datagrid/addons/Filtering/utils.js +84 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +59 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/index.js +1 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +489 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/index.js +1 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +98 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +27 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/index.js +1 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +34 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +18 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +228 -0
- package/es/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +80 -0
- package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +67 -0
- package/es/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +105 -0
- package/es/components/Datagrid/Datagrid/addons/RowSize/index.js +9 -0
- package/es/components/Datagrid/Datagrid/index.js +8 -0
- package/es/components/Datagrid/Datagrid.stories/CustomizeColumnStory.js +6 -0
- package/es/components/Datagrid/Datagrid.stories/RowSizeDropdownStory.js +6 -0
- package/es/components/Datagrid/Datagrid.stories/SelectAllWithToggleStory.js +6 -0
- package/es/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +102 -0
- package/es/components/Datagrid/Datagrid.stories/common.js +190 -0
- package/es/components/Datagrid/Datagrid.stories/index.js +4 -0
- package/es/components/Datagrid/common-column-ids.js +9 -0
- package/es/components/Datagrid/index.js +28 -0
- package/es/components/Datagrid/useActionsColumn.js +140 -0
- package/es/components/Datagrid/useColumnCenterAlign.js +44 -0
- package/es/components/Datagrid/useColumnOrder.js +9 -0
- package/es/components/Datagrid/useColumnRightAlign.js +44 -0
- package/es/components/Datagrid/useCustomizeColumns.js +44 -0
- package/es/components/Datagrid/useDatagrid.js +37 -0
- package/es/components/Datagrid/useDefaultStringRenderer.js +42 -0
- package/es/components/Datagrid/useDisableSelectRows.js +80 -0
- package/es/components/Datagrid/useEditableCell.js +12 -0
- package/es/components/Datagrid/useExpandedRow.js +46 -0
- package/es/components/Datagrid/useFiltering.js +95 -0
- package/es/components/Datagrid/useFlexResize.js +44 -0
- package/es/components/Datagrid/useFloatingScroll.js +75 -0
- package/es/components/Datagrid/useInfiniteScroll.js +52 -0
- package/es/components/Datagrid/useInlineEdit.js +71 -0
- package/es/components/Datagrid/useNestedRowExpander.js +41 -0
- package/es/components/Datagrid/useNestedRows.js +58 -0
- package/es/components/Datagrid/useOnRowClick.js +47 -0
- package/es/components/Datagrid/useParentDimensions.js +57 -0
- package/es/components/Datagrid/useResizeTable.js +34 -0
- package/es/components/Datagrid/useRowExpander.js +41 -0
- package/es/components/Datagrid/useRowIsMouseOver.js +52 -0
- package/es/components/Datagrid/useRowRenderer.js +25 -0
- package/es/components/Datagrid/useRowSize.js +55 -0
- package/es/components/Datagrid/useSelectAllToggle.js +90 -0
- package/es/components/Datagrid/useSelectRows.js +117 -0
- package/es/components/Datagrid/useSkeletonRows.js +27 -0
- package/es/components/Datagrid/useSortableColumns.js +115 -0
- package/es/components/Datagrid/useStickyColumn.js +182 -0
- package/es/components/Datagrid/utils/DatagridActions.js +239 -0
- package/es/components/Datagrid/utils/DatagridPagination.js +32 -0
- package/es/components/Datagrid/utils/Wrapper.js +21 -0
- package/es/components/Datagrid/utils/getArgTypes.js +95 -0
- package/es/components/Datagrid/utils/getAutoSizedColumnWidth.js +27 -0
- package/es/components/Datagrid/utils/getInlineEditColumns.js +157 -0
- package/es/components/Datagrid/utils/makeData.js +193 -0
- package/es/components/EditFullPage/EditFullPage.js +86 -0
- package/es/components/EditFullPage/index.js +8 -0
- package/es/components/EditInPlace/EditInPlace.js +303 -0
- package/es/components/EditInPlace/index.js +8 -0
- package/es/components/EditSidePanel/EditSidePanel.js +189 -0
- package/es/components/EditSidePanel/index.js +8 -0
- package/es/components/EditTearsheet/EditTearsheet.js +195 -0
- package/es/components/EditTearsheet/EditTearsheetForm.js +99 -0
- package/es/components/EditTearsheet/index.js +9 -0
- package/es/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +218 -0
- package/es/components/EditTearsheetNarrow/EditTearsheetNarrow.js +86 -0
- package/es/components/EditTearsheetNarrow/index.js +8 -0
- package/es/components/EditUpdateCards/EditUpdateCards.js +142 -0
- package/es/components/EditUpdateCards/index.js +8 -0
- package/es/components/EmptyStates/EmptyState.js +116 -0
- package/es/components/EmptyStates/EmptyStateContent.js +87 -0
- package/es/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +111 -0
- package/es/components/EmptyStates/ErrorEmptyState/index.js +8 -0
- package/es/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +111 -0
- package/es/components/EmptyStates/NoDataEmptyState/index.js +8 -0
- package/es/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +111 -0
- package/es/components/EmptyStates/NoTagsEmptyState/index.js +8 -0
- package/es/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +111 -0
- package/es/components/EmptyStates/NotFoundEmptyState/index.js +8 -0
- package/es/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +111 -0
- package/es/components/EmptyStates/NotificationsEmptyState/index.js +8 -0
- package/es/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +111 -0
- package/es/components/EmptyStates/UnauthorizedEmptyState/index.js +8 -0
- package/es/components/EmptyStates/assets/ErrorIllustration.js +218 -0
- package/es/components/EmptyStates/assets/NoDataIllustration.js +181 -0
- package/es/components/EmptyStates/assets/NoTagsIllustration.js +489 -0
- package/es/components/EmptyStates/assets/NotFoundIllustration.js +366 -0
- package/es/components/EmptyStates/assets/NotificationsIllustration.js +337 -0
- package/es/components/EmptyStates/assets/UnauthorizedIllustration.js +310 -0
- package/es/components/EmptyStates/index.js +14 -0
- package/es/components/ExampleComponent/ExampleComponent.js +180 -0
- package/es/components/ExampleComponent/ExampleDeprecatedComponent.js +28 -0
- package/es/components/ExampleComponent/index.js +8 -0
- package/es/components/ExampleComponent/useExample.js +49 -0
- package/es/components/ExportModal/ExportModal.js +278 -0
- package/es/components/ExportModal/index.js +8 -0
- package/es/components/ExpressiveCard/ExpressiveCard.js +114 -0
- package/es/components/ExpressiveCard/index.js +8 -0
- package/es/components/FilterSummary/FilterSummary.js +54 -0
- package/es/components/FilterSummary/index.js +7 -0
- package/es/components/HTTPErrors/HTTPError403/HTTPError403.js +85 -0
- package/es/components/HTTPErrors/HTTPError403/index.js +8 -0
- package/es/components/HTTPErrors/HTTPError404/HTTPError404.js +85 -0
- package/es/components/HTTPErrors/HTTPError404/index.js +8 -0
- package/es/components/HTTPErrors/HTTPErrorContent.js +81 -0
- package/es/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +85 -0
- package/es/components/HTTPErrors/HTTPErrorOther/index.js +8 -0
- package/es/components/HTTPErrors/assets/HTTPErrorSvg403.js +1240 -0
- package/es/components/HTTPErrors/assets/HTTPErrorSvg404.js +1039 -0
- package/es/components/HTTPErrors/assets/HTTPErrorSvgOther.js +1090 -0
- package/es/components/HTTPErrors/index.js +10 -0
- package/es/components/ImportModal/ImportModal.js +383 -0
- package/es/components/ImportModal/index.js +8 -0
- package/es/components/MultiAddSelect/MultiAddSelect.js +148 -0
- package/es/components/MultiAddSelect/index.js +8 -0
- package/es/components/NotificationsPanel/NotificationsPanel.js +556 -0
- package/es/components/NotificationsPanel/NotificationsPanel_data.js +135 -0
- package/es/components/NotificationsPanel/index.js +8 -0
- package/es/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +48 -0
- package/es/components/NotificationsPanel/utils.js +50 -0
- package/es/components/OptionsTile/OptionsTile.js +327 -0
- package/es/components/OptionsTile/index.js +8 -0
- package/es/components/PageHeader/PageHeader.js +767 -0
- package/es/components/PageHeader/PageHeaderDemo.data.js +613 -0
- package/es/components/PageHeader/PageHeaderTitle.js +121 -0
- package/es/components/PageHeader/PageHeaderUtils.js +179 -0
- package/es/components/PageHeader/index.js +8 -0
- package/es/components/ProductiveCard/ProductiveCard.js +123 -0
- package/es/components/ProductiveCard/index.js +8 -0
- package/es/components/RemoveModal/RemoveModal.js +183 -0
- package/es/components/RemoveModal/index.js +8 -0
- package/es/components/Saving/Saving.js +159 -0
- package/es/components/Saving/index.js +8 -0
- package/es/components/SidePanel/SidePanel.js +630 -0
- package/es/components/SidePanel/constants.js +14 -0
- package/es/components/SidePanel/index.js +8 -0
- package/es/components/SidePanel/motion/variants.js +46 -0
- package/es/components/SingleAddSelect/SingleAddSelect.js +94 -0
- package/es/components/SingleAddSelect/index.js +8 -0
- package/es/components/StatusIcon/StatusIcon.js +345 -0
- package/es/components/StatusIcon/index.js +8 -0
- package/es/components/TagSet/TagSet.js +324 -0
- package/es/components/TagSet/TagSetModal.js +112 -0
- package/es/components/TagSet/TagSetOverflow.js +123 -0
- package/es/components/TagSet/constants.js +21 -0
- package/es/components/TagSet/index.js +8 -0
- package/es/components/Tearsheet/Tearsheet.js +190 -0
- package/es/components/Tearsheet/TearsheetNarrow.js +152 -0
- package/es/components/Tearsheet/TearsheetShell.js +405 -0
- package/es/components/Tearsheet/index.js +9 -0
- package/es/components/Toolbar/Toolbar.js +102 -0
- package/es/components/Toolbar/ToolbarButton.js +57 -0
- package/es/components/Toolbar/ToolbarGroup.js +35 -0
- package/es/components/Toolbar/index.js +10 -0
- package/es/components/UserProfileImage/UserProfileImage.js +187 -0
- package/es/components/UserProfileImage/index.js +10 -0
- package/es/components/WebTerminal/WebTerminal.js +205 -0
- package/es/components/WebTerminal/WebTerminalContentWrapper.js +50 -0
- package/es/components/WebTerminal/hooks/index.js +52 -0
- package/es/components/WebTerminal/index.js +10 -0
- package/es/components/WebTerminal/preview-components/Navigation.js +37 -0
- package/es/components/WebTerminal/preview-components/documentationLinks.js +32 -0
- package/es/components/WebTerminal/preview-components/index.js +12 -0
- package/es/components/_Canary/Canary.js +48 -0
- package/es/components/_Canary/index.js +8 -0
- package/es/components/index.js +44 -0
- package/es/global/js/hooks/index.js +18 -0
- package/es/global/js/hooks/useActiveElement.js +25 -0
- package/es/global/js/hooks/useClickOutside.js +21 -0
- package/es/global/js/hooks/useControllableState.js +74 -0
- package/es/global/js/hooks/useCreateComponentFocus.js +55 -0
- package/es/global/js/hooks/useCreateComponentStepChange.js +203 -0
- package/es/global/js/hooks/usePreviousValue.js +20 -0
- package/es/global/js/hooks/useResetCreateComponent.js +48 -0
- package/es/global/js/hooks/useResizeObserver.js +74 -0
- package/es/global/js/hooks/useRetrieveStepData.js +48 -0
- package/es/global/js/hooks/useValidCreateStepCount.js +21 -0
- package/es/global/js/hooks/useWindowResize.js +66 -0
- package/es/global/js/hooks/useWindowScroll.js +77 -0
- package/es/global/js/package-settings.js +197 -0
- package/es/global/js/utils/ClickListener.js +65 -0
- package/es/global/js/utils/DisplayBox.js +32 -0
- package/es/global/js/utils/Wrap.js +84 -0
- package/es/global/js/utils/deepCloneObject.js +23 -0
- package/es/global/js/utils/devtools.js +17 -0
- package/es/global/js/utils/getBezierValues.js +19 -0
- package/es/global/js/utils/getFocusableElements.js +14 -0
- package/es/global/js/utils/getNumberOfHiddenSteps.js +19 -0
- package/es/global/js/utils/getScrollbarWidth.js +15 -0
- package/es/global/js/utils/keyboardNavigation.js +36 -0
- package/es/global/js/utils/lastIndexInArray.js +24 -0
- package/es/global/js/utils/motionConstants.js +44 -0
- package/es/global/js/utils/pconsole.js +34 -0
- package/es/global/js/utils/props-helper.js +256 -0
- package/es/global/js/utils/rangeWithCallback.js +14 -0
- package/es/global/js/utils/scrollableAncestor.js +38 -0
- package/es/global/js/utils/story-helper.js +108 -0
- package/es/global/js/utils/test-helper.js +309 -0
- package/es/global/js/utils/unwrap-if-fragment.js +63 -0
- package/es/global/js/utils/uuidv4.js +11 -0
- package/es/global/js/utils/uuidv4.spec.js +27 -0
- package/es/global/js/utils/wait.js +8 -0
- package/es/global/js/utils/wrapFocus.js +68 -0
- package/es/index.js +9 -0
- package/es/settings.js +79 -0
- package/lib/components/APIKeyModal/APIKeyDownloader.js +102 -0
- package/lib/components/APIKeyModal/APIKeyModal.js +519 -0
- package/lib/components/APIKeyModal/index.js +12 -0
- package/lib/components/AboutModal/AboutModal.js +201 -0
- package/lib/components/AboutModal/index.js +12 -0
- package/lib/components/ActionBar/ActionBar.js +264 -0
- package/lib/components/ActionBar/ActionBarItem.js +99 -0
- package/lib/components/ActionBar/ActionBarOverflowItems.js +86 -0
- package/lib/components/ActionBar/index.js +19 -0
- package/lib/components/ActionSet/ActionSet.js +205 -0
- package/lib/components/ActionSet/actions.js +64 -0
- package/lib/components/ActionSet/index.js +12 -0
- package/lib/components/AddSelect/AddSelect.js +138 -0
- package/lib/components/AddSelect/AddSelectBody.js +377 -0
- package/lib/components/AddSelect/AddSelectBreadcrumbs.js +53 -0
- package/lib/components/AddSelect/AddSelectColumn.js +250 -0
- package/lib/components/AddSelect/AddSelectFilter.js +181 -0
- package/lib/components/AddSelect/AddSelectFormControl.js +90 -0
- package/lib/components/AddSelect/AddSelectList.js +61 -0
- package/lib/components/AddSelect/AddSelectMetaPanel.js +76 -0
- package/lib/components/AddSelect/AddSelectRow.js +217 -0
- package/lib/components/AddSelect/AddSelectSidebar.js +127 -0
- package/lib/components/AddSelect/AddSelectSort.js +85 -0
- package/lib/components/AddSelect/add-select-utils.js +138 -0
- package/lib/components/AddSelect/hooks/useFocus.js +39 -0
- package/lib/components/AddSelect/hooks/useItemSort.js +33 -0
- package/lib/components/AddSelect/hooks/useParentSelect.js +28 -0
- package/lib/components/AddSelect/hooks/usePath.js +78 -0
- package/lib/components/AddSelect/index.js +12 -0
- package/lib/components/BreadcrumbWithOverflow/BreadcrumbWithOverflow.js +342 -0
- package/lib/components/BreadcrumbWithOverflow/index.js +12 -0
- package/lib/components/ButtonMenu/ButtonMenu.js +133 -0
- package/lib/components/ButtonMenu/ButtonMenuItem.js +42 -0
- package/lib/components/ButtonMenu/index.js +19 -0
- package/lib/components/ButtonSetWithOverflow/ButtonSetWithOverflow.js +220 -0
- package/lib/components/ButtonSetWithOverflow/index.js +12 -0
- package/lib/components/Card/Card.js +273 -0
- package/lib/components/Card/CardFooter.js +87 -0
- package/lib/components/Card/CardHeader.js +82 -0
- package/lib/components/Card/index.js +26 -0
- package/lib/components/Cascade/Cascade.js +89 -0
- package/lib/components/Cascade/index.js +12 -0
- package/lib/components/ComboButton/ComboButton.js +110 -0
- package/lib/components/ComboButton/ComboButtonItem/index.js +36 -0
- package/lib/components/ComboButton/index.js +19 -0
- package/lib/components/CreateFullPage/CreateFullPage.js +298 -0
- package/lib/components/CreateFullPage/CreateFullPageStep.js +176 -0
- package/lib/components/CreateFullPage/index.js +19 -0
- package/lib/components/CreateInfluencer/CreateInfluencer.js +100 -0
- package/lib/components/CreateInfluencer/index.js +12 -0
- package/lib/components/CreateModal/CreateModal.js +143 -0
- package/lib/components/CreateModal/index.js +12 -0
- package/lib/components/CreateSidePanel/CreateSidePanel.js +160 -0
- package/lib/components/CreateSidePanel/index.js +12 -0
- package/lib/components/CreateTearsheet/CreateTearsheet.js +320 -0
- package/lib/components/CreateTearsheet/CreateTearsheetDivider.js +43 -0
- package/lib/components/CreateTearsheet/CreateTearsheetStep.js +184 -0
- package/lib/components/CreateTearsheet/index.js +26 -0
- package/lib/components/CreateTearsheet/preview-components/MultiStepTearsheet.js +294 -0
- package/lib/components/CreateTearsheet/preview-components/MultiStepWithIntro.js +291 -0
- package/lib/components/CreateTearsheetNarrow/CreateTearsheetNarrow.js +170 -0
- package/lib/components/CreateTearsheetNarrow/index.js +12 -0
- package/lib/components/DataSpreadsheet/DataSpreadsheet.js +891 -0
- package/lib/components/DataSpreadsheet/DataSpreadsheetBody.js +560 -0
- package/lib/components/DataSpreadsheet/DataSpreadsheetHeader.js +291 -0
- package/lib/components/DataSpreadsheet/hooks/index.js +54 -0
- package/lib/components/DataSpreadsheet/hooks/useMoveActiveCell.js +34 -0
- package/lib/components/DataSpreadsheet/hooks/useMultipleKeyTracking.js +127 -0
- package/lib/components/DataSpreadsheet/hooks/useResetSpreadsheetFocus.js +33 -0
- package/lib/components/DataSpreadsheet/hooks/useSpreadsheetEdit.js +110 -0
- package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseMove.js +64 -0
- package/lib/components/DataSpreadsheet/hooks/useSpreadsheetMouseUp.js +170 -0
- package/lib/components/DataSpreadsheet/hooks/useSpreadsheetOutsideClick.js +47 -0
- package/lib/components/DataSpreadsheet/index.js +12 -0
- package/lib/components/DataSpreadsheet/utils/checkActiveHeaderCell.js +37 -0
- package/lib/components/DataSpreadsheet/utils/checkSelectedHeaderCell.js +36 -0
- package/lib/components/DataSpreadsheet/utils/createActiveCellFn.js +61 -0
- package/lib/components/DataSpreadsheet/utils/createCellSelectionArea.js +71 -0
- package/lib/components/DataSpreadsheet/utils/generateData.js +60 -0
- package/lib/components/DataSpreadsheet/utils/getCellSize.js +32 -0
- package/lib/components/DataSpreadsheet/utils/getSelectionAreaPoints.js +26 -0
- package/lib/components/DataSpreadsheet/utils/getSpreadsheetWidth.js +41 -0
- package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionEnter.js +113 -0
- package/lib/components/DataSpreadsheet/utils/handleActiveCellInSelectionTab.js +105 -0
- package/lib/components/DataSpreadsheet/utils/handleCellDeletion.js +47 -0
- package/lib/components/DataSpreadsheet/utils/handleEditSubmit.js +85 -0
- package/lib/components/DataSpreadsheet/utils/handleHeaderCellSelection.js +166 -0
- package/lib/components/DataSpreadsheet/utils/handleMultipleKeys.js +267 -0
- package/lib/components/DataSpreadsheet/utils/moveColumnIndicatorLine.js +40 -0
- package/lib/components/DataSpreadsheet/utils/removeCellSelections.js +35 -0
- package/lib/components/DataSpreadsheet/utils/selectAllCells.js +55 -0
- package/lib/components/Datagrid/Datagrid/Datagrid.js +70 -0
- package/lib/components/Datagrid/Datagrid/DatagridBody.js +39 -0
- package/lib/components/Datagrid/Datagrid/DatagridContent.js +192 -0
- package/lib/components/Datagrid/Datagrid/DatagridEmptyBody.js +49 -0
- package/lib/components/Datagrid/Datagrid/DatagridExpandedRow.js +40 -0
- package/lib/components/Datagrid/Datagrid/DatagridHead.js +30 -0
- package/lib/components/Datagrid/Datagrid/DatagridHeaderRow.js +61 -0
- package/lib/components/Datagrid/Datagrid/DatagridRefBody.js +43 -0
- package/lib/components/Datagrid/Datagrid/DatagridRow.js +126 -0
- package/lib/components/Datagrid/Datagrid/DatagridSelectAll.js +72 -0
- package/lib/components/Datagrid/Datagrid/DatagridSelectAllWithToggle.js +150 -0
- package/lib/components/Datagrid/Datagrid/DatagridSimpleBody.js +39 -0
- package/lib/components/Datagrid/Datagrid/DatagridToolbar.js +153 -0
- package/lib/components/Datagrid/Datagrid/DatagridVirtualBody.js +119 -0
- package/lib/components/Datagrid/Datagrid/DraggableElement.js +189 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Actions.js +50 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/ButtonWrapper.js +62 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/Columns.js +125 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/CustomizeColumnsTearsheet.js +184 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/DraggableItemsList.js +117 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/TearsheetWrapper.js +61 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/common.js +21 -0
- package/lib/components/Datagrid/Datagrid/addons/CustomizeColumns/index.js +20 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterFlyout.js +253 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterPanel.js +276 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/FilterProvider.js +96 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/constants.js +45 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/index.js +27 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useFilters.js +338 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useShouldDisableButtons.js +41 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/hooks/useSubscribeToEventEmitter.js +30 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/index.js +33 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/motion/variants.js +64 -0
- package/lib/components/Datagrid/Datagrid/addons/Filtering/utils.js +91 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/InlineEditButton.js +67 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditButton/index.js +12 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/InlineEditCell.js +498 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditCell/index.js +12 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/InlineEditContext.js +108 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/getCellIdAsObject.js +34 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/index.js +18 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/InlineEditContext/returnUpdatedActiveCell.js +40 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridFocus.js +25 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleGridKeyPress.js +234 -0
- package/lib/components/Datagrid/Datagrid/addons/InlineEdit/handleMultipleKeys.js +87 -0
- package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeDropdown.js +77 -0
- package/lib/components/Datagrid/Datagrid/addons/RowSize/RowSizeRadioGroup.js +116 -0
- package/lib/components/Datagrid/Datagrid/addons/RowSize/index.js +13 -0
- package/lib/components/Datagrid/Datagrid/index.js +12 -0
- package/lib/components/Datagrid/Datagrid.stories/CustomizeColumnStory.js +13 -0
- package/lib/components/Datagrid/Datagrid.stories/RowSizeDropdownStory.js +13 -0
- package/lib/components/Datagrid/Datagrid.stories/SelectAllWithToggleStory.js +13 -0
- package/lib/components/Datagrid/Datagrid.stories/StickyActionsColumnStory.js +103 -0
- package/lib/components/Datagrid/Datagrid.stories/common.js +200 -0
- package/lib/components/Datagrid/Datagrid.stories/index.js +34 -0
- package/lib/components/Datagrid/common-column-ids.js +16 -0
- package/lib/components/Datagrid/index.js +153 -0
- package/lib/components/Datagrid/useActionsColumn.js +150 -0
- package/lib/components/Datagrid/useColumnCenterAlign.js +51 -0
- package/lib/components/Datagrid/useColumnOrder.js +15 -0
- package/lib/components/Datagrid/useColumnRightAlign.js +51 -0
- package/lib/components/Datagrid/useCustomizeColumns.js +53 -0
- package/lib/components/Datagrid/useDatagrid.js +44 -0
- package/lib/components/Datagrid/useDefaultStringRenderer.js +49 -0
- package/lib/components/Datagrid/useDisableSelectRows.js +87 -0
- package/lib/components/Datagrid/useEditableCell.js +20 -0
- package/lib/components/Datagrid/useExpandedRow.js +52 -0
- package/lib/components/Datagrid/useFiltering.js +101 -0
- package/lib/components/Datagrid/useFlexResize.js +52 -0
- package/lib/components/Datagrid/useFloatingScroll.js +84 -0
- package/lib/components/Datagrid/useInfiniteScroll.js +61 -0
- package/lib/components/Datagrid/useInlineEdit.js +82 -0
- package/lib/components/Datagrid/useNestedRowExpander.js +50 -0
- package/lib/components/Datagrid/useNestedRows.js +66 -0
- package/lib/components/Datagrid/useOnRowClick.js +54 -0
- package/lib/components/Datagrid/useParentDimensions.js +66 -0
- package/lib/components/Datagrid/useResizeTable.js +42 -0
- package/lib/components/Datagrid/useRowExpander.js +50 -0
- package/lib/components/Datagrid/useRowIsMouseOver.js +58 -0
- package/lib/components/Datagrid/useRowRenderer.js +34 -0
- package/lib/components/Datagrid/useRowSize.js +61 -0
- package/lib/components/Datagrid/useSelectAllToggle.js +102 -0
- package/lib/components/Datagrid/useSelectRows.js +126 -0
- package/lib/components/Datagrid/useSkeletonRows.js +35 -0
- package/lib/components/Datagrid/useSortableColumns.js +121 -0
- package/lib/components/Datagrid/useStickyColumn.js +188 -0
- package/lib/components/Datagrid/utils/DatagridActions.js +250 -0
- package/lib/components/Datagrid/utils/DatagridPagination.js +40 -0
- package/lib/components/Datagrid/utils/Wrapper.js +29 -0
- package/lib/components/Datagrid/utils/getArgTypes.js +102 -0
- package/lib/components/Datagrid/utils/getAutoSizedColumnWidth.js +35 -0
- package/lib/components/Datagrid/utils/getInlineEditColumns.js +166 -0
- package/lib/components/Datagrid/utils/makeData.js +201 -0
- package/lib/components/EditFullPage/EditFullPage.js +89 -0
- package/lib/components/EditFullPage/index.js +12 -0
- package/lib/components/EditInPlace/EditInPlace.js +312 -0
- package/lib/components/EditInPlace/index.js +12 -0
- package/lib/components/EditSidePanel/EditSidePanel.js +193 -0
- package/lib/components/EditSidePanel/index.js +12 -0
- package/lib/components/EditTearsheet/EditTearsheet.js +207 -0
- package/lib/components/EditTearsheet/EditTearsheetForm.js +109 -0
- package/lib/components/EditTearsheet/index.js +19 -0
- package/lib/components/EditTearsheet/preview-components/MultiFormEditTearsheet.js +229 -0
- package/lib/components/EditTearsheetNarrow/EditTearsheetNarrow.js +89 -0
- package/lib/components/EditTearsheetNarrow/index.js +12 -0
- package/lib/components/EditUpdateCards/EditUpdateCards.js +146 -0
- package/lib/components/EditUpdateCards/index.js +12 -0
- package/lib/components/EmptyStates/EmptyState.js +122 -0
- package/lib/components/EmptyStates/EmptyStateContent.js +89 -0
- package/lib/components/EmptyStates/ErrorEmptyState/ErrorEmptyState.js +116 -0
- package/lib/components/EmptyStates/ErrorEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/NoDataEmptyState/NoDataEmptyState.js +116 -0
- package/lib/components/EmptyStates/NoDataEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/NoTagsEmptyState/NoTagsEmptyState.js +116 -0
- package/lib/components/EmptyStates/NoTagsEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/NotFoundEmptyState/NotFoundEmptyState.js +116 -0
- package/lib/components/EmptyStates/NotFoundEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/NotificationsEmptyState/NotificationsEmptyState.js +116 -0
- package/lib/components/EmptyStates/NotificationsEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/UnauthorizedEmptyState/UnauthorizedEmptyState.js +116 -0
- package/lib/components/EmptyStates/UnauthorizedEmptyState/index.js +12 -0
- package/lib/components/EmptyStates/assets/ErrorIllustration.js +223 -0
- package/lib/components/EmptyStates/assets/NoDataIllustration.js +186 -0
- package/lib/components/EmptyStates/assets/NoTagsIllustration.js +494 -0
- package/lib/components/EmptyStates/assets/NotFoundIllustration.js +371 -0
- package/lib/components/EmptyStates/assets/NotificationsIllustration.js +342 -0
- package/lib/components/EmptyStates/assets/UnauthorizedIllustration.js +315 -0
- package/lib/components/EmptyStates/index.js +54 -0
- package/lib/components/ExampleComponent/ExampleComponent.js +188 -0
- package/lib/components/ExampleComponent/ExampleDeprecatedComponent.js +36 -0
- package/lib/components/ExampleComponent/index.js +12 -0
- package/lib/components/ExampleComponent/useExample.js +58 -0
- package/lib/components/ExportModal/ExportModal.js +287 -0
- package/lib/components/ExportModal/index.js +12 -0
- package/lib/components/ExpressiveCard/ExpressiveCard.js +125 -0
- package/lib/components/ExpressiveCard/index.js +12 -0
- package/lib/components/FilterSummary/FilterSummary.js +63 -0
- package/lib/components/FilterSummary/index.js +13 -0
- package/lib/components/HTTPErrors/HTTPError403/HTTPError403.js +90 -0
- package/lib/components/HTTPErrors/HTTPError403/index.js +12 -0
- package/lib/components/HTTPErrors/HTTPError404/HTTPError404.js +90 -0
- package/lib/components/HTTPErrors/HTTPError404/index.js +12 -0
- package/lib/components/HTTPErrors/HTTPErrorContent.js +83 -0
- package/lib/components/HTTPErrors/HTTPErrorOther/HTTPErrorOther.js +90 -0
- package/lib/components/HTTPErrors/HTTPErrorOther/index.js +12 -0
- package/lib/components/HTTPErrors/assets/HTTPErrorSvg403.js +1249 -0
- package/lib/components/HTTPErrors/assets/HTTPErrorSvg404.js +1048 -0
- package/lib/components/HTTPErrors/assets/HTTPErrorSvgOther.js +1099 -0
- package/lib/components/HTTPErrors/index.js +26 -0
- package/lib/components/ImportModal/ImportModal.js +392 -0
- package/lib/components/ImportModal/index.js +12 -0
- package/lib/components/MultiAddSelect/MultiAddSelect.js +159 -0
- package/lib/components/MultiAddSelect/index.js +12 -0
- package/lib/components/NotificationsPanel/NotificationsPanel.js +562 -0
- package/lib/components/NotificationsPanel/NotificationsPanel_data.js +143 -0
- package/lib/components/NotificationsPanel/index.js +12 -0
- package/lib/components/NotificationsPanel/preview-components/UnreadNotificationBell.js +55 -0
- package/lib/components/NotificationsPanel/utils.js +57 -0
- package/lib/components/OptionsTile/OptionsTile.js +334 -0
- package/lib/components/OptionsTile/index.js +12 -0
- package/lib/components/PageHeader/PageHeader.js +775 -0
- package/lib/components/PageHeader/PageHeaderDemo.data.js +620 -0
- package/lib/components/PageHeader/PageHeaderTitle.js +129 -0
- package/lib/components/PageHeader/PageHeaderUtils.js +188 -0
- package/lib/components/PageHeader/index.js +12 -0
- package/lib/components/ProductiveCard/ProductiveCard.js +132 -0
- package/lib/components/ProductiveCard/index.js +12 -0
- package/lib/components/RemoveModal/RemoveModal.js +192 -0
- package/lib/components/RemoveModal/index.js +12 -0
- package/lib/components/Saving/Saving.js +169 -0
- package/lib/components/Saving/index.js +12 -0
- package/lib/components/SidePanel/SidePanel.js +638 -0
- package/lib/components/SidePanel/constants.js +21 -0
- package/lib/components/SidePanel/index.js +12 -0
- package/lib/components/SidePanel/motion/variants.js +54 -0
- package/lib/components/SingleAddSelect/SingleAddSelect.js +105 -0
- package/lib/components/SingleAddSelect/index.js +12 -0
- package/lib/components/StatusIcon/StatusIcon.js +356 -0
- package/lib/components/StatusIcon/index.js +12 -0
- package/lib/components/TagSet/TagSet.js +335 -0
- package/lib/components/TagSet/TagSetModal.js +121 -0
- package/lib/components/TagSet/TagSetOverflow.js +132 -0
- package/lib/components/TagSet/constants.js +28 -0
- package/lib/components/TagSet/index.js +12 -0
- package/lib/components/Tearsheet/Tearsheet.js +196 -0
- package/lib/components/Tearsheet/TearsheetNarrow.js +158 -0
- package/lib/components/Tearsheet/TearsheetShell.js +416 -0
- package/lib/components/Tearsheet/index.js +19 -0
- package/lib/components/Toolbar/Toolbar.js +114 -0
- package/lib/components/Toolbar/ToolbarButton.js +68 -0
- package/lib/components/Toolbar/ToolbarGroup.js +44 -0
- package/lib/components/Toolbar/index.js +26 -0
- package/lib/components/UserProfileImage/UserProfileImage.js +191 -0
- package/lib/components/UserProfileImage/index.js +12 -0
- package/lib/components/WebTerminal/WebTerminal.js +212 -0
- package/lib/components/WebTerminal/WebTerminalContentWrapper.js +55 -0
- package/lib/components/WebTerminal/hooks/index.js +64 -0
- package/lib/components/WebTerminal/index.js +32 -0
- package/lib/components/WebTerminal/preview-components/Navigation.js +45 -0
- package/lib/components/WebTerminal/preview-components/documentationLinks.js +39 -0
- package/lib/components/WebTerminal/preview-components/index.js +13 -0
- package/lib/components/_Canary/Canary.js +51 -0
- package/lib/components/_Canary/index.js +12 -0
- package/lib/components/index.js +486 -0
- package/lib/global/js/hooks/index.js +88 -0
- package/lib/global/js/hooks/useActiveElement.js +33 -0
- package/lib/global/js/hooks/useClickOutside.js +28 -0
- package/lib/global/js/hooks/useControllableState.js +80 -0
- package/lib/global/js/hooks/useCreateComponentFocus.js +62 -0
- package/lib/global/js/hooks/useCreateComponentStepChange.js +211 -0
- package/lib/global/js/hooks/usePreviousValue.js +26 -0
- package/lib/global/js/hooks/useResetCreateComponent.js +54 -0
- package/lib/global/js/hooks/useResizeObserver.js +83 -0
- package/lib/global/js/hooks/useRetrieveStepData.js +55 -0
- package/lib/global/js/hooks/useValidCreateStepCount.js +27 -0
- package/lib/global/js/hooks/useWindowResize.js +73 -0
- package/lib/global/js/hooks/useWindowScroll.js +86 -0
- package/lib/global/js/package-settings.js +203 -0
- package/lib/global/js/utils/ClickListener.js +76 -0
- package/lib/global/js/utils/DisplayBox.js +40 -0
- package/lib/global/js/utils/Wrap.js +89 -0
- package/lib/global/js/utils/deepCloneObject.js +31 -0
- package/lib/global/js/utils/devtools.js +26 -0
- package/lib/global/js/utils/getBezierValues.js +25 -0
- package/lib/global/js/utils/getFocusableElements.js +22 -0
- package/lib/global/js/utils/getNumberOfHiddenSteps.js +26 -0
- package/lib/global/js/utils/getScrollbarWidth.js +22 -0
- package/lib/global/js/utils/keyboardNavigation.js +46 -0
- package/lib/global/js/utils/lastIndexInArray.js +31 -0
- package/lib/global/js/utils/motionConstants.js +51 -0
- package/lib/global/js/utils/pconsole.js +47 -0
- package/lib/global/js/utils/props-helper.js +267 -0
- package/lib/global/js/utils/rangeWithCallback.js +21 -0
- package/lib/global/js/utils/scrollableAncestor.js +46 -0
- package/lib/global/js/utils/story-helper.js +120 -0
- package/lib/global/js/utils/test-helper.js +329 -0
- package/lib/global/js/utils/unwrap-if-fragment.js +70 -0
- package/lib/global/js/utils/uuidv4.js +18 -0
- package/lib/global/js/utils/uuidv4.spec.js +30 -0
- package/lib/global/js/utils/wait.js +15 -0
- package/lib/global/js/utils/wrapFocus.js +74 -0
- package/lib/index.js +27 -0
- package/lib/settings.js +88 -0
- package/package.json +3 -2
- package/scss/components/APIKeyModal/_api-key-modal.scss +52 -0
- package/scss/components/APIKeyModal/_carbon-imports.scss +15 -0
- package/scss/components/APIKeyModal/_index-with-carbon.scss +9 -0
- package/scss/components/APIKeyModal/_index.scss +10 -0
- package/scss/components/APIKeyModal/_storybook-styles.scss +35 -0
- package/scss/components/AboutModal/_about-modal.scss +95 -0
- package/scss/components/AboutModal/_carbon-imports.scss +11 -0
- package/scss/components/AboutModal/_index-with-carbon.scss +9 -0
- package/scss/components/AboutModal/_index.scss +8 -0
- package/scss/components/AboutModal/_storybook-styles.scss +29 -0
- package/scss/components/ActionBar/_action-bar.scss +51 -0
- package/scss/components/ActionBar/_carbon-imports.scss +11 -0
- package/scss/components/ActionBar/_index-with-carbon.scss +9 -0
- package/scss/components/ActionBar/_index.scss +8 -0
- package/scss/components/ActionBar/_storybook-styles.scss +8 -0
- package/scss/components/ActionSet/_action-set.scss +126 -0
- package/scss/components/ActionSet/_carbon-imports.scss +11 -0
- package/scss/components/ActionSet/_index-with-carbon.scss +9 -0
- package/scss/components/ActionSet/_index.scss +8 -0
- package/scss/components/ActionSet/_storybook-styles.scss +36 -0
- package/scss/components/AddSelect/_add-select.scss +462 -0
- package/scss/components/AddSelect/_carbon-imports.scss +19 -0
- package/scss/components/AddSelect/_index-with-carbon.scss +9 -0
- package/scss/components/AddSelect/_index.scss +10 -0
- package/scss/components/AddSelect/_storybook-styles.scss +6 -0
- package/scss/components/BreadcrumbWithOverflow/_breadcrumb-with-overflow.scss +97 -0
- package/scss/components/BreadcrumbWithOverflow/_carbon-imports.scss +12 -0
- package/scss/components/BreadcrumbWithOverflow/_index-with-carbon.scss +9 -0
- package/scss/components/BreadcrumbWithOverflow/_index.scss +8 -0
- package/scss/components/BreadcrumbWithOverflow/_storybook-styles.scss +8 -0
- package/scss/components/ButtonMenu/_button-menu.scss +29 -0
- package/scss/components/ButtonMenu/_carbon-imports.scss +9 -0
- package/scss/components/ButtonMenu/_index-with-carbon.scss +9 -0
- package/scss/components/ButtonMenu/_index.scss +8 -0
- package/scss/components/ButtonMenu/_storybook-styles.scss +6 -0
- package/scss/components/ButtonSetWithOverflow/_button-set-with-overflow.scss +42 -0
- package/scss/components/ButtonSetWithOverflow/_carbon-imports.scss +10 -0
- package/scss/components/ButtonSetWithOverflow/_index-with-carbon.scss +9 -0
- package/scss/components/ButtonSetWithOverflow/_index.scss +8 -0
- package/scss/components/ButtonSetWithOverflow/_storybook-styles.scss +8 -0
- package/scss/components/Card/_carbon-imports.scss +11 -0
- package/scss/components/Card/_card.scss +123 -0
- package/scss/components/Card/_index-with-carbon.scss +9 -0
- package/scss/components/Card/_index.scss +8 -0
- package/scss/components/Card/_storybook-styles.scss +12 -0
- package/scss/components/Cascade/_carbon-imports.scss +6 -0
- package/scss/components/Cascade/_cascade.scss +47 -0
- package/scss/components/Cascade/_index-with-carbon.scss +9 -0
- package/scss/components/Cascade/_index.scss +10 -0
- package/scss/components/Cascade/_storybook-styles.scss +33 -0
- package/scss/components/ComboButton/_carbon-imports.scss +11 -0
- package/scss/components/ComboButton/_combo-button.scss +76 -0
- package/scss/components/ComboButton/_index-with-carbon.scss +9 -0
- package/scss/components/ComboButton/_index.scss +10 -0
- package/scss/components/CreateFullPage/_carbon-imports.scss +17 -0
- package/scss/components/CreateFullPage/_create-full-page.scss +169 -0
- package/scss/components/CreateFullPage/_index-with-carbon.scss +9 -0
- package/scss/components/CreateFullPage/_index.scss +8 -0
- package/scss/components/CreateFullPage/_storybook-styles.scss +67 -0
- package/scss/components/CreateInfluencer/_carbon-imports.scss +10 -0
- package/scss/components/CreateInfluencer/_create-influencer.scss +86 -0
- package/scss/components/CreateInfluencer/_index-with-carbon.scss +9 -0
- package/scss/components/CreateInfluencer/_index.scss +8 -0
- package/scss/components/CreateModal/_carbon-imports.scss +12 -0
- package/scss/components/CreateModal/_create-modal.scss +81 -0
- package/scss/components/CreateModal/_index-with-carbon.scss +9 -0
- package/scss/components/CreateModal/_index.scss +8 -0
- package/scss/components/CreateModal/_storybook-styles.scss +54 -0
- package/scss/components/CreateSidePanel/_carbon-imports.scss +10 -0
- package/scss/components/CreateSidePanel/_create-side-panel.scss +93 -0
- package/scss/components/CreateSidePanel/_index-with-carbon.scss +9 -0
- package/scss/components/CreateSidePanel/_index.scss +8 -0
- package/scss/components/CreateSidePanel/_storybook-styles.scss +29 -0
- package/scss/components/CreateTearsheet/_carbon-imports.scss +10 -0
- package/scss/components/CreateTearsheet/_create-tearsheet.scss +158 -0
- package/scss/components/CreateTearsheet/_index-with-carbon.scss +9 -0
- package/scss/components/CreateTearsheet/_index.scss +8 -0
- package/scss/components/CreateTearsheet/_storybook-styles.scss +56 -0
- package/scss/components/CreateTearsheetNarrow/_carbon-imports.scss +10 -0
- package/scss/components/CreateTearsheetNarrow/_create-tearsheet-narrow.scss +61 -0
- package/scss/components/CreateTearsheetNarrow/_index-with-carbon.scss +9 -0
- package/scss/components/CreateTearsheetNarrow/_index.scss +8 -0
- package/scss/components/CreateTearsheetNarrow/_storybook-styles.scss +27 -0
- package/scss/components/DataSpreadsheet/_carbon-imports.scss +6 -0
- package/scss/components/DataSpreadsheet/_data-spreadsheet.scss +294 -0
- package/scss/components/DataSpreadsheet/_index-with-carbon.scss +9 -0
- package/scss/components/DataSpreadsheet/_index.scss +8 -0
- package/scss/components/DataSpreadsheet/_storybook-styles.scss +6 -0
- package/scss/components/Datagrid/_carbon-imports.scss +6 -0
- package/scss/components/Datagrid/_datagrid.scss +63 -0
- package/scss/components/Datagrid/_index-with-carbon.scss +9 -0
- package/scss/components/Datagrid/_index.scss +8 -0
- package/scss/components/Datagrid/_storybook-styles.scss +116 -0
- package/scss/components/Datagrid/styles/_datagrid.scss +634 -0
- package/scss/components/Datagrid/styles/_draggableElement.scss +92 -0
- package/scss/components/Datagrid/styles/_index.scss +22 -0
- package/scss/components/Datagrid/styles/_useActionsColumn.scss +39 -0
- package/scss/components/Datagrid/styles/_useColumnCenterAlign.scss +20 -0
- package/scss/components/Datagrid/styles/_useColumnRightAlign.scss +29 -0
- package/scss/components/Datagrid/styles/_useExpandedRow.scss +60 -0
- package/scss/components/Datagrid/styles/_useInlineEdit.scss +431 -0
- package/scss/components/Datagrid/styles/_useNestedRows.scss +71 -0
- package/scss/components/Datagrid/styles/_useNestedTable.scss +34 -0
- package/scss/components/Datagrid/styles/_useSelectAllToggle.scss +37 -0
- package/scss/components/Datagrid/styles/_useSortableColumns.scss +79 -0
- package/scss/components/Datagrid/styles/_useStickyColumn.scss +68 -0
- package/scss/components/Datagrid/styles/_variables.scss +10 -0
- package/scss/components/Datagrid/styles/addons/_CustomizeColumnsTearsheet.scss +82 -0
- package/scss/components/Datagrid/styles/addons/_FilterFlyout.scss +87 -0
- package/scss/components/Datagrid/styles/addons/_FilterPanel.scss +129 -0
- package/scss/components/Datagrid/styles/addons/_RowSizeDropdown.scss +45 -0
- package/scss/components/EditFullPage/_edit-full-page.scss +26 -0
- package/scss/components/EditFullPage/_index.scss +8 -0
- package/scss/components/EditFullPage/_storybook-styles.scss +10 -0
- package/scss/components/EditInPlace/_carbon-imports.scss +9 -0
- package/scss/components/EditInPlace/_edit-in-place.scss +164 -0
- package/scss/components/EditInPlace/_index-with-carbon.scss +9 -0
- package/scss/components/EditInPlace/_index.scss +10 -0
- package/scss/components/EditInPlace/_storybook-styles.scss +15 -0
- package/scss/components/EditSidePanel/_carbon-imports.scss +9 -0
- package/scss/components/EditSidePanel/_edit-side-panel.scss +66 -0
- package/scss/components/EditSidePanel/_index-with-carbon.scss +9 -0
- package/scss/components/EditSidePanel/_index.scss +8 -0
- package/scss/components/EditSidePanel/_storybook-styles.scss +29 -0
- package/scss/components/EditTearsheet/_edit-tearsheet.scss +136 -0
- package/scss/components/EditTearsheet/_index.scss +8 -0
- package/scss/components/EditTearsheet/_storybook-styles.scss +59 -0
- package/scss/components/EditTearsheetNarrow/_edit-tearsheet-narrow.scss +26 -0
- package/scss/components/EditTearsheetNarrow/_index.scss +8 -0
- package/scss/components/EditTearsheetNarrow/_storybook-styles.scss +10 -0
- package/scss/components/EditUpdateCards/_carbon-imports.scss +9 -0
- package/scss/components/EditUpdateCards/_edit-update-cards.scss +85 -0
- package/scss/components/EditUpdateCards/_index-with-carbon.scss +9 -0
- package/scss/components/EditUpdateCards/_index.scss +8 -0
- package/scss/components/EditUpdateCards/_storybook-styles.scss +55 -0
- package/scss/components/EmptyStates/_carbon-imports.scss +11 -0
- package/scss/components/EmptyStates/_empty-state.scss +82 -0
- package/scss/components/EmptyStates/_index-with-carbon.scss +9 -0
- package/scss/components/EmptyStates/_index.scss +8 -0
- package/scss/components/EmptyStates/_storybook-styles.scss +6 -0
- package/scss/components/ExampleComponent/_carbon-imports.scss +10 -0
- package/scss/components/ExampleComponent/_example-component.scss +28 -0
- package/scss/components/ExampleComponent/_index-with-carbon.scss +9 -0
- package/scss/components/ExampleComponent/_index.scss +8 -0
- package/scss/components/ExampleComponent/_storybook-styles.scss +6 -0
- package/scss/components/ExportModal/_carbon-imports.scss +16 -0
- package/scss/components/ExportModal/_export-modal.scss +46 -0
- package/scss/components/ExportModal/_index-with-carbon.scss +9 -0
- package/scss/components/ExportModal/_index.scss +10 -0
- package/scss/components/ExportModal/_storybook-styles.scss +6 -0
- package/scss/components/ExpressiveCard/_carbon-imports.scss +6 -0
- package/scss/components/ExpressiveCard/_expressive-card.scss +18 -0
- package/scss/components/ExpressiveCard/_index-with-carbon.scss +9 -0
- package/scss/components/ExpressiveCard/_index.scss +10 -0
- package/scss/components/ExpressiveCard/_storybook-styles.scss +26 -0
- package/scss/components/FilterSummary/_filter-summary.scss +21 -0
- package/scss/components/FilterSummary/_index.scss +10 -0
- package/scss/components/FilterSummary/_storybook-styles.scss +14 -0
- package/scss/components/HTTPErrors/_carbon-imports.scss +10 -0
- package/scss/components/HTTPErrors/_http-errors.scss +68 -0
- package/scss/components/HTTPErrors/_index-with-carbon.scss +9 -0
- package/scss/components/HTTPErrors/_index.scss +8 -0
- package/scss/components/HTTPErrors/_storybook-styles.scss +6 -0
- package/scss/components/ImportModal/_carbon-imports.scss +14 -0
- package/scss/components/ImportModal/_import-modal.scss +83 -0
- package/scss/components/ImportModal/_index-with-carbon.scss +9 -0
- package/scss/components/ImportModal/_index.scss +8 -0
- package/scss/components/ImportModal/_storybook-styles.scss +6 -0
- package/scss/components/MultiAddSelect/_carbon-imports.scss +6 -0
- package/scss/components/MultiAddSelect/_index-with-carbon.scss +9 -0
- package/scss/components/MultiAddSelect/_index.scss +8 -0
- package/scss/components/MultiAddSelect/_multi-add-select.scss +8 -0
- package/scss/components/MultiAddSelect/_storybook-styles.scss +6 -0
- package/scss/components/NotificationsPanel/_carbon-imports.scss +12 -0
- package/scss/components/NotificationsPanel/_index-with-carbon.scss +9 -0
- package/scss/components/NotificationsPanel/_index.scss +8 -0
- package/scss/components/NotificationsPanel/_notifications-panel.scss +294 -0
- package/scss/components/NotificationsPanel/_storybook-styles.scss +15 -0
- package/scss/components/OptionsTile/_carbon-imports.scss +10 -0
- package/scss/components/OptionsTile/_index-with-carbon.scss +9 -0
- package/scss/components/OptionsTile/_index.scss +8 -0
- package/scss/components/OptionsTile/_options-tile.scss +230 -0
- package/scss/components/OptionsTile/_storybook-styles.scss +29 -0
- package/scss/components/PageHeader/_carbon-imports.scss +13 -0
- package/scss/components/PageHeader/_index-with-carbon.scss +9 -0
- package/scss/components/PageHeader/_index.scss +10 -0
- package/scss/components/PageHeader/_page-header.scss +654 -0
- package/scss/components/PageHeader/_storybook-styles.scss +80 -0
- package/scss/components/ProductiveCard/_carbon-imports.scss +6 -0
- package/scss/components/ProductiveCard/_index-with-carbon.scss +9 -0
- package/scss/components/ProductiveCard/_index.scss +10 -0
- package/scss/components/ProductiveCard/_productive-card.scss +95 -0
- package/scss/components/ProductiveCard/_storybook-styles.scss +23 -0
- package/scss/components/RemoveModal/_carbon-imports.scss +12 -0
- package/scss/components/RemoveModal/_index-with-carbon.scss +9 -0
- package/scss/components/RemoveModal/_index.scss +10 -0
- package/scss/components/RemoveModal/_remove-modal.scss +27 -0
- package/scss/components/RemoveModal/_storybook-styles.scss +6 -0
- package/scss/components/Saving/_carbon-imports.scss +11 -0
- package/scss/components/Saving/_index-with-carbon.scss +9 -0
- package/scss/components/Saving/_index.scss +10 -0
- package/scss/components/Saving/_saving.scss +34 -0
- package/scss/components/Saving/_storybook-styles.scss +12 -0
- package/scss/components/SidePanel/_carbon-imports.scss +10 -0
- package/scss/components/SidePanel/_index-with-carbon.scss +9 -0
- package/scss/components/SidePanel/_index.scss +8 -0
- package/scss/components/SidePanel/_side-panel-variables.scss +14 -0
- package/scss/components/SidePanel/_side-panel.scss +450 -0
- package/scss/components/SidePanel/_storybook-styles.scss +45 -0
- package/scss/components/SingleAddSelect/_carbon-imports.scss +6 -0
- package/scss/components/SingleAddSelect/_index-with-carbon.scss +9 -0
- package/scss/components/SingleAddSelect/_index.scss +8 -0
- package/scss/components/SingleAddSelect/_single-add-select.scss +8 -0
- package/scss/components/SingleAddSelect/_storybook-styles.scss +6 -0
- package/scss/components/StatusIcon/_carbon-imports.scss +6 -0
- package/scss/components/StatusIcon/_index-with-carbon.scss +9 -0
- package/scss/components/StatusIcon/_index.scss +8 -0
- package/scss/components/StatusIcon/_status-icon.scss +145 -0
- package/scss/components/StatusIcon/_storybook-styles.scss +6 -0
- package/scss/components/TagSet/_carbon-imports.scss +14 -0
- package/scss/components/TagSet/_index-with-carbon.scss +9 -0
- package/scss/components/TagSet/_index.scss +8 -0
- package/scss/components/TagSet/_storybook-styles.scss +8 -0
- package/scss/components/TagSet/_tag-set.scss +180 -0
- package/scss/components/Tearsheet/_carbon-imports.scss +11 -0
- package/scss/components/Tearsheet/_index-with-carbon.scss +9 -0
- package/scss/components/Tearsheet/_index.scss +8 -0
- package/scss/components/Tearsheet/_storybook-styles.scss +25 -0
- package/scss/components/Tearsheet/_tearsheet.scss +336 -0
- package/scss/components/Toolbar/_carbon-imports.scss +8 -0
- package/scss/components/Toolbar/_index-with-carbon.scss +9 -0
- package/scss/components/Toolbar/_index.scss +8 -0
- package/scss/components/Toolbar/_toolbar.scss +75 -0
- package/scss/components/UserProfileImage/_carbon-imports.scss +10 -0
- package/scss/components/UserProfileImage/_color-map.scss +39 -0
- package/scss/components/UserProfileImage/_index-with-carbon.scss +9 -0
- package/scss/components/UserProfileImage/_index.scss +8 -0
- package/scss/components/UserProfileImage/_storybook.scss +6 -0
- package/scss/components/UserProfileImage/_user-profile-image.scss +155 -0
- package/scss/components/WebTerminal/_carbon-imports.scss +12 -0
- package/scss/components/WebTerminal/_index-with-carbon.scss +9 -0
- package/scss/components/WebTerminal/_index.scss +8 -0
- package/scss/components/WebTerminal/_storybook-styles.scss +36 -0
- package/scss/components/WebTerminal/_web-terminal.scss +94 -0
- package/scss/components/_Canary/_canary.scss +7 -0
- package/scss/components/_index-released-only-with-carbon.scss +37 -0
- package/scss/components/_index-released-only.scss +38 -0
- package/scss/components/_index-with-carbon.scss +47 -0
- package/scss/components/_index.scss +51 -0
- package/scss/config.scss +1 -0
- package/scss/global/styles/_display-box.scss +66 -0
- package/scss/global/styles/_imported-carbon-modules.scss +25 -0
- package/scss/global/styles/_mixins.scss +22 -0
- package/scss/global/styles/_project-settings.scss +10 -0
- package/scss/index-full-carbon.scss +10 -0
- package/scss/index-without-carbon-released-only.scss +12 -0
- package/scss/index-without-carbon.scss +12 -0
- package/scss/index.scss +10 -0
@@ -0,0 +1,164 @@
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
2
|
+
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
|
3
|
+
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; }
|
4
|
+
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; }
|
5
|
+
/**
|
6
|
+
* Copyright IBM Corp. 2022, 2022
|
7
|
+
*
|
8
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
9
|
+
* LICENSE file in the root directory of this source tree.
|
10
|
+
*/
|
11
|
+
|
12
|
+
import { useEffect } from 'react';
|
13
|
+
import { px } from '@carbon/layout';
|
14
|
+
import { pkg } from '../../../settings';
|
15
|
+
import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
|
16
|
+
export var useSpreadsheetMouseUp = function useSpreadsheetMouseUp(_ref) {
|
17
|
+
var currentMatcher = _ref.currentMatcher,
|
18
|
+
setSelectionAreas = _ref.setSelectionAreas,
|
19
|
+
setClickAndHoldActive = _ref.setClickAndHoldActive,
|
20
|
+
setValidStartingPoint = _ref.setValidStartingPoint,
|
21
|
+
validStartingPoint = _ref.validStartingPoint,
|
22
|
+
_ref$blockClass = _ref.blockClass,
|
23
|
+
blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
|
24
|
+
ref = _ref.ref,
|
25
|
+
setHeaderCellHoldActive = _ref.setHeaderCellHoldActive,
|
26
|
+
setColumnOrder = _ref.setColumnOrder,
|
27
|
+
visibleColumns = _ref.visibleColumns,
|
28
|
+
setActiveCellCoordinates = _ref.setActiveCellCoordinates,
|
29
|
+
activeCellCoordinates = _ref.activeCellCoordinates,
|
30
|
+
rows = _ref.rows,
|
31
|
+
defaultColumn = _ref.defaultColumn,
|
32
|
+
selectionAreas = _ref.selectionAreas;
|
33
|
+
useEffect(function () {
|
34
|
+
var handleMouseUp = function handleMouseUp(event) {
|
35
|
+
// Remove the cloned selection area on mouse up
|
36
|
+
if (!validStartingPoint) {
|
37
|
+
setHeaderCellHoldActive(false);
|
38
|
+
var selectionAreaCloneElement = ref.current.querySelector(".".concat(blockClass, "__selection-area--element-cloned"));
|
39
|
+
if (!selectionAreaCloneElement) {
|
40
|
+
return;
|
41
|
+
}
|
42
|
+
// Mouse up while a cloned selection area exists/a column is being reordered
|
43
|
+
if (selectionAreaCloneElement) {
|
44
|
+
var closestCell = event.target.closest(".".concat(blockClass, "--interactive-cell-element"));
|
45
|
+
var newColumnIndex = parseInt === null || parseInt === void 0 ? void 0 : parseInt(closestCell === null || closestCell === void 0 ? void 0 : closestCell.getAttribute('data-column-index'));
|
46
|
+
var originalColumnIndex = parseInt === null || parseInt === void 0 ? void 0 : parseInt(selectionAreaCloneElement === null || selectionAreaCloneElement === void 0 ? void 0 : selectionAreaCloneElement.getAttribute('data-column-index-original'));
|
47
|
+
var selectionAreaToClone = selectionAreas.filter(function (item) {
|
48
|
+
return (item === null || item === void 0 ? void 0 : item.matcher) === currentMatcher;
|
49
|
+
});
|
50
|
+
var selectionAreaIndexArray = selectionAreaToClone[0].header.selectedIndexList;
|
51
|
+
var columnToMoveToElement = ref.current.querySelector("[data-row-index=\"header\"][data-column-index=\"".concat(newColumnIndex, "\"]"));
|
52
|
+
// Mouse up element was not part of the spreadsheet component
|
53
|
+
if (!columnToMoveToElement) {
|
54
|
+
return;
|
55
|
+
}
|
56
|
+
var selectionAreaToMove = ref.current.querySelector("[data-matcher-id=\"".concat(currentMatcher, "\"]"));
|
57
|
+
var spreadsheetPosition = ref.current.getBoundingClientRect();
|
58
|
+
var listContainer = ref.current.querySelector(".".concat(blockClass, "__list--container"));
|
59
|
+
var leftScrollAmount = listContainer.scrollLeft;
|
60
|
+
var newIndexLessThanStarting = newColumnIndex < originalColumnIndex;
|
61
|
+
var newIndexGreater = newColumnIndex > originalColumnIndex;
|
62
|
+
var differenceBetweenOldNewIndex = newIndexGreater ? newColumnIndex - originalColumnIndex : originalColumnIndex - newColumnIndex;
|
63
|
+
setSelectionAreas(function (prev) {
|
64
|
+
var selectionAreaClone = deepCloneObject(prev);
|
65
|
+
if (originalColumnIndex === newColumnIndex) {
|
66
|
+
return prev;
|
67
|
+
}
|
68
|
+
var indexOfItemToUpdate = selectionAreaClone.findIndex(function (item) {
|
69
|
+
return item.matcher === currentMatcher;
|
70
|
+
});
|
71
|
+
if (indexOfItemToUpdate === -1) {
|
72
|
+
return prev;
|
73
|
+
}
|
74
|
+
if (!selectionAreaIndexArray.includes(newColumnIndex)) {
|
75
|
+
// We need to not add just the newColumnIndex, but an array of indexes
|
76
|
+
// if there are multiple columns
|
77
|
+
var newIndexArray = newIndexGreater ? selectionAreaIndexArray.map(function (num) {
|
78
|
+
return num + differenceBetweenOldNewIndex;
|
79
|
+
}) : selectionAreaIndexArray.map(function (num) {
|
80
|
+
return num - differenceBetweenOldNewIndex;
|
81
|
+
});
|
82
|
+
selectionAreaClone[indexOfItemToUpdate].header.selectedIndexList = newIndexArray;
|
83
|
+
selectionAreaClone[indexOfItemToUpdate].point1.column = Math.min.apply(Math, _toConsumableArray(newIndexArray));
|
84
|
+
selectionAreaClone[indexOfItemToUpdate].point2.column = Math.max.apply(Math, _toConsumableArray(newIndexArray));
|
85
|
+
}
|
86
|
+
return selectionAreaClone;
|
87
|
+
});
|
88
|
+
// Only reorder columns if the new index is _not_ part of the
|
89
|
+
// selectionAreaIndexArray, meaning the new placement is outside
|
90
|
+
// of the current selection area. Similarly, the active cell position
|
91
|
+
// should only be changed under the same condition.
|
92
|
+
if (!selectionAreaIndexArray.includes(newColumnIndex)) {
|
93
|
+
var deleteCount = selectionAreaIndexArray.length;
|
94
|
+
var startIndex = Math.min.apply(Math, _toConsumableArray(selectionAreaIndexArray));
|
95
|
+
var columnIdArray = visibleColumns.map(function (column) {
|
96
|
+
return column.id;
|
97
|
+
});
|
98
|
+
var columnIdArrayClone = _toConsumableArray(columnIdArray);
|
99
|
+
var getNewColumnOrder = function getNewColumnOrder() {
|
100
|
+
var newColumnList = [];
|
101
|
+
selectionAreaIndexArray.map(function (index) {
|
102
|
+
return newColumnList.push(columnIdArray[index]);
|
103
|
+
});
|
104
|
+
return newColumnList;
|
105
|
+
};
|
106
|
+
// Remove one element at the original index
|
107
|
+
columnIdArrayClone.splice(startIndex, deleteCount);
|
108
|
+
var originalPointIndex = selectionAreaIndexArray.findIndex(function (item) {
|
109
|
+
return item === originalColumnIndex;
|
110
|
+
});
|
111
|
+
var updatedNewIndexWithNewOrder = newColumnIndex - originalPointIndex;
|
112
|
+
// Add one element at the new index
|
113
|
+
columnIdArrayClone.splice.apply(columnIdArrayClone, [updatedNewIndexWithNewOrder, 0].concat(_toConsumableArray(getNewColumnOrder())));
|
114
|
+
setColumnOrder(columnIdArrayClone); // Function provided by useTable (react-table) hook to reorder columns
|
115
|
+
var newCellCoords = _objectSpread(_objectSpread({}, activeCellCoordinates), {}, {
|
116
|
+
column: newIndexGreater ? activeCellCoordinates.column + differenceBetweenOldNewIndex : activeCellCoordinates.column - differenceBetweenOldNewIndex
|
117
|
+
});
|
118
|
+
setActiveCellCoordinates(newCellCoords);
|
119
|
+
var firstSelectedHeader = Array.from(ref.current.querySelectorAll(".".concat(blockClass, "__th--selected-header")))[0];
|
120
|
+
var firstSelectedHeaderCoords = firstSelectedHeader.getBoundingClientRect();
|
121
|
+
var newRelativePosition = firstSelectedHeaderCoords.left - spreadsheetPosition.left + leftScrollAmount;
|
122
|
+
// console.log(firstSelectedHeaderCoords.left - spreadsheetPosition.left + leftScrollAmount);
|
123
|
+
var updatedSelectionAreaPlacement = newIndexLessThanStarting ? newRelativePosition : newColumnIndex === originalColumnIndex ? selectionAreaToMove.style.left : newRelativePosition;
|
124
|
+
selectionAreaToMove.style.left = px(updatedSelectionAreaPlacement);
|
125
|
+
}
|
126
|
+
// Remove the cloned column and indicator elements
|
127
|
+
var indicatorLineElement = ref.current.querySelector(".".concat(blockClass, "__reorder-indicator-line"));
|
128
|
+
indicatorLineElement === null || indicatorLineElement === void 0 ? void 0 : indicatorLineElement.remove();
|
129
|
+
selectionAreaCloneElement === null || selectionAreaCloneElement === void 0 ? void 0 : selectionAreaCloneElement.remove();
|
130
|
+
}
|
131
|
+
}
|
132
|
+
// Mouse up was on a spreadsheet body cell which is a valid
|
133
|
+
// start/end point for creating a selection area
|
134
|
+
if (validStartingPoint) {
|
135
|
+
setClickAndHoldActive(false);
|
136
|
+
setValidStartingPoint(false);
|
137
|
+
var cellButton = event.target.closest(".".concat(blockClass, "__body--td"));
|
138
|
+
if (cellButton) {
|
139
|
+
var endCellCoordinates = {
|
140
|
+
row: Number(cellButton.getAttribute('data-row-index')),
|
141
|
+
column: Number(cellButton.getAttribute('data-column-index'))
|
142
|
+
};
|
143
|
+
setSelectionAreas(function (prev) {
|
144
|
+
var selectionAreaClone = deepCloneObject(prev);
|
145
|
+
var indexOfItemToUpdate = selectionAreaClone.findIndex(function (item) {
|
146
|
+
return item.matcher === currentMatcher;
|
147
|
+
});
|
148
|
+
// No items in the array have an object that matches the value of currentMatcher
|
149
|
+
if (indexOfItemToUpdate === -1) {
|
150
|
+
return prev;
|
151
|
+
}
|
152
|
+
selectionAreaClone[indexOfItemToUpdate].point2 = endCellCoordinates;
|
153
|
+
selectionAreaClone[indexOfItemToUpdate].areaCreated = false;
|
154
|
+
return selectionAreaClone;
|
155
|
+
});
|
156
|
+
}
|
157
|
+
}
|
158
|
+
};
|
159
|
+
document.addEventListener('mouseup', handleMouseUp);
|
160
|
+
return function () {
|
161
|
+
document.removeEventListener('mouseup', handleMouseUp);
|
162
|
+
};
|
163
|
+
}, [blockClass, currentMatcher, setSelectionAreas, setClickAndHoldActive, setValidStartingPoint, validStartingPoint, ref, setHeaderCellHoldActive, setColumnOrder, visibleColumns, setActiveCellCoordinates, activeCellCoordinates, rows, defaultColumn, selectionAreas]);
|
164
|
+
};
|
@@ -0,0 +1,41 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { useEffect } from 'react';
|
9
|
+
import { pkg } from '../../../settings';
|
10
|
+
import { removeCellSelections } from '../utils/removeCellSelections';
|
11
|
+
|
12
|
+
// Click outside useEffect for spreadsheet
|
13
|
+
export var useSpreadsheetOutsideClick = function useSpreadsheetOutsideClick(_ref) {
|
14
|
+
var spreadsheetRef = _ref.spreadsheetRef,
|
15
|
+
_ref$blockClass = _ref.blockClass,
|
16
|
+
blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
|
17
|
+
setActiveCellCoordinates = _ref.setActiveCellCoordinates,
|
18
|
+
setSelectionAreas = _ref.setSelectionAreas,
|
19
|
+
removeActiveCell = _ref.removeActiveCell,
|
20
|
+
setContainerHasFocus = _ref.setContainerHasFocus,
|
21
|
+
removeCellEditor = _ref.removeCellEditor;
|
22
|
+
useEffect(function () {
|
23
|
+
var handleOutsideClick = function handleOutsideClick(event) {
|
24
|
+
if (!spreadsheetRef.current || spreadsheetRef.current.contains(event.target) || event.target.classList.contains("".concat(blockClass, "__active-cell--highlight")) || event.target.classList.contains("".concat(blockClass, "--interactive-cell-element"))) {
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
setActiveCellCoordinates(null);
|
28
|
+
setSelectionAreas([]);
|
29
|
+
removeActiveCell();
|
30
|
+
removeCellSelections({
|
31
|
+
spreadsheetRef: spreadsheetRef
|
32
|
+
});
|
33
|
+
setContainerHasFocus(false);
|
34
|
+
removeCellEditor();
|
35
|
+
};
|
36
|
+
document.addEventListener('click', handleOutsideClick);
|
37
|
+
return function () {
|
38
|
+
document.removeEventListener('click', handleOutsideClick);
|
39
|
+
};
|
40
|
+
}, [spreadsheetRef, removeActiveCell, blockClass, setActiveCellCoordinates, setContainerHasFocus, setSelectionAreas, removeCellEditor]);
|
41
|
+
};
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
|
2
|
+
/**
|
3
|
+
* Copyright IBM Corp. 2022, 2022
|
4
|
+
*
|
5
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
6
|
+
* LICENSE file in the root directory of this source tree.
|
7
|
+
*/
|
8
|
+
|
9
|
+
import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
|
10
|
+
|
11
|
+
// Determines if a row or column header cell should receive a highlight/active background color
|
12
|
+
// Check each object in selectionAreas and see if the headerIndex is between
|
13
|
+
// point1.row and point2.row, inclusive
|
14
|
+
export var checkActiveHeaderCell = function checkActiveHeaderCell(headerIndex, selectionAreas, headerType) {
|
15
|
+
var areasCloned = deepCloneObject(selectionAreas);
|
16
|
+
var activeRowIndexes = [];
|
17
|
+
areasCloned.forEach(function (area) {
|
18
|
+
var _area$point, _area$point2, _area$point3, _area$point4;
|
19
|
+
var greatestRowIndex = Math.max((_area$point = area.point1) === null || _area$point === void 0 ? void 0 : _area$point[headerType], (_area$point2 = area.point2) === null || _area$point2 === void 0 ? void 0 : _area$point2[headerType]);
|
20
|
+
var lowestRowIndex = Math.min((_area$point3 = area.point1) === null || _area$point3 === void 0 ? void 0 : _area$point3[headerType], (_area$point4 = area.point2) === null || _area$point4 === void 0 ? void 0 : _area$point4[headerType]);
|
21
|
+
for (var i = lowestRowIndex; i <= greatestRowIndex; i++) {
|
22
|
+
activeRowIndexes.push(i);
|
23
|
+
}
|
24
|
+
});
|
25
|
+
var activeRowIndexesNoDuplicates = _toConsumableArray(new Set(activeRowIndexes));
|
26
|
+
if (areasCloned !== null && areasCloned !== void 0 && areasCloned.length && activeRowIndexesNoDuplicates.includes(headerIndex)) {
|
27
|
+
return true;
|
28
|
+
}
|
29
|
+
return false;
|
30
|
+
};
|
@@ -0,0 +1,29 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
|
9
|
+
export var checkSelectedHeaderCell = function checkSelectedHeaderCell(headerIndex, selectionAreas, headerType, items) {
|
10
|
+
var areasCloned = deepCloneObject(selectionAreas);
|
11
|
+
var isSelectedHeader = areasCloned.some(function (area) {
|
12
|
+
var _area$point, _area$point2, _area$point3, _area$point4, _area$point5, _area$point6, _area$point7, _area$point8;
|
13
|
+
var oppositeType = headerType === 'column' ? 'row' : 'column';
|
14
|
+
var minOppositeSelection = Math.min(area === null || area === void 0 ? void 0 : (_area$point = area.point1) === null || _area$point === void 0 ? void 0 : _area$point[oppositeType], area === null || area === void 0 ? void 0 : (_area$point2 = area.point2) === null || _area$point2 === void 0 ? void 0 : _area$point2[oppositeType]);
|
15
|
+
var maxOppositeSelection = Math.max(area === null || area === void 0 ? void 0 : (_area$point3 = area.point1) === null || _area$point3 === void 0 ? void 0 : _area$point3[oppositeType], area === null || area === void 0 ? void 0 : (_area$point4 = area.point2) === null || _area$point4 === void 0 ? void 0 : _area$point4[oppositeType]);
|
16
|
+
var minSelection = Math.min(area === null || area === void 0 ? void 0 : (_area$point5 = area.point1) === null || _area$point5 === void 0 ? void 0 : _area$point5[headerType], area === null || area === void 0 ? void 0 : (_area$point6 = area.point2) === null || _area$point6 === void 0 ? void 0 : _area$point6[headerType]);
|
17
|
+
var maxSelection = Math.max(area === null || area === void 0 ? void 0 : (_area$point7 = area.point1) === null || _area$point7 === void 0 ? void 0 : _area$point7[headerType], area === null || area === void 0 ? void 0 : (_area$point8 = area.point2) === null || _area$point8 === void 0 ? void 0 : _area$point8[headerType]);
|
18
|
+
var isTrueSelectedState = (items === null || items === void 0 ? void 0 : items.length) - 1 === maxOppositeSelection && minOppositeSelection === 0;
|
19
|
+
// console.log({minSelection, maxSelection});
|
20
|
+
// Iterate over all columns included in the selection area
|
21
|
+
for (var i = minSelection; i <= maxSelection; i++) {
|
22
|
+
if (headerIndex === i && isTrueSelectedState) {
|
23
|
+
return true;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
return false;
|
27
|
+
});
|
28
|
+
return isSelectedHeader;
|
29
|
+
};
|
@@ -0,0 +1,54 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { px } from '@carbon/layout';
|
9
|
+
import { pkg } from '../../../settings';
|
10
|
+
export var createActiveCellFn = function createActiveCellFn(_ref) {
|
11
|
+
var placementElement = _ref.placementElement,
|
12
|
+
coords = _ref.coords,
|
13
|
+
_ref$addToHeader = _ref.addToHeader,
|
14
|
+
addToHeader = _ref$addToHeader === void 0 ? false : _ref$addToHeader,
|
15
|
+
contextRef = _ref.contextRef,
|
16
|
+
_ref$blockClass = _ref.blockClass,
|
17
|
+
blockClass = _ref$blockClass === void 0 ? "".concat(pkg.prefix, "--data-spreadsheet") : _ref$blockClass,
|
18
|
+
onActiveCellChange = _ref.onActiveCellChange,
|
19
|
+
activeCellValue = _ref.activeCellValue,
|
20
|
+
activeCellRef = _ref.activeCellRef,
|
21
|
+
cellEditorRef = _ref.cellEditorRef,
|
22
|
+
defaultColumn = _ref.defaultColumn;
|
23
|
+
if (!coords) {
|
24
|
+
return;
|
25
|
+
}
|
26
|
+
// If the active cell is in the column header row (very first), we need to append this element
|
27
|
+
// to `.${blockClass}__header--container`, otherwise it should be appended to `.${blockClass}__listContainer` firstElementChild
|
28
|
+
var point1Element = document.querySelector("[data-row-index=\"".concat(coords.row, "\"][data-column-index=\"").concat(coords.column, "\"]")) || document.querySelector(".".concat(blockClass, "__body--td")); // if we can't find the point1 element (this can happen in the case where a virtualized row is not present anymore in the DOM), we get the default height/width of the first body cell we find
|
29
|
+
var selectionAreaCellWidth = point1Element.offsetWidth;
|
30
|
+
var selectionAreaCellHeight = point1Element.offsetHeight;
|
31
|
+
var activeElementContainer = addToHeader ? contextRef === null || contextRef === void 0 ? void 0 : contextRef.current.querySelector(".".concat(blockClass, "__header--container")) : contextRef === null || contextRef === void 0 ? void 0 : contextRef.current.querySelector(".".concat(blockClass, "__list--container")).firstElementChild;
|
32
|
+
var relativePosition = {
|
33
|
+
top: placementElement ? placementElement.getBoundingClientRect().top - activeElementContainer.getBoundingClientRect().top : coords.row === 0 ? 0 : selectionAreaCellHeight * coords.row,
|
34
|
+
// calculate top value here if virtualized row is not in DOM
|
35
|
+
left: placementElement ? placementElement.getBoundingClientRect().left - activeElementContainer.getBoundingClientRect().left : coords.column === 0 ? 0 + (defaultColumn.rowHeaderWidth - 4) : selectionAreaCellWidth * coords.column + (defaultColumn.rowHeaderWidth - 4) // calculate left value here if virtualized row is not in DOM, accounting for row header cell width (including borders)
|
36
|
+
};
|
37
|
+
|
38
|
+
var activeCellButton = activeCellRef === null || activeCellRef === void 0 ? void 0 : activeCellRef.current;
|
39
|
+
activeCellButton.style.width = px(placementElement ? placementElement === null || placementElement === void 0 ? void 0 : placementElement.offsetWidth : selectionAreaCellWidth);
|
40
|
+
activeCellButton.style.height = px(placementElement ? placementElement === null || placementElement === void 0 ? void 0 : placementElement.offsetHeight : selectionAreaCellHeight);
|
41
|
+
activeCellButton.style.left = px(relativePosition.left);
|
42
|
+
activeCellButton.style.top = px(relativePosition.top);
|
43
|
+
activeCellButton.style.display = 'block';
|
44
|
+
activeCellButton.setAttribute('data-active-row-index', typeof (coords === null || coords === void 0 ? void 0 : coords.row) === 'number' ? coords.row : 'header');
|
45
|
+
activeCellButton.setAttribute('data-active-column-index', typeof (coords === null || coords === void 0 ? void 0 : coords.column) === 'number' ? coords.column : 'header');
|
46
|
+
activeElementContainer.appendChild(activeCellButton);
|
47
|
+
activeCellButton.focus();
|
48
|
+
if (!addToHeader) {
|
49
|
+
activeElementContainer.appendChild(cellEditorRef.current);
|
50
|
+
}
|
51
|
+
if (typeof (coords === null || coords === void 0 ? void 0 : coords.column) === 'number' && typeof (coords === null || coords === void 0 ? void 0 : coords.row) === 'number') {
|
52
|
+
onActiveCellChange === null || onActiveCellChange === void 0 ? void 0 : onActiveCellChange(activeCellValue);
|
53
|
+
}
|
54
|
+
};
|
@@ -0,0 +1,64 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { px } from '@carbon/layout';
|
9
|
+
import { deepCloneObject } from '../../../global/js/utils/deepCloneObject';
|
10
|
+
import { getSelectionAreaPoints } from './getSelectionAreaPoints';
|
11
|
+
export var createCellSelectionArea = function createCellSelectionArea(_ref) {
|
12
|
+
var ref = _ref.ref,
|
13
|
+
area = _ref.area,
|
14
|
+
blockClass = _ref.blockClass,
|
15
|
+
defaultColumn = _ref.defaultColumn,
|
16
|
+
selectionAreas = _ref.selectionAreas,
|
17
|
+
setSelectionAreas = _ref.setSelectionAreas,
|
18
|
+
setActiveCellInsideSelectionArea = _ref.setActiveCellInsideSelectionArea,
|
19
|
+
visibleColumns = _ref.visibleColumns;
|
20
|
+
var _getSelectionAreaPoin = getSelectionAreaPoints(area),
|
21
|
+
lowestColumnIndex = _getSelectionAreaPoin.lowestColumnIndex,
|
22
|
+
lowestRowIndex = _getSelectionAreaPoin.lowestRowIndex,
|
23
|
+
greatestColumnIndex = _getSelectionAreaPoin.greatestColumnIndex,
|
24
|
+
greatestRowIndex = _getSelectionAreaPoin.greatestRowIndex;
|
25
|
+
if (greatestRowIndex - lowestRowIndex > 0 || greatestColumnIndex - lowestColumnIndex > 0) {
|
26
|
+
setActiveCellInsideSelectionArea(true);
|
27
|
+
var activeCellElement = ref.current.querySelector(".".concat(blockClass, "__active-cell--highlight"));
|
28
|
+
activeCellElement.setAttribute('data-selection-id', area.matcher);
|
29
|
+
}
|
30
|
+
var selectionAreaVariableWidth = 0;
|
31
|
+
visibleColumns.forEach(function (item, index) {
|
32
|
+
if (index >= lowestColumnIndex && index <= greatestColumnIndex) {
|
33
|
+
selectionAreaVariableWidth += (item === null || item === void 0 ? void 0 : item.width) || (defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.width);
|
34
|
+
}
|
35
|
+
});
|
36
|
+
var point1Element = document.querySelector("[data-row-index=\"".concat(area.point1.row, "\"][data-column-index=\"").concat(area.point1.column, "\"]")) || document.querySelector(".".concat(blockClass, "__body--td")); // if we can't find the point1 element (this can happen in the case where a virtualized row is not present anymore in the DOM), we get the default height of the first body cell we find
|
37
|
+
|
38
|
+
var selectionAreaCellHeight = point1Element.offsetHeight;
|
39
|
+
var selectionAreaTotalHeight = selectionAreaCellHeight * (greatestRowIndex - lowestRowIndex + 1);
|
40
|
+
var bodyContainer = document.querySelector(".".concat(blockClass, "__list--container")).firstElementChild;
|
41
|
+
var placementElement = bodyContainer.querySelector("[data-row-index=\"".concat(lowestRowIndex, "\"][data-column-index=\"").concat(lowestColumnIndex, "\"]"));
|
42
|
+
var relativePosition = {
|
43
|
+
top: placementElement ? placementElement.getBoundingClientRect().top - bodyContainer.getBoundingClientRect().top : lowestRowIndex === 0 ? 0 : selectionAreaCellHeight * lowestRowIndex,
|
44
|
+
// calculate top value here if virtualized row is not in DOM
|
45
|
+
left: placementElement ? placementElement.getBoundingClientRect().left - bodyContainer.getBoundingClientRect().left : lowestColumnIndex === 0 ? 0 + (defaultColumn.rowHeaderWidth - 4) : defaultColumn.width * lowestColumnIndex + (defaultColumn.rowHeaderWidth - 4) // calculate left value here if virtualized row is not in DOM, accounting for row header cell width (including borders)
|
46
|
+
};
|
47
|
+
|
48
|
+
var selectionAreaElement = document.querySelector("[data-matcher-id=\"".concat(area.matcher, "\"]")) || document.createElement('div');
|
49
|
+
selectionAreaElement.classList.add("".concat(blockClass, "__selection-area--element"));
|
50
|
+
selectionAreaElement.setAttribute('data-matcher-id', area.matcher);
|
51
|
+
selectionAreaElement.style.width = px(selectionAreaVariableWidth);
|
52
|
+
selectionAreaElement.style.height = px(selectionAreaTotalHeight);
|
53
|
+
selectionAreaElement.style.left = px(relativePosition.left);
|
54
|
+
selectionAreaElement.style.top = px(relativePosition.top);
|
55
|
+
bodyContainer.appendChild(selectionAreaElement);
|
56
|
+
var selectionAreasClone = deepCloneObject(selectionAreas);
|
57
|
+
var indexOfCurrentArea = selectionAreasClone.findIndex(function (item) {
|
58
|
+
return item.matcher === area.matcher;
|
59
|
+
});
|
60
|
+
// We need to add another property to the selectionAreas object array to
|
61
|
+
// let us know if an area has been created for each item already, ie createdArea: true
|
62
|
+
selectionAreasClone[indexOfCurrentArea].areaCreated = true;
|
63
|
+
setSelectionAreas(selectionAreasClone);
|
64
|
+
};
|
@@ -0,0 +1,52 @@
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
2
|
+
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; }
|
3
|
+
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; }
|
4
|
+
/**
|
5
|
+
* Copyright IBM Corp. 2022, 2022
|
6
|
+
*
|
7
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
8
|
+
* LICENSE file in the root directory of this source tree.
|
9
|
+
*/
|
10
|
+
|
11
|
+
// cspell:disable
|
12
|
+
var pets = ['dog', 'cat', 'bird', 'lizard', 'frog', 'hamster', 'fish', 'rabbit', 'snake'];
|
13
|
+
var petNames = ['Bruno', 'Willow', 'Kona', 'Heidi', 'Rusty', 'Bonnie', 'Cash', 'Gucci', 'Brody', 'Emma', 'Loki', 'Angel', 'Astro', 'Sherman', 'Layla', 'Peanut', 'Grace', 'Mickey', 'Sasha', 'Finn', 'Tucker', 'Bear', 'Mocha', 'Roscoe'];
|
14
|
+
// cspell:enable
|
15
|
+
|
16
|
+
var range = function range(len) {
|
17
|
+
var arr = [];
|
18
|
+
for (var i = 0; i < len; i++) {
|
19
|
+
arr.push(i);
|
20
|
+
}
|
21
|
+
return arr;
|
22
|
+
};
|
23
|
+
var newPet = function newPet(extraColumns) {
|
24
|
+
var extraDataProps = extraColumns && {
|
25
|
+
ownerName: petNames[Math.floor(Math.random() * petNames.length)],
|
26
|
+
weight: Math.floor(Math.random() * 40)
|
27
|
+
};
|
28
|
+
var defaultPet = {
|
29
|
+
petType: pets[Math.floor(Math.random() * pets.length)],
|
30
|
+
firstName: petNames[Math.floor(Math.random() * petNames.length)],
|
31
|
+
age: Math.floor(Math.random() * 30),
|
32
|
+
visits: Math.floor(Math.random() * 40),
|
33
|
+
health: Math.floor(Math.random() * 100)
|
34
|
+
};
|
35
|
+
if (extraColumns) {
|
36
|
+
return _objectSpread(_objectSpread({}, defaultPet), extraDataProps);
|
37
|
+
}
|
38
|
+
return defaultPet;
|
39
|
+
};
|
40
|
+
export var generateData = function generateData(_ref) {
|
41
|
+
var rows = _ref.rows,
|
42
|
+
extraColumns = _ref.extraColumns;
|
43
|
+
var makeDataLevel = function makeDataLevel() {
|
44
|
+
var depth = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
|
45
|
+
var lens = [rows];
|
46
|
+
var len = lens[depth];
|
47
|
+
return range(len).map(function () {
|
48
|
+
return _objectSpread({}, newPet(extraColumns));
|
49
|
+
});
|
50
|
+
};
|
51
|
+
return makeDataLevel();
|
52
|
+
};
|
@@ -0,0 +1,25 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { baseFontSize, sizeXSmall as xs, sizeSmall as sm, sizeMedium as md, sizeLarge as lg } from '@carbon/layout';
|
9
|
+
var getSizeInPixels = function getSizeInPixels(carbonSize) {
|
10
|
+
return Number(carbonSize.replace('rem', '') * baseFontSize);
|
11
|
+
};
|
12
|
+
export var getCellSize = function getCellSize(cellSize) {
|
13
|
+
switch (cellSize) {
|
14
|
+
case 'xs':
|
15
|
+
return getSizeInPixels(xs);
|
16
|
+
case 'sm':
|
17
|
+
return getSizeInPixels(sm);
|
18
|
+
case 'md':
|
19
|
+
return getSizeInPixels(md);
|
20
|
+
case 'lg':
|
21
|
+
return getSizeInPixels(lg);
|
22
|
+
default:
|
23
|
+
return getSizeInPixels(sm);
|
24
|
+
}
|
25
|
+
};
|
@@ -0,0 +1,19 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
export var getSelectionAreaPoints = function getSelectionAreaPoints(area) {
|
9
|
+
var greatestRowIndex = Math.max(area.point1.row, area.point2.row);
|
10
|
+
var greatestColumnIndex = Math.max(area.point1.column, area.point2.column);
|
11
|
+
var lowestRowIndex = Math.min(area.point1.row, area.point2.row);
|
12
|
+
var lowestColumnIndex = Math.min(area.point1.column, area.point2.column);
|
13
|
+
return {
|
14
|
+
greatestRowIndex: greatestRowIndex,
|
15
|
+
greatestColumnIndex: greatestColumnIndex,
|
16
|
+
lowestColumnIndex: lowestColumnIndex,
|
17
|
+
lowestRowIndex: lowestRowIndex
|
18
|
+
};
|
19
|
+
};
|
@@ -0,0 +1,34 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2022, 2022
|
3
|
+
*
|
4
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
|
8
|
+
import { px } from '@carbon/layout';
|
9
|
+
export var getSpreadsheetWidth = function getSpreadsheetWidth(_ref) {
|
10
|
+
var type = _ref.type,
|
11
|
+
headerGroup = _ref.headerGroup,
|
12
|
+
scrollBarSizeValue = _ref.scrollBarSizeValue,
|
13
|
+
totalVisibleColumns = _ref.totalVisibleColumns,
|
14
|
+
defaultColumn = _ref.defaultColumn,
|
15
|
+
totalColumnsWidth = _ref.totalColumnsWidth,
|
16
|
+
visibleColumns = _ref.visibleColumns;
|
17
|
+
var additionalWidth = scrollBarSizeValue + defaultColumn.rowHeaderWidth;
|
18
|
+
if (!totalVisibleColumns) {
|
19
|
+
if (type === 'header') {
|
20
|
+
return px(parseInt(headerGroup.getHeaderGroupProps().style.width) + additionalWidth);
|
21
|
+
}
|
22
|
+
if (type !== 'header') {
|
23
|
+
return totalColumnsWidth + additionalWidth;
|
24
|
+
}
|
25
|
+
}
|
26
|
+
if (totalVisibleColumns) {
|
27
|
+
var totalVisibleColumnWidth = visibleColumns.map(function (item, index) {
|
28
|
+
return index <= totalVisibleColumns - 1 && ((item === null || item === void 0 ? void 0 : item.width) || (defaultColumn === null || defaultColumn === void 0 ? void 0 : defaultColumn.width));
|
29
|
+
}).reduce(function (prev, curr) {
|
30
|
+
return prev + curr;
|
31
|
+
}, 0);
|
32
|
+
return totalVisibleColumnWidth + additionalWidth;
|
33
|
+
}
|
34
|
+
};
|
@@ -0,0 +1,107 @@
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
2
|
+
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; }
|
3
|
+
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; }
|
4
|
+
/**
|
5
|
+
* Copyright IBM Corp. 2022, 2022
|
6
|
+
*
|
7
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
8
|
+
* LICENSE file in the root directory of this source tree.
|
9
|
+
*/
|
10
|
+
|
11
|
+
import { getSelectionAreaPoints } from './getSelectionAreaPoints';
|
12
|
+
export var handleActiveCellInSelectionEnter = function handleActiveCellInSelectionEnter(_ref) {
|
13
|
+
var activeCellInsideSelectionArea = _ref.activeCellInsideSelectionArea,
|
14
|
+
activeCellCoordinates = _ref.activeCellCoordinates,
|
15
|
+
activeCellRef = _ref.activeCellRef,
|
16
|
+
selectionAreas = _ref.selectionAreas,
|
17
|
+
updateActiveCellCoordinates = _ref.updateActiveCellCoordinates;
|
18
|
+
if (!activeCellInsideSelectionArea) {
|
19
|
+
return;
|
20
|
+
}
|
21
|
+
var activeCellSelectionId = activeCellRef.current.getAttribute('data-selection-id');
|
22
|
+
var activeCellIndexInSelectionAreas = selectionAreas.findIndex(function (item) {
|
23
|
+
return item.matcher === activeCellSelectionId;
|
24
|
+
});
|
25
|
+
var selectionAreaToNavigate = selectionAreas[activeCellIndexInSelectionAreas];
|
26
|
+
var _getSelectionAreaPoin = getSelectionAreaPoints(selectionAreaToNavigate),
|
27
|
+
lowestColumnIndex = _getSelectionAreaPoin.lowestColumnIndex,
|
28
|
+
lowestRowIndex = _getSelectionAreaPoin.lowestRowIndex,
|
29
|
+
greatestColumnIndex = _getSelectionAreaPoin.greatestColumnIndex,
|
30
|
+
greatestRowIndex = _getSelectionAreaPoin.greatestRowIndex;
|
31
|
+
// Move active cell down one row if possible
|
32
|
+
var coordinatesClone = _objectSpread({}, activeCellCoordinates);
|
33
|
+
if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) < greatestRowIndex) {
|
34
|
+
updateActiveCellCoordinates({
|
35
|
+
coords: coordinatesClone,
|
36
|
+
updatedValue: {
|
37
|
+
row: (coordinatesClone === null || coordinatesClone === void 0 ? void 0 : coordinatesClone.row) + 1
|
38
|
+
},
|
39
|
+
optOutOfSelectionAreaUpdate: true
|
40
|
+
});
|
41
|
+
}
|
42
|
+
// Move active cell to next column of selection area if it exists
|
43
|
+
// If not, find the next selection area and update active cell to
|
44
|
+
// be the first cell in that selection
|
45
|
+
if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.row) === greatestRowIndex) {
|
46
|
+
if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) < greatestColumnIndex) {
|
47
|
+
updateActiveCellCoordinates({
|
48
|
+
coords: coordinatesClone,
|
49
|
+
updatedValue: {
|
50
|
+
column: (coordinatesClone === null || coordinatesClone === void 0 ? void 0 : coordinatesClone.column) + 1,
|
51
|
+
row: lowestRowIndex
|
52
|
+
},
|
53
|
+
optOutOfSelectionAreaUpdate: true
|
54
|
+
});
|
55
|
+
}
|
56
|
+
// Move to next selection area if there is one, or back to
|
57
|
+
// the beginning of the current selection
|
58
|
+
if ((activeCellCoordinates === null || activeCellCoordinates === void 0 ? void 0 : activeCellCoordinates.column) === greatestColumnIndex) {
|
59
|
+
if (selectionAreas.length > 1) {
|
60
|
+
if (selectionAreas[activeCellIndexInSelectionAreas + 1]) {
|
61
|
+
// Update activeCellRef data-selection-id attribute to the matcher of the next selection area
|
62
|
+
activeCellRef.current.setAttribute('data-selection-id', selectionAreas[activeCellIndexInSelectionAreas + 1].matcher);
|
63
|
+
var nextSelectionArea = selectionAreas[activeCellIndexInSelectionAreas + 1];
|
64
|
+
var _getSelectionAreaPoin2 = getSelectionAreaPoints(nextSelectionArea),
|
65
|
+
_lowestColumnIndex = _getSelectionAreaPoin2.lowestColumnIndex,
|
66
|
+
_lowestRowIndex = _getSelectionAreaPoin2.lowestRowIndex;
|
67
|
+
updateActiveCellCoordinates({
|
68
|
+
coords: coordinatesClone,
|
69
|
+
updatedValue: {
|
70
|
+
column: _lowestColumnIndex,
|
71
|
+
row: _lowestRowIndex
|
72
|
+
},
|
73
|
+
optOutOfSelectionAreaUpdate: true
|
74
|
+
});
|
75
|
+
return;
|
76
|
+
} else {
|
77
|
+
// There are multiple selection areas and the active cell is in the last one
|
78
|
+
// So we need to move the active cell to the first cell in the first selection area
|
79
|
+
activeCellRef.current.setAttribute('data-selection-id', selectionAreas[0].matcher);
|
80
|
+
var firstSelectionArea = selectionAreas[0];
|
81
|
+
var _getSelectionAreaPoin3 = getSelectionAreaPoints(firstSelectionArea),
|
82
|
+
_lowestColumnIndex2 = _getSelectionAreaPoin3.lowestColumnIndex,
|
83
|
+
_lowestRowIndex2 = _getSelectionAreaPoin3.lowestRowIndex;
|
84
|
+
updateActiveCellCoordinates({
|
85
|
+
coords: coordinatesClone,
|
86
|
+
updatedValue: {
|
87
|
+
column: _lowestColumnIndex2,
|
88
|
+
row: _lowestRowIndex2
|
89
|
+
},
|
90
|
+
optOutOfSelectionAreaUpdate: true
|
91
|
+
});
|
92
|
+
}
|
93
|
+
}
|
94
|
+
// Only one selection area, go back to first cell in the selection
|
95
|
+
if (selectionAreas.length === 1) {
|
96
|
+
return updateActiveCellCoordinates({
|
97
|
+
coords: coordinatesClone,
|
98
|
+
updatedValue: {
|
99
|
+
column: lowestColumnIndex,
|
100
|
+
row: lowestRowIndex
|
101
|
+
},
|
102
|
+
optOutOfSelectionAreaUpdate: true
|
103
|
+
});
|
104
|
+
}
|
105
|
+
}
|
106
|
+
}
|
107
|
+
};
|