@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,405 @@
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
2
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
3
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
4
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
5
|
+
var _excluded = ["actions", "children", "className", "closeIconDescription", "description", "hasCloseIcon", "headerActions", "influencer", "influencerPosition", "influencerWidth", "label", "navigation", "onClose", "open", "selectorPrimaryFocus", "size", "portalTarget", "title", "verticalPosition"];
|
6
|
+
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; }
|
7
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
8
|
+
/**
|
9
|
+
* Copyright IBM Corp. 2020, 2023
|
10
|
+
*
|
11
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
12
|
+
* LICENSE file in the root directory of this source tree.
|
13
|
+
*/
|
14
|
+
|
15
|
+
// Import portions of React that are needed.
|
16
|
+
import React, { useEffect, useState, useRef } from 'react';
|
17
|
+
import { createPortal } from 'react-dom';
|
18
|
+
import { useResizeObserver } from '../../global/js/hooks/useResizeObserver';
|
19
|
+
|
20
|
+
// Other standard imports.
|
21
|
+
import PropTypes from 'prop-types';
|
22
|
+
import cx from 'classnames';
|
23
|
+
import { pkg } from '../../settings';
|
24
|
+
import pconsole from '../../global/js/utils/pconsole';
|
25
|
+
|
26
|
+
// Carbon and package components we use.
|
27
|
+
import { Button, ComposedModal, Layer, ModalHeader, ModalBody, usePrefix } from '@carbon/react';
|
28
|
+
import { ActionSet } from '../ActionSet';
|
29
|
+
import { Wrap } from '../../global/js/utils/Wrap';
|
30
|
+
|
31
|
+
// The block part of our conventional BEM class names (bc__E--M).
|
32
|
+
var bc = "".concat(pkg.prefix, "--tearsheet");
|
33
|
+
var componentName = 'TearsheetShell';
|
34
|
+
var maxDepth = 3;
|
35
|
+
|
36
|
+
// NOTE: the component SCSS is not imported here: it is rolled up separately.
|
37
|
+
|
38
|
+
// Global data structure to communicate the state of tearsheet stacking
|
39
|
+
// (i.e. when more than one tearsheet is open). Each tearsheet supplies a
|
40
|
+
// handler to be called whenever the stacking of the tearsheets changes, which
|
41
|
+
// happens when a tearsheet opens or closes. The 'open' array contains one
|
42
|
+
// handler per OPEN tearsheet ordered from lowest to highest in visual z-order.
|
43
|
+
// The 'all' array contains all the handlers for open and closed tearsheets.
|
44
|
+
var stack = {
|
45
|
+
open: [],
|
46
|
+
all: []
|
47
|
+
};
|
48
|
+
|
49
|
+
// these props are only applicable when size='wide'
|
50
|
+
export var tearsheetShellWideProps = ['headerActions', 'influencer', 'influencerPosition', 'influencerWidth', 'navigation'];
|
51
|
+
export var tearsheetIsPassive = function tearsheetIsPassive(actions) {
|
52
|
+
return !actions || !(actions !== null && actions !== void 0 && actions.length);
|
53
|
+
};
|
54
|
+
export var tearsheetHasCloseIcon = function tearsheetHasCloseIcon(actions, hasCloseIcon) {
|
55
|
+
return hasCloseIcon !== null && hasCloseIcon !== void 0 ? hasCloseIcon : tearsheetIsPassive(actions);
|
56
|
+
};
|
57
|
+
|
58
|
+
// TearSheetShell is used internally by TearSheet and TearSheetNarrow
|
59
|
+
export var TearsheetShell = /*#__PURE__*/React.forwardRef(function (_ref, ref) {
|
60
|
+
var actions = _ref.actions,
|
61
|
+
children = _ref.children,
|
62
|
+
className = _ref.className,
|
63
|
+
closeIconDescription = _ref.closeIconDescription,
|
64
|
+
description = _ref.description,
|
65
|
+
hasCloseIcon = _ref.hasCloseIcon,
|
66
|
+
headerActions = _ref.headerActions,
|
67
|
+
influencer = _ref.influencer,
|
68
|
+
influencerPosition = _ref.influencerPosition,
|
69
|
+
influencerWidth = _ref.influencerWidth,
|
70
|
+
label = _ref.label,
|
71
|
+
navigation = _ref.navigation,
|
72
|
+
onClose = _ref.onClose,
|
73
|
+
open = _ref.open,
|
74
|
+
selectorPrimaryFocus = _ref.selectorPrimaryFocus,
|
75
|
+
size = _ref.size,
|
76
|
+
portalTargetIn = _ref.portalTarget,
|
77
|
+
title = _ref.title,
|
78
|
+
verticalPosition = _ref.verticalPosition,
|
79
|
+
rest = _objectWithoutProperties(_ref, _excluded);
|
80
|
+
var carbonPrefix = usePrefix();
|
81
|
+
var bcModalHeader = "".concat(carbonPrefix, "--modal-header");
|
82
|
+
// node the modal tearsheet is hosted in
|
83
|
+
var _useState = useState(null),
|
84
|
+
_useState2 = _slicedToArray(_useState, 2),
|
85
|
+
portalTarget = _useState2[0],
|
86
|
+
setPortalTarget = _useState2[1];
|
87
|
+
useEffect(function () {
|
88
|
+
if (portalTargetIn) {
|
89
|
+
setPortalTarget(portalTargetIn);
|
90
|
+
} else {
|
91
|
+
if (pkg.isFeatureEnabled('default-portal-target-body')) {
|
92
|
+
setPortalTarget(document.body);
|
93
|
+
}
|
94
|
+
}
|
95
|
+
}, [portalTargetIn]);
|
96
|
+
var localRef = useRef();
|
97
|
+
var resizer = useRef(null);
|
98
|
+
var modalRef = ref || localRef;
|
99
|
+
var _useResizeObserver = useResizeObserver(resizer),
|
100
|
+
width = _useResizeObserver.width;
|
101
|
+
var wide = size === 'wide';
|
102
|
+
|
103
|
+
// Keep track of the stack depth and our position in it (1-based, 0=closed)
|
104
|
+
var _useState3 = useState(0),
|
105
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
106
|
+
depth = _useState4[0],
|
107
|
+
setDepth = _useState4[1];
|
108
|
+
var _useState5 = useState(0),
|
109
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
110
|
+
position = _useState6[0],
|
111
|
+
setPosition = _useState6[1];
|
112
|
+
|
113
|
+
// Keep a record of the previous value of depth.
|
114
|
+
var prevDepth = useRef();
|
115
|
+
useEffect(function () {
|
116
|
+
prevDepth.current = depth;
|
117
|
+
});
|
118
|
+
|
119
|
+
// A "passive" tearsheet is one with no navigation actions.
|
120
|
+
var isPassive = tearsheetIsPassive(actions);
|
121
|
+
var effectiveHasCloseIcon = tearsheetHasCloseIcon(actions, hasCloseIcon);
|
122
|
+
|
123
|
+
// Callback that will be called whenever the stacking order changes.
|
124
|
+
// position is 1-based with 0 indicating closed.
|
125
|
+
function handleStackChange(newDepth, newPosition) {
|
126
|
+
setDepth(newDepth);
|
127
|
+
setPosition(newPosition);
|
128
|
+
}
|
129
|
+
handleStackChange.checkFocus = function () {
|
130
|
+
// if we are now the topmost tearsheet, ensure we have focus
|
131
|
+
if (position === depth && modalRef.current && !modalRef.current.contains(document.activeElement)) {
|
132
|
+
handleStackChange.claimFocus();
|
133
|
+
}
|
134
|
+
};
|
135
|
+
|
136
|
+
// Callback to give the tearsheet the opportunity to claim focus
|
137
|
+
handleStackChange.claimFocus = function () {
|
138
|
+
var element = selectorPrimaryFocus ? modalRef.current.querySelector(selectorPrimaryFocus) : modalRef.current;
|
139
|
+
setTimeout(function () {
|
140
|
+
return element.focus();
|
141
|
+
}, 1);
|
142
|
+
};
|
143
|
+
useEffect(function () {
|
144
|
+
var notify = function notify() {
|
145
|
+
return stack.all.forEach(function (handler) {
|
146
|
+
handler(Math.min(stack.open.length, maxDepth), stack.open.indexOf(handler) + 1);
|
147
|
+
handler.checkFocus();
|
148
|
+
});
|
149
|
+
};
|
150
|
+
|
151
|
+
// Register this tearsheet's stack change callback/listener.
|
152
|
+
stack.all.push(handleStackChange);
|
153
|
+
|
154
|
+
// If the tearsheet is mounting with open=true or open is changing from
|
155
|
+
// false to true to open it then append its notification callback to
|
156
|
+
// the end of the stack array (as its ID), and call all the callbacks
|
157
|
+
// to notify all open tearsheets that the stacking has changed.
|
158
|
+
if (open) {
|
159
|
+
stack.open.push(handleStackChange);
|
160
|
+
notify();
|
161
|
+
}
|
162
|
+
|
163
|
+
// Cleanup function called whenever the tearsheet unmounts or the open
|
164
|
+
// prop changes value (in which case it is called prior to this hook
|
165
|
+
// being called again).
|
166
|
+
return function cleanup() {
|
167
|
+
// Remove the notification callback from the all handlers array.
|
168
|
+
stack.all.splice(stack.all.indexOf(handleStackChange), 1);
|
169
|
+
|
170
|
+
// Remove the notification callback from the open handlers array, if
|
171
|
+
// it's there, and notify all open tearsheets that the stacking has
|
172
|
+
// changed (only necessary if this tearsheet was open).
|
173
|
+
var openIndex = stack.open.indexOf(handleStackChange);
|
174
|
+
if (openIndex >= 0) {
|
175
|
+
stack.open.splice(openIndex, 1);
|
176
|
+
notify();
|
177
|
+
}
|
178
|
+
};
|
179
|
+
}, [open]);
|
180
|
+
function handleFocus() {
|
181
|
+
// If something within us is receiving focus but we are not the topmost
|
182
|
+
// stacked tearsheet, transfer focus to the topmost tearsheet instead
|
183
|
+
if (position < depth) {
|
184
|
+
stack.open[stack.open.length - 1].claimFocus();
|
185
|
+
}
|
186
|
+
}
|
187
|
+
if (position <= depth) {
|
188
|
+
var _cx, _ref2, _cx3, _cx5, _cx6;
|
189
|
+
// Include a modal header if and only if one or more of these is given.
|
190
|
+
// We can't use a Wrap for the ModalHeader because ComposedModal requires
|
191
|
+
// the direct child to be the ModalHeader instance.
|
192
|
+
var includeHeader = label || title || description || headerActions || navigation || effectiveHasCloseIcon;
|
193
|
+
|
194
|
+
// Include an ActionSet if and only if one or more actions is given.
|
195
|
+
var includeActions = actions && (actions === null || actions === void 0 ? void 0 : actions.length) > 0;
|
196
|
+
return (portalTarget ? createPortal : function (children) {
|
197
|
+
return children;
|
198
|
+
})( /*#__PURE__*/React.createElement(ComposedModal, _extends({}, rest, {
|
199
|
+
"aria-label": title,
|
200
|
+
className: cx(bc, className, (_cx = {}, _defineProperty(_cx, "".concat(bc, "--stacked-").concat(position, "-of-").concat(depth),
|
201
|
+
// Don't apply this on the initial open of a single tearsheet.
|
202
|
+
depth > 1 || depth === 1 && prevDepth.current > 1), _defineProperty(_cx, "".concat(bc, "--wide"), wide), _defineProperty(_cx, "".concat(bc, "--narrow"), !wide), _cx)),
|
203
|
+
style: (_ref2 = {}, _defineProperty(_ref2, "--".concat(bc, "--stacking-scale-factor-single"), (width - 32) / width), _defineProperty(_ref2, "--".concat(bc, "--stacking-scale-factor-double"), (width - 64) / width), _ref2),
|
204
|
+
containerClassName: cx("".concat(bc, "__container"), _defineProperty({}, "".concat(bc, "__container--lower"), verticalPosition === 'lower')),
|
205
|
+
onClose: onClose,
|
206
|
+
open: open,
|
207
|
+
selectorPrimaryFocus: selectorPrimaryFocus,
|
208
|
+
onFocus: handleFocus,
|
209
|
+
preventCloseOnClickOutside: !isPassive,
|
210
|
+
ref: modalRef,
|
211
|
+
selectorsFloatingMenus: [".".concat(carbonPrefix, "--overflow-menu-options"), ".".concat(carbonPrefix, "--tooltip"), '.flatpickr-calendar', ".".concat(bc, "__container")],
|
212
|
+
size: "sm"
|
213
|
+
}), includeHeader && /*#__PURE__*/React.createElement(ModalHeader, {
|
214
|
+
className: cx("".concat(bc, "__header"), (_cx3 = {}, _defineProperty(_cx3, "".concat(bc, "__header--with-close-icon"), effectiveHasCloseIcon), _defineProperty(_cx3, "".concat(bc, "__header--with-nav"), navigation), _cx3)),
|
215
|
+
closeClassName: cx(_defineProperty({}, "".concat(bc, "__header--no-close-icon"), !effectiveHasCloseIcon)),
|
216
|
+
closeModal: onClose,
|
217
|
+
iconDescription: closeIconDescription
|
218
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
219
|
+
className: "".concat(bc, "__header-content")
|
220
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
221
|
+
className: "".concat(bc, "__header-fields")
|
222
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
223
|
+
element: "h2",
|
224
|
+
className: "".concat(bcModalHeader, "__label")
|
225
|
+
}, label), /*#__PURE__*/React.createElement(Wrap, {
|
226
|
+
element: "h3",
|
227
|
+
className: cx("".concat(bcModalHeader, "__heading"), "".concat(bc, "__heading"))
|
228
|
+
}, title), /*#__PURE__*/React.createElement(Wrap, {
|
229
|
+
className: "".concat(bc, "__header-description")
|
230
|
+
}, description)), /*#__PURE__*/React.createElement(Wrap, {
|
231
|
+
className: "".concat(bc, "__header-actions")
|
232
|
+
}, headerActions)), /*#__PURE__*/React.createElement(Wrap, {
|
233
|
+
className: "".concat(bc, "__header-navigation")
|
234
|
+
}, navigation)), /*#__PURE__*/React.createElement(Wrap, {
|
235
|
+
element: ModalBody,
|
236
|
+
className: "".concat(bc, "__body")
|
237
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
238
|
+
className: cx((_cx5 = {}, _defineProperty(_cx5, "".concat(bc, "__influencer"), true), _defineProperty(_cx5, "".concat(bc, "__influencer--wide"), influencerWidth === 'wide'), _cx5)),
|
239
|
+
neverRender: influencerPosition === 'right'
|
240
|
+
}, influencer), /*#__PURE__*/React.createElement(Wrap, {
|
241
|
+
className: "".concat(bc, "__right")
|
242
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
243
|
+
className: "".concat(bc, "__main"),
|
244
|
+
alwaysRender: includeActions,
|
245
|
+
element: wide ? Layer : undefined
|
246
|
+
}, /*#__PURE__*/React.createElement(Wrap, {
|
247
|
+
className: "".concat(bc, "__content"),
|
248
|
+
alwaysRender: influencer && influencerPosition === 'right',
|
249
|
+
element: wide ? Layer : undefined
|
250
|
+
}, children), /*#__PURE__*/React.createElement(Wrap, {
|
251
|
+
className: cx((_cx6 = {}, _defineProperty(_cx6, "".concat(bc, "__influencer"), true), _defineProperty(_cx6, "".concat(bc, "__influencer--wide"), influencerWidth === 'wide'), _cx6)),
|
252
|
+
neverRender: influencerPosition !== 'right'
|
253
|
+
}, influencer)), includeActions && /*#__PURE__*/React.createElement(Wrap, {
|
254
|
+
className: "".concat(bc, "__button-container")
|
255
|
+
}, /*#__PURE__*/React.createElement(ActionSet, {
|
256
|
+
actions: actions,
|
257
|
+
buttonSize: wide ? '2xl' : null,
|
258
|
+
className: "".concat(bc, "__buttons"),
|
259
|
+
size: wide ? '2xl' : 'lg'
|
260
|
+
})))), /*#__PURE__*/React.createElement("div", {
|
261
|
+
className: "".concat(bc, "__resize-detector"),
|
262
|
+
ref: resizer
|
263
|
+
})), portalTarget);
|
264
|
+
} else {
|
265
|
+
pconsole.warn('Tearsheet not rendered: maximum stacking depth exceeded.');
|
266
|
+
return null;
|
267
|
+
}
|
268
|
+
});
|
269
|
+
|
270
|
+
// The display name of the component, used by React. Note that displayName
|
271
|
+
// is used in preference to relying on function.name.
|
272
|
+
TearsheetShell.displayName = componentName;
|
273
|
+
export var deprecatedProps = {
|
274
|
+
/**
|
275
|
+
* **Deprecated**
|
276
|
+
*
|
277
|
+
* The position of the top of tearsheet in the viewport. The 'normal'
|
278
|
+
* position is a short distance down from the top of the
|
279
|
+
* viewport, leaving room at the top for a global header bar to show through
|
280
|
+
* from below. The 'lower' position (the default) provides a little extra room at the top
|
281
|
+
* to allow an action bar navigation or breadcrumbs to also show through.
|
282
|
+
*/
|
283
|
+
verticalPosition: PropTypes.oneOf(['normal', 'lower'])
|
284
|
+
};
|
285
|
+
|
286
|
+
// The types and DocGen commentary for the component props,
|
287
|
+
// in alphabetical order (for consistency).
|
288
|
+
// See https://www.npmjs.com/package/prop-types#usage.
|
289
|
+
|
290
|
+
// Note that the descriptions here should be kept in sync with those for the
|
291
|
+
// corresponding props for Tearsheet and TearsheetNarrow components.
|
292
|
+
TearsheetShell.propTypes = _objectSpread({
|
293
|
+
/**
|
294
|
+
* The actions to be shown as buttons in the action area at the bottom of the
|
295
|
+
* tearsheet. Each action is specified as an object with optional fields
|
296
|
+
* 'label' to supply the button label, 'kind' to select the button kind (must
|
297
|
+
* be 'primary', 'secondary' or 'ghost'), 'loading' to display a loading
|
298
|
+
* indicator, and 'onClick' to receive notifications when the button is
|
299
|
+
* clicked. Additional fields in the object will be passed to the Button
|
300
|
+
* component, and these can include 'disabled', 'ref', 'className', and any
|
301
|
+
* other Button props. Any other fields in the object will be passed through
|
302
|
+
* to the button element as HTML attributes.
|
303
|
+
*
|
304
|
+
* See https://react.carbondesignsystem.com/?path=/docs/components-button--default#component-api
|
305
|
+
*/
|
306
|
+
actions: PropTypes.arrayOf(
|
307
|
+
// NB we don't include the validator here, as the component wrapping this
|
308
|
+
// one should ensure appropriate validation is done.
|
309
|
+
PropTypes.shape(_objectSpread(_objectSpread({}, Button.propTypes), {}, {
|
310
|
+
kind: PropTypes.oneOf(['ghost', 'danger--ghost', 'secondary', 'danger', 'primary']),
|
311
|
+
label: PropTypes.string,
|
312
|
+
loading: PropTypes.bool,
|
313
|
+
// we duplicate this Button prop to improve the DocGen here
|
314
|
+
onClick: Button.propTypes.onClick
|
315
|
+
}))),
|
316
|
+
/**
|
317
|
+
* The main content of the tearsheet.
|
318
|
+
*/
|
319
|
+
children: PropTypes.node,
|
320
|
+
/**
|
321
|
+
* An optional class or classes to be added to the outermost element.
|
322
|
+
*/
|
323
|
+
className: PropTypes.string,
|
324
|
+
/**
|
325
|
+
* The accessibility title for the close icon (if shown).
|
326
|
+
*
|
327
|
+
* **Note:** This prop is only required if a close icon is shown, i.e. if
|
328
|
+
* there are a no navigation actions and/or hasCloseIcon is true.
|
329
|
+
*/
|
330
|
+
closeIconDescription: PropTypes.string.isRequired.if(function (_ref3) {
|
331
|
+
var actions = _ref3.actions,
|
332
|
+
hasCloseIcon = _ref3.hasCloseIcon;
|
333
|
+
return tearsheetHasCloseIcon(actions, hasCloseIcon);
|
334
|
+
}),
|
335
|
+
/**
|
336
|
+
* A description of the flow, displayed in the header area of the tearsheet.
|
337
|
+
*/
|
338
|
+
description: PropTypes.node,
|
339
|
+
/**
|
340
|
+
* Enable a close icon ('x') in the header area of the tearsheet. By default,
|
341
|
+
* (when this prop is omitted, or undefined or null) a tearsheet does not
|
342
|
+
* display a close icon if there are navigation actions ("transactional
|
343
|
+
* tearsheet") and displays one if there are no navigation actions ("passive
|
344
|
+
* tearsheet"), and that behavior can be overridden if required by setting
|
345
|
+
* this prop to either true or false.
|
346
|
+
*/
|
347
|
+
hasCloseIcon: PropTypes.bool,
|
348
|
+
/**
|
349
|
+
* The content for the header actions area, displayed alongside the title in
|
350
|
+
* the header area of the tearsheet. This is typically a drop-down, or a set
|
351
|
+
* of small buttons, or similar. NB the headerActions is only applicable for
|
352
|
+
* wide tearsheets.
|
353
|
+
*/
|
354
|
+
headerActions: PropTypes.element,
|
355
|
+
/**
|
356
|
+
* The content for the influencer section of the tearsheet, displayed
|
357
|
+
* alongside the main content. This is typically a menu, or filter, or
|
358
|
+
* progress indicator, or similar. NB the influencer is only applicable for
|
359
|
+
* wide tearsheets.
|
360
|
+
*/
|
361
|
+
influencer: PropTypes.element,
|
362
|
+
/**
|
363
|
+
* The position of the influencer section, 'left' or 'right'.
|
364
|
+
*/
|
365
|
+
influencerPosition: PropTypes.oneOf(['left', 'right']),
|
366
|
+
/**
|
367
|
+
* The width of the influencer: 'narrow' (the default) is 256px, and 'wide'
|
368
|
+
* is 320px.
|
369
|
+
*/
|
370
|
+
influencerWidth: PropTypes.oneOf(['narrow', 'wide']),
|
371
|
+
/**
|
372
|
+
* A label for the tearsheet, displayed in the header area of the tearsheet
|
373
|
+
* to maintain context for the tearsheet (e.g. as the title changes from page
|
374
|
+
* to page of a multi-page task).
|
375
|
+
*/
|
376
|
+
label: PropTypes.node,
|
377
|
+
/**
|
378
|
+
* Navigation content, such as a set of tabs, to be displayed at the bottom
|
379
|
+
* of the header area of the tearsheet. NB the navigation is only applicable
|
380
|
+
* for wide tearsheets.
|
381
|
+
*/
|
382
|
+
navigation: PropTypes.element,
|
383
|
+
/**
|
384
|
+
* An optional handler that is called when the user closes the tearsheet (by
|
385
|
+
* clicking the close button, if enabled, or clicking outside, if enabled).
|
386
|
+
* Returning `false` here prevents the modal from closing.
|
387
|
+
*/
|
388
|
+
onClose: PropTypes.func,
|
389
|
+
/**
|
390
|
+
* Specifies whether the tearsheet is currently open.
|
391
|
+
*/
|
392
|
+
open: PropTypes.bool,
|
393
|
+
/**
|
394
|
+
* The DOM node the tearsheet should be rendered within. Defaults to document.body.
|
395
|
+
*/
|
396
|
+
portalTarget: PropTypes.node,
|
397
|
+
/**
|
398
|
+
* Specifies the width of the tearsheet, 'narrow' or 'wide'.
|
399
|
+
*/
|
400
|
+
size: PropTypes.oneOf(['narrow', 'wide']).isRequired,
|
401
|
+
/**
|
402
|
+
* The main title of the tearsheet, displayed in the header area.
|
403
|
+
*/
|
404
|
+
title: PropTypes.node
|
405
|
+
}, deprecatedProps);
|
@@ -0,0 +1,9 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2020, 2021
|
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 { Tearsheet } from './Tearsheet';
|
9
|
+
export { TearsheetNarrow } from './TearsheetNarrow';
|
@@ -0,0 +1,102 @@
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
2
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
3
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
4
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
5
|
+
var _excluded = ["children", "className", "vertical"];
|
6
|
+
/**
|
7
|
+
* Copyright IBM Corp. 2021, 2022
|
8
|
+
*
|
9
|
+
* This source code is licensed under the Apache-2.0 license found in the
|
10
|
+
* LICENSE file in the root directory of this source tree.
|
11
|
+
*/
|
12
|
+
|
13
|
+
import cx from 'classnames';
|
14
|
+
import { bool, node, string } from 'prop-types';
|
15
|
+
import React, { createContext, forwardRef, useCallback, useEffect, useRef, useState } from 'react';
|
16
|
+
import { getDevtoolsProps } from '../../global/js/utils/devtools';
|
17
|
+
import { getFocusableElements as _getFocusableElements } from '../../global/js/utils/getFocusableElements';
|
18
|
+
import { pkg } from '../../settings';
|
19
|
+
var checkComponentEnabled = pkg.checkComponentEnabled,
|
20
|
+
prefix = pkg.prefix;
|
21
|
+
var blockClass = "".concat(prefix, "--toolbar");
|
22
|
+
var ToolbarContext = /*#__PURE__*/createContext();
|
23
|
+
|
24
|
+
/** Toolbars are a collection of action items that organize a program’s interaction patterns into a series of closely related commands. */
|
25
|
+
var Toolbar = /*#__PURE__*/forwardRef(function (_ref2, r) {
|
26
|
+
var children = _ref2.children,
|
27
|
+
className = _ref2.className,
|
28
|
+
vertical = _ref2.vertical,
|
29
|
+
rest = _objectWithoutProperties(_ref2, _excluded);
|
30
|
+
var focusableElements = useRef();
|
31
|
+
var getFocusableElements = useCallback(function () {
|
32
|
+
return focusableElements.current;
|
33
|
+
}, [focusableElements]);
|
34
|
+
var _ref = useRef();
|
35
|
+
var ref = r || _ref;
|
36
|
+
var _useState = useState(),
|
37
|
+
_useState2 = _slicedToArray(_useState, 2),
|
38
|
+
focus = _useState2[0],
|
39
|
+
setFocus = _useState2[1];
|
40
|
+
useEffect(function () {
|
41
|
+
focusableElements.current = _getFocusableElements(ref.current);
|
42
|
+
typeof focus !== 'undefined' && getFocusableElements().forEach(function (element, index) {
|
43
|
+
element[index !== focus ? 'setAttribute' : 'removeAttribute']('tabindex', -1);
|
44
|
+
});
|
45
|
+
});
|
46
|
+
useEffect(function () {
|
47
|
+
typeof focus !== 'undefined' && getFocusableElements()[focus].focus();
|
48
|
+
}, [focus, getFocusableElements]);
|
49
|
+
var _ref3 = !vertical ? ['ArrowRight', 'ArrowLeft'] : ['ArrowDown', 'ArrowUp'],
|
50
|
+
_ref4 = _slicedToArray(_ref3, 2),
|
51
|
+
arrowNext = _ref4[0],
|
52
|
+
arrowPrevious = _ref4[1];
|
53
|
+
function onArrowDown(increment) {
|
54
|
+
var nextFocus = focus + increment;
|
55
|
+
getFocusableElements()[nextFocus] && setFocus(nextFocus);
|
56
|
+
}
|
57
|
+
function onFocus(_ref5) {
|
58
|
+
var target = _ref5.target;
|
59
|
+
var elements = getFocusableElements();
|
60
|
+
elements.includes(target) && setFocus(elements.indexOf(target));
|
61
|
+
}
|
62
|
+
function onKeyDown(_ref6) {
|
63
|
+
var key = _ref6.key,
|
64
|
+
target = _ref6.target;
|
65
|
+
if (getFocusableElements().includes(target)) {
|
66
|
+
switch (key) {
|
67
|
+
case arrowNext:
|
68
|
+
onArrowDown(1);
|
69
|
+
break;
|
70
|
+
case arrowPrevious:
|
71
|
+
onArrowDown(-1);
|
72
|
+
break;
|
73
|
+
}
|
74
|
+
}
|
75
|
+
}
|
76
|
+
return /*#__PURE__*/React.createElement("div", _extends({}, rest, {
|
77
|
+
ref: ref,
|
78
|
+
className: cx(blockClass, className, _defineProperty({}, "".concat(blockClass, "--vertical"), vertical)),
|
79
|
+
onFocus: onFocus,
|
80
|
+
onKeyDown: onKeyDown
|
81
|
+
}, vertical && {
|
82
|
+
'aria-orientation': 'vertical'
|
83
|
+
}, getDevtoolsProps(componentName), {
|
84
|
+
role: "toolbar"
|
85
|
+
}), /*#__PURE__*/React.createElement(ToolbarContext.Provider, {
|
86
|
+
value: {
|
87
|
+
vertical: vertical
|
88
|
+
}
|
89
|
+
}, children));
|
90
|
+
});
|
91
|
+
var componentName = 'Toolbar';
|
92
|
+
Toolbar.displayName = componentName;
|
93
|
+
Toolbar.propTypes = {
|
94
|
+
/** Provide the content of the `Toolbar` */
|
95
|
+
children: node.isRequired,
|
96
|
+
/** Provide an optional class to be applied to the containing node */
|
97
|
+
className: string,
|
98
|
+
/** Determines whether the `Toolbar` is rendered vertically */
|
99
|
+
vertical: bool
|
100
|
+
};
|
101
|
+
Toolbar = checkComponentEnabled(Toolbar, componentName);
|
102
|
+
export { blockClass, componentName, Toolbar, ToolbarContext };
|
@@ -0,0 +1,57 @@
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
2
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
3
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
4
|
+
var _excluded = ["caret", "children", "className", "renderIcon", "iconDescription"];
|
5
|
+
/**
|
6
|
+
* Copyright IBM Corp. 2021, 2021
|
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 { IconButton } from '@carbon/react';
|
13
|
+
import cx from 'classnames';
|
14
|
+
import { bool, func, node, string } from 'prop-types';
|
15
|
+
import React, { forwardRef, useContext } from 'react';
|
16
|
+
import { pkg } from '../../settings';
|
17
|
+
import { blockClass as toolbarClass, ToolbarContext } from './Toolbar';
|
18
|
+
export var blockClass = "".concat(toolbarClass, "__button");
|
19
|
+
|
20
|
+
/** Toolbar buttons are common functions performed as part of a products interface or an open window. */
|
21
|
+
export var ToolbarButton = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
22
|
+
var _useContext;
|
23
|
+
var caret = _ref.caret,
|
24
|
+
children = _ref.children,
|
25
|
+
className = _ref.className,
|
26
|
+
renderIcon = _ref.renderIcon,
|
27
|
+
_ref$iconDescription = _ref.iconDescription,
|
28
|
+
iconDescription = _ref$iconDescription === void 0 ? '' : _ref$iconDescription,
|
29
|
+
rest = _objectWithoutProperties(_ref, _excluded);
|
30
|
+
var Icon = renderIcon;
|
31
|
+
return /*#__PURE__*/React.createElement(IconButton, _extends({
|
32
|
+
align: ((_useContext = useContext(ToolbarContext)) === null || _useContext === void 0 ? void 0 : _useContext.vertical) && 'right'
|
33
|
+
}, rest, {
|
34
|
+
label: iconDescription,
|
35
|
+
ref: ref,
|
36
|
+
className: cx(className, _defineProperty({}, "".concat(blockClass, "--caret"), caret)),
|
37
|
+
kind: "ghost",
|
38
|
+
size: "md"
|
39
|
+
}), /*#__PURE__*/React.createElement(React.Fragment, null, Icon ? /*#__PURE__*/React.createElement(Icon, null) : null, children, caret && /*#__PURE__*/React.createElement("span", {
|
40
|
+
className: "".concat(blockClass, "__caret")
|
41
|
+
})));
|
42
|
+
});
|
43
|
+
var componentName = 'ToolbarButton';
|
44
|
+
ToolbarButton.displayName = componentName;
|
45
|
+
ToolbarButton.propTypes = {
|
46
|
+
/** Determines whether the caret is rendered */
|
47
|
+
caret: bool,
|
48
|
+
/** Provide the content of the `ToolbarButton` */
|
49
|
+
children: node,
|
50
|
+
/** Provide an optional class to be applied to the containing node */
|
51
|
+
className: string,
|
52
|
+
/** Specifies the label for the icon button */
|
53
|
+
iconDescription: string.isRequired,
|
54
|
+
/** Specifies the icon to be used by the ToolbarButton component */
|
55
|
+
renderIcon: func.isRequired
|
56
|
+
};
|
57
|
+
ToolbarButton = pkg.checkComponentEnabled(ToolbarButton, componentName);
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import _extends from "@babel/runtime/helpers/extends";
|
2
|
+
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
3
|
+
var _excluded = ["className", "children"];
|
4
|
+
/**
|
5
|
+
* Copyright IBM Corp. 2021, 2021
|
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 cx from 'classnames';
|
12
|
+
import { node, string } from 'prop-types';
|
13
|
+
import React, { forwardRef } from 'react';
|
14
|
+
import { pkg } from '../../settings';
|
15
|
+
import { blockClass } from './Toolbar';
|
16
|
+
|
17
|
+
/** Toolbar groups organize the commands within a toolbar into related groups. */
|
18
|
+
export var ToolbarGroup = /*#__PURE__*/forwardRef(function (_ref, ref) {
|
19
|
+
var className = _ref.className,
|
20
|
+
children = _ref.children,
|
21
|
+
rest = _objectWithoutProperties(_ref, _excluded);
|
22
|
+
return /*#__PURE__*/React.createElement("div", _extends({}, rest, {
|
23
|
+
ref: ref,
|
24
|
+
className: cx("".concat(blockClass, "__group"), className)
|
25
|
+
}), children);
|
26
|
+
});
|
27
|
+
var componentName = 'ToolbarGroup';
|
28
|
+
ToolbarGroup.displayName = componentName;
|
29
|
+
ToolbarGroup.propTypes = {
|
30
|
+
/** Provide the content of the `ToolbarGroup` */
|
31
|
+
children: node.isRequired,
|
32
|
+
/** Provide an optional class to be applied to the containing node */
|
33
|
+
className: string
|
34
|
+
};
|
35
|
+
ToolbarGroup = pkg.checkComponentEnabled(ToolbarGroup, componentName);
|
@@ -0,0 +1,10 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright IBM Corp. 2021, 2021
|
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 { Toolbar } from './Toolbar';
|
9
|
+
export { ToolbarButton } from './ToolbarButton';
|
10
|
+
export { ToolbarGroup } from './ToolbarGroup';
|