@rebasepro/core 0.0.1-canary.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +174 -0
- package/dist/app/AppBar.d.ts +12 -0
- package/dist/app/Drawer.d.ts +19 -0
- package/dist/app/Scaffold.d.ts +34 -0
- package/dist/app/index.d.ts +4 -0
- package/dist/app/useApp.d.ts +17 -0
- package/dist/components/AIIcon.d.ts +16 -0
- package/dist/components/AdminModeSyncer.d.ts +17 -0
- package/dist/components/ArrayContainer.d.ts +59 -0
- package/dist/components/CircularProgressCenter.d.ts +11 -0
- package/dist/components/ClearFilterSortButton.d.ts +5 -0
- package/dist/components/ConfirmationDialog.d.ts +9 -0
- package/dist/components/Debug/UIReferenceView.d.ts +1 -0
- package/dist/components/Debug/UIStyleGuide.d.ts +1 -0
- package/dist/components/DeleteEntityDialog.d.ts +12 -0
- package/dist/components/EntityCollectionTable/EntityCollectionRowActions.d.ts +37 -0
- package/dist/components/EntityCollectionTable/EntityCollectionTable.d.ts +27 -0
- package/dist/components/EntityCollectionTable/EntityCollectionTableProps.d.ts +128 -0
- package/dist/components/EntityCollectionTable/PropertyTableCell.d.ts +25 -0
- package/dist/components/EntityCollectionTable/column_utils.d.ts +15 -0
- package/dist/components/EntityCollectionTable/fields/TableMultipleRelationField.d.ts +20 -0
- package/dist/components/EntityCollectionTable/fields/TableReferenceField.d.ts +21 -0
- package/dist/components/EntityCollectionTable/fields/TableRelationField.d.ts +21 -0
- package/dist/components/EntityCollectionTable/fields/TableRelationSelectorField.d.ts +20 -0
- package/dist/components/EntityCollectionTable/fields/TableStorageUpload.d.ts +32 -0
- package/dist/components/EntityCollectionTable/index.d.ts +6 -0
- package/dist/components/EntityCollectionTable/internal/CollectionTableToolbar.d.ts +16 -0
- package/dist/components/EntityCollectionTable/internal/EntityTableCell.d.ts +32 -0
- package/dist/components/EntityCollectionTable/internal/EntityTableCellActions.d.ts +9 -0
- package/dist/components/EntityCollectionTable/internal/common.d.ts +4 -0
- package/dist/components/EntityCollectionTable/internal/popup_field/PopupFormField.d.ts +26 -0
- package/dist/components/EntityCollectionTable/internal/popup_field/useDraggable.d.ts +13 -0
- package/dist/components/EntityCollectionTable/internal/popup_field/useWindowSize.d.ts +6 -0
- package/dist/components/EntityCollectionView/Board.d.ts +2 -0
- package/dist/components/EntityCollectionView/BoardColumn.d.ts +42 -0
- package/dist/components/EntityCollectionView/BoardColumnTitle.d.ts +9 -0
- package/dist/components/EntityCollectionView/BoardSortableList.d.ts +14 -0
- package/dist/components/EntityCollectionView/EntityBoardCard.d.ts +26 -0
- package/dist/components/EntityCollectionView/EntityCard.d.ts +19 -0
- package/dist/components/EntityCollectionView/EntityCollectionBoardView.d.ts +20 -0
- package/dist/components/EntityCollectionView/EntityCollectionCardView.d.ts +31 -0
- package/dist/components/EntityCollectionView/EntityCollectionView.d.ts +54 -0
- package/dist/components/EntityCollectionView/EntityCollectionViewActions.d.ts +14 -0
- package/dist/components/EntityCollectionView/EntityCollectionViewStartActions.d.ts +15 -0
- package/dist/components/EntityCollectionView/FiltersDialog.d.ts +14 -0
- package/dist/components/EntityCollectionView/ViewModeToggle.d.ts +44 -0
- package/dist/components/EntityCollectionView/board_types.d.ts +105 -0
- package/dist/components/EntityCollectionView/useBoardDataController.d.ts +60 -0
- package/dist/components/EntityCollectionView/useSelectionController.d.ts +2 -0
- package/dist/components/EntityCollectionView/utils.d.ts +3 -0
- package/dist/components/EntityJsonPreview.d.ts +3 -0
- package/dist/components/EntityPreview.d.ts +54 -0
- package/dist/components/EntityView.d.ts +11 -0
- package/dist/components/ErrorBoundary.d.ts +11 -0
- package/dist/components/ErrorTooltip.d.ts +2 -0
- package/dist/components/ErrorView.d.ts +21 -0
- package/dist/components/FieldCaption.d.ts +5 -0
- package/dist/components/HomePage/ContentHomePage.d.ts +11 -0
- package/dist/components/HomePage/FavouritesView.d.ts +3 -0
- package/dist/components/HomePage/HomePageDnD.d.ts +77 -0
- package/dist/components/HomePage/NavigationCard.d.ts +10 -0
- package/dist/components/HomePage/NavigationCardBinding.d.ts +18 -0
- package/dist/components/HomePage/NavigationGroup.d.ts +11 -0
- package/dist/components/HomePage/RenameGroupDialog.d.ts +9 -0
- package/dist/components/HomePage/SmallNavigationCard.d.ts +6 -0
- package/dist/components/HomePage/StudioHomePage.d.ts +9 -0
- package/dist/components/HomePage/index.d.ts +5 -0
- package/dist/components/NotFoundPage.d.ts +1 -0
- package/dist/components/PropertyCollectionView.d.ts +22 -0
- package/dist/components/PropertyConfigBadge.d.ts +6 -0
- package/dist/components/PropertyIdCopyTooltip.d.ts +8 -0
- package/dist/components/RebaseLogo.d.ts +7 -0
- package/dist/components/ReferenceTable/EntitySelectionTable.d.ts +58 -0
- package/dist/components/ReferenceWidget.d.ts +29 -0
- package/dist/components/RelationSelector.d.ts +32 -0
- package/dist/components/SearchIconsView.d.ts +5 -0
- package/dist/components/SelectableTable/SelectableTable.d.ts +89 -0
- package/dist/components/SelectableTable/SelectableTableContext.d.ts +4 -0
- package/dist/components/SelectableTable/filters/BooleanFilterField.d.ts +9 -0
- package/dist/components/SelectableTable/filters/DateTimeFilterField.d.ts +12 -0
- package/dist/components/SelectableTable/filters/ReferenceFilterField.d.ts +15 -0
- package/dist/components/SelectableTable/filters/RelationFilterField.d.ts +12 -0
- package/dist/components/SelectableTable/filters/StringNumberFilterField.d.ts +13 -0
- package/dist/components/UnsavedChangesDialog.d.ts +9 -0
- package/dist/components/UserDisplay.d.ts +7 -0
- package/dist/components/UserSettingsView.d.ts +1 -0
- package/dist/components/VirtualTable/VirtualTable.d.ts +11 -0
- package/dist/components/VirtualTable/VirtualTableCell.d.ts +20 -0
- package/dist/components/VirtualTable/VirtualTableHeader.d.ts +29 -0
- package/dist/components/VirtualTable/VirtualTableHeaderRow.d.ts +2 -0
- package/dist/components/VirtualTable/VirtualTableProps.d.ts +239 -0
- package/dist/components/VirtualTable/VirtualTableRow.d.ts +3 -0
- package/dist/components/VirtualTable/fields/VirtualTableDateField.d.ts +12 -0
- package/dist/components/VirtualTable/fields/VirtualTableInput.d.ts +9 -0
- package/dist/components/VirtualTable/fields/VirtualTableNumberInput.d.ts +8 -0
- package/dist/components/VirtualTable/fields/VirtualTableSelect.d.ts +15 -0
- package/dist/components/VirtualTable/fields/VirtualTableSwitch.d.ts +7 -0
- package/dist/components/VirtualTable/fields/VirtualTableUserSelect.d.ts +12 -0
- package/dist/components/VirtualTable/index.d.ts +3 -0
- package/dist/components/VirtualTable/types.d.ts +37 -0
- package/dist/components/admin/RoleChip.d.ts +4 -0
- package/dist/components/admin/RolesView.d.ts +4 -0
- package/dist/components/admin/UsersView.d.ts +4 -0
- package/dist/components/admin/index.d.ts +3 -0
- package/dist/components/common/default_entity_actions.d.ts +4 -0
- package/dist/components/common/index.d.ts +6 -0
- package/dist/components/common/table_height.d.ts +5 -0
- package/dist/components/common/types.d.ts +58 -0
- package/dist/components/common/useColumnsIds.d.ts +6 -0
- package/dist/components/common/useDataSourceTableController.d.ts +44 -0
- package/dist/components/common/useDebouncedCallback.d.ts +1 -0
- package/dist/components/common/useDebouncedData.d.ts +9 -0
- package/dist/components/common/useScrollRestoration.d.ts +14 -0
- package/dist/components/common/useTableSearchHelper.d.ts +11 -0
- package/dist/components/index.d.ts +35 -0
- package/dist/contexts/AdminModeController.d.ts +4 -0
- package/dist/contexts/AnalyticsContext.d.ts +3 -0
- package/dist/contexts/AuthControllerContext.d.ts +3 -0
- package/dist/contexts/BreacrumbsContext.d.ts +8 -0
- package/dist/contexts/CustomizationControllerContext.d.ts +3 -0
- package/dist/contexts/DataSourceContext.d.ts +3 -0
- package/dist/contexts/DialogsProvider.d.ts +4 -0
- package/dist/contexts/EffectiveRoleController.d.ts +4 -0
- package/dist/contexts/InternalUserManagementContext.d.ts +3 -0
- package/dist/contexts/ModeController.d.ts +4 -0
- package/dist/contexts/NavigationContext.d.ts +3 -0
- package/dist/contexts/SideDialogsControllerContext.d.ts +3 -0
- package/dist/contexts/SideEntityControllerContext.d.ts +3 -0
- package/dist/contexts/SnackbarProvider.d.ts +2 -0
- package/dist/contexts/StorageSourceContext.d.ts +3 -0
- package/dist/contexts/UserConfigurationPersistenceContext.d.ts +3 -0
- package/dist/contexts/index.d.ts +15 -0
- package/dist/core/DefaultAppBar.d.ts +29 -0
- package/dist/core/DefaultDrawer.d.ts +29 -0
- package/dist/core/DrawerNavigationGroup.d.ts +45 -0
- package/dist/core/DrawerNavigationItem.d.ts +10 -0
- package/dist/core/EntityEditView.d.ts +47 -0
- package/dist/core/EntityEditViewFormActions.d.ts +2 -0
- package/dist/core/EntitySidePanel.d.ts +10 -0
- package/dist/core/Rebase.d.ts +13 -0
- package/dist/core/RebaseRouter.d.ts +4 -0
- package/dist/core/RebaseRoutes.d.ts +17 -0
- package/dist/core/SideDialogs.d.ts +25 -0
- package/dist/core/field_configs.d.ts +6 -0
- package/dist/core/index.d.ts +9 -0
- package/dist/form/EntityForm.d.ts +7 -0
- package/dist/form/EntityFormActions.d.ts +2 -0
- package/dist/form/PropertyFieldBinding.d.ts +30 -0
- package/dist/form/components/ErrorFocus.d.ts +4 -0
- package/dist/form/components/FieldHelperText.d.ts +12 -0
- package/dist/form/components/FormEntry.d.ts +6 -0
- package/dist/form/components/FormLayout.d.ts +5 -0
- package/dist/form/components/LabelWithIcon.d.ts +14 -0
- package/dist/form/components/LabelWithIconAndTooltip.d.ts +15 -0
- package/dist/form/components/LocalChangesMenu.d.ts +11 -0
- package/dist/form/components/StorageItemPreview.d.ts +13 -0
- package/dist/form/components/StorageUploadProgress.d.ts +10 -0
- package/dist/form/components/index.d.ts +5 -0
- package/dist/form/field_bindings/ArrayCustomShapedFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/ArrayOfReferencesFieldBinding.d.ts +11 -0
- package/dist/form/field_bindings/BlockFieldBinding.d.ts +10 -0
- package/dist/form/field_bindings/DateTimeFieldBinding.d.ts +11 -0
- package/dist/form/field_bindings/KeyValueFieldBinding.d.ts +7 -0
- package/dist/form/field_bindings/MapFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/MarkdownEditorFieldBinding.d.ts +11 -0
- package/dist/form/field_bindings/MultiSelectFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/MultipleRelationFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/ReadOnlyFieldBinding.d.ts +10 -0
- package/dist/form/field_bindings/ReferenceAsStringFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/ReferenceFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/RelationFieldBinding.d.ts +2 -0
- package/dist/form/field_bindings/RepeatFieldBinding.d.ts +10 -0
- package/dist/form/field_bindings/SelectFieldBinding.d.ts +10 -0
- package/dist/form/field_bindings/StorageUploadFieldBinding.d.ts +19 -0
- package/dist/form/field_bindings/SwitchFieldBinding.d.ts +9 -0
- package/dist/form/field_bindings/TextFieldBinding.d.ts +8 -0
- package/dist/form/field_bindings/UserSelectFieldBinding.d.ts +12 -0
- package/dist/form/index.d.ts +20 -0
- package/dist/form/useClearRestoreValue.d.ts +13 -0
- package/dist/form/validation.d.ts +26 -0
- package/dist/hooks/ApiConfigContext.d.ts +24 -0
- package/dist/hooks/data/delete.d.ts +33 -0
- package/dist/hooks/data/save.d.ts +37 -0
- package/dist/hooks/data/useCollectionFetch.d.ts +50 -0
- package/dist/hooks/data/useDataOrder.d.ts +12 -0
- package/dist/hooks/data/useDataSource.d.ts +6 -0
- package/dist/hooks/data/useEntityFetch.d.ts +29 -0
- package/dist/hooks/data/useRelationSelector.d.ts +45 -0
- package/dist/hooks/index.d.ts +41 -0
- package/dist/hooks/navigation/contexts/CMSUrlContext.d.ts +4 -0
- package/dist/hooks/navigation/contexts/CollectionRegistryContext.d.ts +4 -0
- package/dist/hooks/navigation/contexts/NavigationStateContext.d.ts +4 -0
- package/dist/hooks/navigation/contexts/index.d.ts +3 -0
- package/dist/hooks/navigation/useBuildCMSUrlController.d.ts +6 -0
- package/dist/hooks/navigation/useBuildCollectionRegistryController.d.ts +7 -0
- package/dist/hooks/navigation/useBuildNavigationStateController.d.ts +32 -0
- package/dist/hooks/navigation/useNavigationRegistry.d.ts +10 -0
- package/dist/hooks/navigation/useNavigationResolution.d.ts +5 -0
- package/dist/hooks/navigation/useNavigationURLs.d.ts +11 -0
- package/dist/hooks/navigation/useResolvedCollections.d.ts +26 -0
- package/dist/hooks/navigation/useResolvedViews.d.ts +28 -0
- package/dist/hooks/navigation/useTopLevelNavigation.d.ts +26 -0
- package/dist/hooks/navigation/utils.d.ts +12 -0
- package/dist/hooks/useAdminModeController.d.ts +19 -0
- package/dist/hooks/useAnalyticsController.d.ts +5 -0
- package/dist/hooks/useAuthController.d.ts +11 -0
- package/dist/hooks/useBackendStorageSource.d.ts +30 -0
- package/dist/hooks/useBreadcrumbsController.d.ts +42 -0
- package/dist/hooks/useBrowserTitleAndIcon.d.ts +6 -0
- package/dist/hooks/useBuildAdminModeController.d.ts +6 -0
- package/dist/hooks/useBuildEffectiveRoleController.d.ts +8 -0
- package/dist/hooks/useBuildLocalConfigurationPersistence.d.ts +2 -0
- package/dist/hooks/useBuildModeController.d.ts +6 -0
- package/dist/hooks/useBuildNavigationController.d.ts +16 -0
- package/dist/hooks/useClipboard.d.ts +57 -0
- package/dist/hooks/useCollapsedGroups.d.ts +12 -0
- package/dist/hooks/useCustomizationController.d.ts +11 -0
- package/dist/hooks/useDialogsController.d.ts +11 -0
- package/dist/hooks/useEffectiveRoleController.d.ts +7 -0
- package/dist/hooks/useEntitySelectionDialog.d.ts +18 -0
- package/dist/hooks/useInternalUserManagementController.d.ts +12 -0
- package/dist/hooks/useLargeLayout.d.ts +1 -0
- package/dist/hooks/useModeController.d.ts +19 -0
- package/dist/hooks/usePermissions.d.ts +11 -0
- package/dist/hooks/useRebaseContext.d.ts +11 -0
- package/dist/hooks/useResolvedNavigationFrom.d.ts +72 -0
- package/dist/hooks/useSideDialogsController.d.ts +18 -0
- package/dist/hooks/useSideEntityController.d.ts +12 -0
- package/dist/hooks/useSnackbarController.d.ts +20 -0
- package/dist/hooks/useStorageSource.d.ts +6 -0
- package/dist/hooks/useUnsavedChangesDialog.d.ts +12 -0
- package/dist/hooks/useUserConfigurationPersistence.d.ts +8 -0
- package/dist/hooks/useValidateAuthenticator.d.ts +21 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.es.js +34745 -0
- package/dist/index.es.js.map +1 -0
- package/dist/index.umd.js +34751 -0
- package/dist/index.umd.js.map +1 -0
- package/dist/internal/common.d.ts +3 -0
- package/dist/internal/useBuildDataSource.d.ts +12 -0
- package/dist/internal/useBuildSideDialogsController.d.ts +2 -0
- package/dist/internal/useBuildSideEntityController.d.ts +4 -0
- package/dist/internal/useRestoreScroll.d.ts +6 -0
- package/dist/preview/PropertyPreview.d.ts +6 -0
- package/dist/preview/components/ArrayEnumPreview.d.ts +10 -0
- package/dist/preview/components/AsyncPreviewComponent.d.ts +11 -0
- package/dist/preview/components/BooleanPreview.d.ts +10 -0
- package/dist/preview/components/DatePreview.d.ts +17 -0
- package/dist/preview/components/EmptyValue.d.ts +6 -0
- package/dist/preview/components/EnumValuesChip.d.ts +13 -0
- package/dist/preview/components/ImagePreview.d.ts +16 -0
- package/dist/preview/components/ReferencePreview.d.ts +16 -0
- package/dist/preview/components/RelationPreview.d.ts +16 -0
- package/dist/preview/components/StorageThumbnail.d.ts +15 -0
- package/dist/preview/components/UrlComponentPreview.d.ts +13 -0
- package/dist/preview/components/UserPreview.d.ts +8 -0
- package/dist/preview/index.d.ts +24 -0
- package/dist/preview/property_previews/ArrayOfMapsPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayOfReferencesPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayOfRelationsPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayOfStorageComponentsPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayOfStringsPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayOneOfPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayPropertyEnumPreview.d.ts +5 -0
- package/dist/preview/property_previews/ArrayPropertyPreview.d.ts +5 -0
- package/dist/preview/property_previews/MapPropertyPreview.d.ts +8 -0
- package/dist/preview/property_previews/NumberPropertyPreview.d.ts +6 -0
- package/dist/preview/property_previews/SkeletonPropertyComponent.d.ts +13 -0
- package/dist/preview/property_previews/StringPropertyPreview.d.ts +6 -0
- package/dist/preview/util.d.ts +6 -0
- package/dist/routes/CustomCMSRoute.d.ts +4 -0
- package/dist/routes/RebaseRoute.d.ts +1 -0
- package/dist/routes/index.d.ts +2 -0
- package/dist/util/createFormexStub.d.ts +2 -0
- package/dist/util/entity_cache.d.ts +27 -0
- package/dist/util/enums.d.ts +5 -0
- package/dist/util/icon_list.d.ts +5 -0
- package/dist/util/icon_synonyms.d.ts +1853 -0
- package/dist/util/icons.d.ts +16 -0
- package/dist/util/index.d.ts +11 -0
- package/dist/util/previews.d.ts +3 -0
- package/dist/util/property_utils.d.ts +23 -0
- package/dist/util/useDebouncedCallback.d.ts +1 -0
- package/dist/util/useStorageUploadController.d.ts +36 -0
- package/dist/util/useTraceUpdate.d.ts +2 -0
- package/dist/vitePlugin.d.ts +16 -0
- package/package.json +165 -0
- package/src/app/AppBar.tsx +18 -0
- package/src/app/Drawer.tsx +30 -0
- package/src/app/Scaffold.tsx +238 -0
- package/src/app/index.ts +4 -0
- package/src/app/useApp.tsx +36 -0
- package/src/components/AIIcon.tsx +39 -0
- package/src/components/AdminModeSyncer.tsx +47 -0
- package/src/components/ArrayContainer.tsx +549 -0
- package/src/components/CircularProgressCenter.tsx +26 -0
- package/src/components/ClearFilterSortButton.tsx +44 -0
- package/src/components/ConfirmationDialog.tsx +46 -0
- package/src/components/Debug/UIReferenceView.tsx +710 -0
- package/src/components/Debug/UIStyleGuide.tsx +164 -0
- package/src/components/DeleteEntityDialog.tsx +181 -0
- package/src/components/EntityCollectionTable/EntityCollectionRowActions.tsx +225 -0
- package/src/components/EntityCollectionTable/EntityCollectionTable.tsx +383 -0
- package/src/components/EntityCollectionTable/EntityCollectionTableProps.tsx +180 -0
- package/src/components/EntityCollectionTable/PropertyTableCell.tsx +561 -0
- package/src/components/EntityCollectionTable/column_utils.tsx +74 -0
- package/src/components/EntityCollectionTable/fields/TableMultipleRelationField.tsx +122 -0
- package/src/components/EntityCollectionTable/fields/TableReferenceField.tsx +169 -0
- package/src/components/EntityCollectionTable/fields/TableRelationField.tsx +177 -0
- package/src/components/EntityCollectionTable/fields/TableRelationSelectorField.tsx +42 -0
- package/src/components/EntityCollectionTable/fields/TableStorageUpload.tsx +315 -0
- package/src/components/EntityCollectionTable/index.tsx +12 -0
- package/src/components/EntityCollectionTable/internal/CollectionTableToolbar.tsx +90 -0
- package/src/components/EntityCollectionTable/internal/EntityTableCell.tsx +311 -0
- package/src/components/EntityCollectionTable/internal/EntityTableCellActions.tsx +82 -0
- package/src/components/EntityCollectionTable/internal/common.tsx +72 -0
- package/src/components/EntityCollectionTable/internal/popup_field/PopupFormField.tsx +425 -0
- package/src/components/EntityCollectionTable/internal/popup_field/useDraggable.tsx +96 -0
- package/src/components/EntityCollectionTable/internal/popup_field/useWindowSize.tsx +20 -0
- package/src/components/EntityCollectionView/Board.tsx +324 -0
- package/src/components/EntityCollectionView/BoardColumn.tsx +158 -0
- package/src/components/EntityCollectionView/BoardColumnTitle.tsx +45 -0
- package/src/components/EntityCollectionView/BoardSortableList.tsx +172 -0
- package/src/components/EntityCollectionView/EntityBoardCard.tsx +200 -0
- package/src/components/EntityCollectionView/EntityCard.tsx +225 -0
- package/src/components/EntityCollectionView/EntityCollectionBoardView.tsx +746 -0
- package/src/components/EntityCollectionView/EntityCollectionCardView.tsx +254 -0
- package/src/components/EntityCollectionView/EntityCollectionView.tsx +1220 -0
- package/src/components/EntityCollectionView/EntityCollectionViewActions.tsx +142 -0
- package/src/components/EntityCollectionView/EntityCollectionViewStartActions.tsx +131 -0
- package/src/components/EntityCollectionView/FiltersDialog.tsx +249 -0
- package/src/components/EntityCollectionView/ViewModeToggle.tsx +194 -0
- package/src/components/EntityCollectionView/board_types.ts +113 -0
- package/src/components/EntityCollectionView/useBoardDataController.tsx +490 -0
- package/src/components/EntityCollectionView/useSelectionController.tsx +43 -0
- package/src/components/EntityCollectionView/utils.ts +19 -0
- package/src/components/EntityJsonPreview.tsx +66 -0
- package/src/components/EntityPreview.tsx +367 -0
- package/src/components/EntityView.tsx +66 -0
- package/src/components/ErrorBoundary.tsx +40 -0
- package/src/components/ErrorTooltip.tsx +12 -0
- package/src/components/ErrorView.tsx +69 -0
- package/src/components/FieldCaption.tsx +14 -0
- package/src/components/HomePage/ContentHomePage.tsx +634 -0
- package/src/components/HomePage/FavouritesView.tsx +59 -0
- package/src/components/HomePage/HomePageDnD.tsx +702 -0
- package/src/components/HomePage/NavigationCard.tsx +80 -0
- package/src/components/HomePage/NavigationCardBinding.tsx +111 -0
- package/src/components/HomePage/NavigationGroup.tsx +154 -0
- package/src/components/HomePage/RenameGroupDialog.tsx +121 -0
- package/src/components/HomePage/SmallNavigationCard.tsx +45 -0
- package/src/components/HomePage/StudioHomePage.tsx +231 -0
- package/src/components/HomePage/index.tsx +6 -0
- package/src/components/NotFoundPage.tsx +25 -0
- package/src/components/PropertyCollectionView.tsx +333 -0
- package/src/components/PropertyConfigBadge.tsx +27 -0
- package/src/components/PropertyIdCopyTooltip.tsx +47 -0
- package/src/components/RebaseLogo.tsx +29 -0
- package/src/components/ReferenceTable/EntitySelectionTable.tsx +371 -0
- package/src/components/ReferenceWidget.tsx +152 -0
- package/src/components/RelationSelector.tsx +518 -0
- package/src/components/SearchIconsView.tsx +78 -0
- package/src/components/SelectableTable/SelectableTable.tsx +344 -0
- package/src/components/SelectableTable/SelectableTableContext.tsx +6 -0
- package/src/components/SelectableTable/filters/BooleanFilterField.tsx +49 -0
- package/src/components/SelectableTable/filters/DateTimeFilterField.tsx +126 -0
- package/src/components/SelectableTable/filters/ReferenceFilterField.tsx +203 -0
- package/src/components/SelectableTable/filters/RelationFilterField.tsx +138 -0
- package/src/components/SelectableTable/filters/StringNumberFilterField.tsx +217 -0
- package/src/components/UnsavedChangesDialog.tsx +45 -0
- package/src/components/UserDisplay.tsx +55 -0
- package/src/components/UserSettingsView.tsx +220 -0
- package/src/components/VirtualTable/VirtualTable.performance.test.tsx +386 -0
- package/src/components/VirtualTable/VirtualTable.tsx +625 -0
- package/src/components/VirtualTable/VirtualTableCell.tsx +58 -0
- package/src/components/VirtualTable/VirtualTableHeader.tsx +275 -0
- package/src/components/VirtualTable/VirtualTableHeaderRow.tsx +249 -0
- package/src/components/VirtualTable/VirtualTableProps.tsx +298 -0
- package/src/components/VirtualTable/VirtualTableRow.tsx +52 -0
- package/src/components/VirtualTable/fields/VirtualTableDateField.tsx +39 -0
- package/src/components/VirtualTable/fields/VirtualTableInput.tsx +93 -0
- package/src/components/VirtualTable/fields/VirtualTableNumberInput.tsx +83 -0
- package/src/components/VirtualTable/fields/VirtualTableSelect.tsx +133 -0
- package/src/components/VirtualTable/fields/VirtualTableSwitch.tsx +32 -0
- package/src/components/VirtualTable/fields/VirtualTableUserSelect.tsx +111 -0
- package/src/components/VirtualTable/index.tsx +3 -0
- package/src/components/VirtualTable/types.tsx +46 -0
- package/src/components/admin/RoleChip.tsx +23 -0
- package/src/components/admin/RolesView.tsx +408 -0
- package/src/components/admin/UsersView.tsx +353 -0
- package/src/components/admin/index.ts +3 -0
- package/src/components/common/default_entity_actions.tsx +144 -0
- package/src/components/common/index.ts +6 -0
- package/src/components/common/table_height.tsx +21 -0
- package/src/components/common/types.tsx +61 -0
- package/src/components/common/useColumnsIds.tsx +210 -0
- package/src/components/common/useDataSourceTableController.tsx +480 -0
- package/src/components/common/useDebouncedCallback.tsx +20 -0
- package/src/components/common/useDebouncedData.ts +49 -0
- package/src/components/common/useScrollRestoration.tsx +68 -0
- package/src/components/common/useTableSearchHelper.ts +75 -0
- package/src/components/index.tsx +49 -0
- package/src/contexts/AdminModeController.tsx +11 -0
- package/src/contexts/AnalyticsContext.tsx +4 -0
- package/src/contexts/AuthControllerContext.tsx +4 -0
- package/src/contexts/BreacrumbsContext.tsx +45 -0
- package/src/contexts/CustomizationControllerContext.tsx +4 -0
- package/src/contexts/DataSourceContext.tsx +4 -0
- package/src/contexts/DialogsProvider.tsx +53 -0
- package/src/contexts/EffectiveRoleController.tsx +11 -0
- package/src/contexts/InternalUserManagementContext.tsx +4 -0
- package/src/contexts/ModeController.tsx +11 -0
- package/src/contexts/NavigationContext.tsx +4 -0
- package/src/contexts/SideDialogsControllerContext.tsx +4 -0
- package/src/contexts/SideEntityControllerContext.tsx +4 -0
- package/src/contexts/SnackbarProvider.tsx +14 -0
- package/src/contexts/StorageSourceContext.tsx +4 -0
- package/src/contexts/UserConfigurationPersistenceContext.tsx +4 -0
- package/src/contexts/index.ts +15 -0
- package/src/core/DefaultAppBar.tsx +274 -0
- package/src/core/DefaultDrawer.tsx +267 -0
- package/src/core/DrawerNavigationGroup.tsx +117 -0
- package/src/core/DrawerNavigationItem.tsx +65 -0
- package/src/core/EntityEditView.tsx +590 -0
- package/src/core/EntityEditViewFormActions.tsx +343 -0
- package/src/core/EntitySidePanel.tsx +173 -0
- package/src/core/Rebase.tsx +229 -0
- package/src/core/RebaseRouter.tsx +17 -0
- package/src/core/RebaseRoutes.tsx +47 -0
- package/src/core/SideDialogs.tsx +200 -0
- package/src/core/field_configs.tsx +443 -0
- package/src/core/index.tsx +14 -0
- package/src/form/EntityForm.tsx +820 -0
- package/src/form/EntityFormActions.tsx +201 -0
- package/src/form/PropertyFieldBinding.tsx +348 -0
- package/src/form/components/ErrorFocus.tsx +44 -0
- package/src/form/components/FieldHelperText.tsx +45 -0
- package/src/form/components/FormEntry.tsx +22 -0
- package/src/form/components/FormLayout.tsx +16 -0
- package/src/form/components/LabelWithIcon.tsx +43 -0
- package/src/form/components/LabelWithIconAndTooltip.tsx +28 -0
- package/src/form/components/LocalChangesMenu.tsx +144 -0
- package/src/form/components/StorageItemPreview.tsx +79 -0
- package/src/form/components/StorageUploadProgress.tsx +105 -0
- package/src/form/components/index.tsx +5 -0
- package/src/form/field_bindings/ArrayCustomShapedFieldBinding.tsx +105 -0
- package/src/form/field_bindings/ArrayOfReferencesFieldBinding.tsx +163 -0
- package/src/form/field_bindings/BlockFieldBinding.tsx +268 -0
- package/src/form/field_bindings/DateTimeFieldBinding.tsx +70 -0
- package/src/form/field_bindings/KeyValueFieldBinding.tsx +567 -0
- package/src/form/field_bindings/MapFieldBinding.tsx +156 -0
- package/src/form/field_bindings/MarkdownEditorFieldBinding.tsx +146 -0
- package/src/form/field_bindings/MultiSelectFieldBinding.tsx +120 -0
- package/src/form/field_bindings/MultipleRelationFieldBinding.tsx +151 -0
- package/src/form/field_bindings/ReadOnlyFieldBinding.tsx +64 -0
- package/src/form/field_bindings/ReferenceAsStringFieldBinding.tsx +135 -0
- package/src/form/field_bindings/ReferenceFieldBinding.tsx +134 -0
- package/src/form/field_bindings/RelationFieldBinding.tsx +176 -0
- package/src/form/field_bindings/RepeatFieldBinding.tsx +136 -0
- package/src/form/field_bindings/SelectFieldBinding.tsx +107 -0
- package/src/form/field_bindings/StorageUploadFieldBinding.tsx +490 -0
- package/src/form/field_bindings/SwitchFieldBinding.tsx +64 -0
- package/src/form/field_bindings/TextFieldBinding.tsx +153 -0
- package/src/form/field_bindings/UserSelectFieldBinding.tsx +96 -0
- package/src/form/index.tsx +27 -0
- package/src/form/useClearRestoreValue.tsx +35 -0
- package/src/form/validation.ts +532 -0
- package/src/hooks/ApiConfigContext.tsx +40 -0
- package/src/hooks/data/delete.ts +77 -0
- package/src/hooks/data/save.ts +75 -0
- package/src/hooks/data/useCollectionFetch.tsx +148 -0
- package/src/hooks/data/useDataOrder.ts +26 -0
- package/src/hooks/data/useDataSource.tsx +22 -0
- package/src/hooks/data/useEntityFetch.tsx +121 -0
- package/src/hooks/data/useRelationSelector.tsx +205 -0
- package/src/hooks/index.tsx +51 -0
- package/src/hooks/navigation/contexts/CMSUrlContext.tsx +24 -0
- package/src/hooks/navigation/contexts/CollectionRegistryContext.tsx +19 -0
- package/src/hooks/navigation/contexts/NavigationStateContext.tsx +15 -0
- package/src/hooks/navigation/contexts/index.ts +14 -0
- package/src/hooks/navigation/useBuildCMSUrlController.tsx +68 -0
- package/src/hooks/navigation/useBuildCollectionRegistryController.tsx +150 -0
- package/src/hooks/navigation/useBuildNavigationStateController.tsx +135 -0
- package/src/hooks/navigation/useNavigationRegistry.ts +142 -0
- package/src/hooks/navigation/useNavigationResolution.ts +98 -0
- package/src/hooks/navigation/useNavigationURLs.ts +56 -0
- package/src/hooks/navigation/useResolvedCollections.ts +139 -0
- package/src/hooks/navigation/useResolvedViews.tsx +204 -0
- package/src/hooks/navigation/useTopLevelNavigation.ts +265 -0
- package/src/hooks/navigation/utils.ts +177 -0
- package/src/hooks/useAdminModeController.tsx +23 -0
- package/src/hooks/useAnalyticsController.tsx +8 -0
- package/src/hooks/useAuthController.tsx +14 -0
- package/src/hooks/useBackendStorageSource.ts +276 -0
- package/src/hooks/useBreadcrumbsController.tsx +49 -0
- package/src/hooks/useBrowserTitleAndIcon.tsx +25 -0
- package/src/hooks/useBuildAdminModeController.tsx +24 -0
- package/src/hooks/useBuildEffectiveRoleController.tsx +30 -0
- package/src/hooks/useBuildLocalConfigurationPersistence.tsx +65 -0
- package/src/hooks/useBuildModeController.tsx +71 -0
- package/src/hooks/useBuildNavigationController.tsx +341 -0
- package/src/hooks/useClipboard.tsx +158 -0
- package/src/hooks/useCollapsedGroups.ts +72 -0
- package/src/hooks/useCustomizationController.tsx +14 -0
- package/src/hooks/useDialogsController.tsx +14 -0
- package/src/hooks/useEffectiveRoleController.tsx +10 -0
- package/src/hooks/useEntitySelectionDialog.tsx +56 -0
- package/src/hooks/useInternalUserManagementController.tsx +17 -0
- package/src/hooks/useLargeLayout.tsx +65 -0
- package/src/hooks/useModeController.tsx +23 -0
- package/src/hooks/usePermissions.ts +43 -0
- package/src/hooks/useRebaseContext.tsx +86 -0
- package/src/hooks/useResolvedNavigationFrom.tsx +158 -0
- package/src/hooks/useSideDialogsController.tsx +21 -0
- package/src/hooks/useSideEntityController.tsx +15 -0
- package/src/hooks/useSnackbarController.tsx +52 -0
- package/src/hooks/useStorageSource.tsx +14 -0
- package/src/hooks/useUnsavedChangesDialog.tsx +62 -0
- package/src/hooks/useUserConfigurationPersistence.tsx +11 -0
- package/src/hooks/useValidateAuthenticator.tsx +115 -0
- package/src/index.ts +17 -0
- package/src/internal/common.tsx +5 -0
- package/src/internal/useBuildDataSource.ts +380 -0
- package/src/internal/useBuildSideDialogsController.tsx +135 -0
- package/src/internal/useBuildSideEntityController.tsx +309 -0
- package/src/internal/useRestoreScroll.tsx +60 -0
- package/src/preview/PropertyPreview.tsx +308 -0
- package/src/preview/components/ArrayEnumPreview.tsx +38 -0
- package/src/preview/components/AsyncPreviewComponent.tsx +47 -0
- package/src/preview/components/BooleanPreview.tsx +25 -0
- package/src/preview/components/DatePreview.tsx +94 -0
- package/src/preview/components/EmptyValue.tsx +10 -0
- package/src/preview/components/EnumValuesChip.tsx +39 -0
- package/src/preview/components/ImagePreview.tsx +111 -0
- package/src/preview/components/ReferencePreview.tsx +162 -0
- package/src/preview/components/RelationPreview.tsx +153 -0
- package/src/preview/components/StorageThumbnail.tsx +91 -0
- package/src/preview/components/UrlComponentPreview.tsx +113 -0
- package/src/preview/components/UserPreview.tsx +27 -0
- package/src/preview/index.ts +26 -0
- package/src/preview/property_previews/ArrayOfMapsPreview.tsx +72 -0
- package/src/preview/property_previews/ArrayOfReferencesPreview.tsx +43 -0
- package/src/preview/property_previews/ArrayOfRelationsPreview.tsx +52 -0
- package/src/preview/property_previews/ArrayOfStorageComponentsPreview.tsx +49 -0
- package/src/preview/property_previews/ArrayOfStringsPreview.tsx +44 -0
- package/src/preview/property_previews/ArrayOneOfPreview.tsx +67 -0
- package/src/preview/property_previews/ArrayPropertyEnumPreview.tsx +34 -0
- package/src/preview/property_previews/ArrayPropertyPreview.tsx +69 -0
- package/src/preview/property_previews/MapPropertyPreview.tsx +145 -0
- package/src/preview/property_previews/NumberPropertyPreview.tsx +28 -0
- package/src/preview/property_previews/SkeletonPropertyComponent.tsx +275 -0
- package/src/preview/property_previews/StringPropertyPreview.tsx +57 -0
- package/src/preview/util.ts +30 -0
- package/src/routes/CustomCMSRoute.tsx +21 -0
- package/src/routes/RebaseRoute.tsx +255 -0
- package/src/routes/index.ts +2 -0
- package/src/util/createFormexStub.tsx +66 -0
- package/src/util/entity_cache.ts +267 -0
- package/src/util/enums.ts +32 -0
- package/src/util/icon_list.ts +23 -0
- package/src/util/icon_synonyms.ts +1853 -0
- package/src/util/icons.tsx +87 -0
- package/src/util/index.ts +11 -0
- package/src/util/previews.ts +50 -0
- package/src/util/property_utils.tsx +152 -0
- package/src/util/useDebouncedCallback.ts +25 -0
- package/src/util/useStorageUploadController.tsx +342 -0
- package/src/util/useTraceUpdate.tsx +24 -0
- package/src/vitePlugin.ts +47 -0
|
@@ -0,0 +1,324 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
import {
|
|
3
|
+
DndContext,
|
|
4
|
+
DragEndEvent,
|
|
5
|
+
DragOverEvent,
|
|
6
|
+
DragOverlay,
|
|
7
|
+
DragStartEvent,
|
|
8
|
+
PointerSensor,
|
|
9
|
+
pointerWithin,
|
|
10
|
+
useSensor,
|
|
11
|
+
useSensors
|
|
12
|
+
} from "@dnd-kit/core";
|
|
13
|
+
import { arrayMove, horizontalListSortingStrategy, SortableContext } from "@dnd-kit/sortable";
|
|
14
|
+
import { BoardColumn } from "./BoardColumn";
|
|
15
|
+
import { BoardItem, BoardItemMap, BoardItemViewProps, BoardProps } from "./board_types";
|
|
16
|
+
import { cls } from "@rebasepro/ui";
|
|
17
|
+
|
|
18
|
+
export function Board<M extends Record<string, any>, COLUMN extends string>({
|
|
19
|
+
data,
|
|
20
|
+
columns: columnsProp,
|
|
21
|
+
columnLabels,
|
|
22
|
+
columnColors,
|
|
23
|
+
className,
|
|
24
|
+
assignColumn,
|
|
25
|
+
allowColumnReorder = false,
|
|
26
|
+
onColumnReorder,
|
|
27
|
+
onItemsReorder,
|
|
28
|
+
ItemComponent,
|
|
29
|
+
columnLoadingState,
|
|
30
|
+
onLoadMoreColumn,
|
|
31
|
+
onAddItemToColumn,
|
|
32
|
+
AddColumnComponent,
|
|
33
|
+
}: BoardProps<M, COLUMN>) {
|
|
34
|
+
|
|
35
|
+
const [activeItem, setActiveItem] = useState<BoardItem<M> | null>(null);
|
|
36
|
+
const [activeColumn, setActiveColumn] = useState<COLUMN | null>(null);
|
|
37
|
+
const [isDragging, setIsDragging] = useState(false);
|
|
38
|
+
const [dragOverColumnId, setDragOverColumnId] = useState<string | null>(null);
|
|
39
|
+
const [itemMapState, setItemMapState] = useState<BoardItemMap<M>>(() => {
|
|
40
|
+
const dataColumnMap: Record<string, COLUMN> = data.reduce((prev, item: BoardItem<M>) => ({
|
|
41
|
+
...prev,
|
|
42
|
+
[item.id]: assignColumn(item)
|
|
43
|
+
}), {});
|
|
44
|
+
return columnsProp.reduce(
|
|
45
|
+
(previous: BoardItemMap<M>, column: COLUMN) => ({
|
|
46
|
+
...previous,
|
|
47
|
+
[column]: data.filter((item: BoardItem<M>) => dataColumnMap[item.id] === column)
|
|
48
|
+
}),
|
|
49
|
+
{}
|
|
50
|
+
);
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
const sensors = useSensors(
|
|
54
|
+
useSensor(PointerSensor, {
|
|
55
|
+
activationConstraint: {
|
|
56
|
+
distance: 5,
|
|
57
|
+
},
|
|
58
|
+
})
|
|
59
|
+
);
|
|
60
|
+
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
const dataColumnMap: Record<string, COLUMN> = data.reduce((prev, item) => ({
|
|
63
|
+
...prev,
|
|
64
|
+
[item.id]: assignColumn(item)
|
|
65
|
+
}), {});
|
|
66
|
+
|
|
67
|
+
setItemMapState(() => columnsProp.reduce(
|
|
68
|
+
(previous: BoardItemMap<M>, column: COLUMN) => ({
|
|
69
|
+
...previous,
|
|
70
|
+
[column]: data.filter((item: BoardItem<M>) => dataColumnMap[item.id] === column)
|
|
71
|
+
}),
|
|
72
|
+
{}
|
|
73
|
+
));
|
|
74
|
+
}, [data, columnsProp, assignColumn]);
|
|
75
|
+
|
|
76
|
+
const findColumnByItemId = (id: string): string | undefined => {
|
|
77
|
+
return Object.keys(itemMapState).find(col => itemMapState[col]?.some(i => i.id === id));
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
const handleDragStart = (event: DragStartEvent) => {
|
|
81
|
+
setIsDragging(true);
|
|
82
|
+
setDragOverColumnId(null);
|
|
83
|
+
const { active } = event;
|
|
84
|
+
|
|
85
|
+
if (active.data.current?.type === "COLUMN") {
|
|
86
|
+
const columnId = active.id as string;
|
|
87
|
+
const column = columnsProp.find(col => String(col) === columnId);
|
|
88
|
+
if (column) {
|
|
89
|
+
setActiveColumn(column);
|
|
90
|
+
}
|
|
91
|
+
} else if (active.data.current?.type === "ITEM") {
|
|
92
|
+
const columnId = findColumnByItemId(active.id as string);
|
|
93
|
+
if (columnId) {
|
|
94
|
+
const item = itemMapState[columnId]?.find(i => i.id === active.id);
|
|
95
|
+
setActiveItem(item || null);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
const handleDragOver = (event: DragOverEvent) => {
|
|
101
|
+
const {
|
|
102
|
+
active,
|
|
103
|
+
over
|
|
104
|
+
} = event;
|
|
105
|
+
|
|
106
|
+
if (!over) {
|
|
107
|
+
setDragOverColumnId(null);
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
let currentHoveredColumnId: string | null = null;
|
|
112
|
+
const overId = over.id as string;
|
|
113
|
+
const overDataType = over.data.current?.type as string | undefined;
|
|
114
|
+
|
|
115
|
+
if (overDataType === "ITEM-LIST" || overDataType === "COLUMN") {
|
|
116
|
+
currentHoveredColumnId = overId;
|
|
117
|
+
} else if (overDataType === "ITEM") {
|
|
118
|
+
currentHoveredColumnId = findColumnByItemId(overId) || null;
|
|
119
|
+
} else if (columnsProp.includes(overId as COLUMN)) {
|
|
120
|
+
currentHoveredColumnId = overId;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
setDragOverColumnId(currentHoveredColumnId);
|
|
124
|
+
|
|
125
|
+
// Skip item reordering if dragging a column
|
|
126
|
+
if (active.data.current?.type !== "ITEM") {
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
const activeId = active.id as string;
|
|
131
|
+
const activeColumn = findColumnByItemId(activeId);
|
|
132
|
+
let overColumnForMove = findColumnByItemId(overId);
|
|
133
|
+
|
|
134
|
+
if (!overColumnForMove && overDataType === "ITEM-LIST") {
|
|
135
|
+
overColumnForMove = overId;
|
|
136
|
+
}
|
|
137
|
+
if (!overColumnForMove && columnsProp.includes(overId as COLUMN)) {
|
|
138
|
+
overColumnForMove = overId;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
if (!activeColumn || !overColumnForMove) return;
|
|
142
|
+
if (activeColumn === overColumnForMove && activeId === overId && overDataType !== "ITEM-LIST") return;
|
|
143
|
+
|
|
144
|
+
// Prevent moving to a column if item with same ID already exists there
|
|
145
|
+
if (overColumnForMove !== activeColumn &&
|
|
146
|
+
itemMapState[overColumnForMove]?.some(i => i.id === activeId)) {
|
|
147
|
+
return;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
setItemMapState(currentMap => {
|
|
151
|
+
const activeItems = [...(currentMap[activeColumn] || [])];
|
|
152
|
+
const overItems = [...(currentMap[overColumnForMove!] || [])];
|
|
153
|
+
const activeIndex = activeItems.findIndex(i => i.id === activeId);
|
|
154
|
+
|
|
155
|
+
if (activeIndex === -1) return currentMap;
|
|
156
|
+
|
|
157
|
+
let overIndex;
|
|
158
|
+
if (overDataType === "ITEM-LIST" || (columnsProp.includes(overId as COLUMN) && !findColumnByItemId(overId))) {
|
|
159
|
+
overIndex = overItems.length;
|
|
160
|
+
} else {
|
|
161
|
+
overIndex = overItems.findIndex(i => i.id === overId);
|
|
162
|
+
if (overIndex !== -1) {
|
|
163
|
+
const { y } = event.delta;
|
|
164
|
+
const overRect = over.rect;
|
|
165
|
+
if (overRect) {
|
|
166
|
+
const threshold = overRect.height / 2;
|
|
167
|
+
if (y > threshold) {
|
|
168
|
+
overIndex += 1;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
} else {
|
|
172
|
+
overIndex = overItems.length;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
if (activeColumn === overColumnForMove && activeIndex === overIndex) return currentMap;
|
|
177
|
+
|
|
178
|
+
const newItemMap = { ...currentMap };
|
|
179
|
+
if (activeColumn === overColumnForMove) {
|
|
180
|
+
newItemMap[activeColumn] = arrayMove(activeItems, activeIndex, overIndex);
|
|
181
|
+
} else {
|
|
182
|
+
const [moved] = activeItems.splice(activeIndex, 1);
|
|
183
|
+
overItems.splice(overIndex, 0, moved);
|
|
184
|
+
newItemMap[activeColumn] = activeItems;
|
|
185
|
+
newItemMap[overColumnForMove] = overItems;
|
|
186
|
+
}
|
|
187
|
+
return newItemMap;
|
|
188
|
+
});
|
|
189
|
+
};
|
|
190
|
+
|
|
191
|
+
const handleDragEnd = (event: DragEndEvent) => {
|
|
192
|
+
const {
|
|
193
|
+
active,
|
|
194
|
+
over
|
|
195
|
+
} = event;
|
|
196
|
+
|
|
197
|
+
setIsDragging(false);
|
|
198
|
+
setActiveItem(null);
|
|
199
|
+
setActiveColumn(null);
|
|
200
|
+
setDragOverColumnId(null);
|
|
201
|
+
|
|
202
|
+
if (!over) return;
|
|
203
|
+
|
|
204
|
+
const activeId = active.id as string;
|
|
205
|
+
const overId = over.id as string;
|
|
206
|
+
|
|
207
|
+
if (active.data.current?.type === "COLUMN" &&
|
|
208
|
+
over.data.current?.type === "COLUMN" &&
|
|
209
|
+
activeId !== overId) {
|
|
210
|
+
|
|
211
|
+
const oldIndex = columnsProp.findIndex(col => String(col) === activeId);
|
|
212
|
+
const newIndex = columnsProp.findIndex(col => String(col) === overId);
|
|
213
|
+
|
|
214
|
+
if (oldIndex !== -1 && newIndex !== -1 && onColumnReorder && allowColumnReorder) {
|
|
215
|
+
const newOrder = arrayMove([...columnsProp], oldIndex, newIndex);
|
|
216
|
+
onColumnReorder(newOrder);
|
|
217
|
+
}
|
|
218
|
+
} else if (active.data.current?.type === "ITEM" && onItemsReorder) {
|
|
219
|
+
// Find the original column assignment from the input data
|
|
220
|
+
const originalColumn = data.find(item => item.id === activeId)
|
|
221
|
+
? assignColumn(data.find(item => item.id === activeId)!)
|
|
222
|
+
: undefined;
|
|
223
|
+
|
|
224
|
+
// Find the current column assignment from our internal state
|
|
225
|
+
const currentColumn = findColumnByItemId(activeId) as COLUMN | undefined;
|
|
226
|
+
|
|
227
|
+
// When items have been reordered, convert itemMapState to a flat list
|
|
228
|
+
const allItems: BoardItem<M>[] = [];
|
|
229
|
+
|
|
230
|
+
// Collect all items from all columns in their current order
|
|
231
|
+
Object.entries(itemMapState).forEach(([, columnItems]) => {
|
|
232
|
+
if (columnItems && (columnItems as BoardItem<M>[]).length > 0) {
|
|
233
|
+
allItems.push(...(columnItems as BoardItem<M>[]));
|
|
234
|
+
}
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
// Notify parent component of the change, including column movement information
|
|
238
|
+
if (originalColumn !== currentColumn && originalColumn && currentColumn) {
|
|
239
|
+
// Item has moved between columns - provide this context to parent
|
|
240
|
+
onItemsReorder(allItems, {
|
|
241
|
+
itemId: activeId,
|
|
242
|
+
sourceColumn: originalColumn,
|
|
243
|
+
targetColumn: currentColumn
|
|
244
|
+
});
|
|
245
|
+
} else if (currentColumn) {
|
|
246
|
+
// Reordering within the same column - still need to provide moveInfo
|
|
247
|
+
onItemsReorder(allItems, {
|
|
248
|
+
itemId: activeId,
|
|
249
|
+
sourceColumn: currentColumn,
|
|
250
|
+
targetColumn: currentColumn
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
return (
|
|
257
|
+
<DndContext
|
|
258
|
+
sensors={sensors}
|
|
259
|
+
collisionDetection={pointerWithin}
|
|
260
|
+
onDragStart={handleDragStart}
|
|
261
|
+
onDragOver={handleDragOver}
|
|
262
|
+
onDragEnd={handleDragEnd}
|
|
263
|
+
>
|
|
264
|
+
<DragOverlay dropAnimation={{
|
|
265
|
+
duration: 300,
|
|
266
|
+
easing: "cubic-bezier(0.18, 0.67, 0.6, 1.22)",
|
|
267
|
+
}}>
|
|
268
|
+
{activeItem ? (
|
|
269
|
+
<ItemComponent
|
|
270
|
+
item={activeItem}
|
|
271
|
+
isDragging={true}
|
|
272
|
+
index={-1}
|
|
273
|
+
style={{
|
|
274
|
+
boxShadow: "0 4px 16px rgba(0,0,0,0.15)",
|
|
275
|
+
opacity: 0.9,
|
|
276
|
+
}}
|
|
277
|
+
/>
|
|
278
|
+
) : activeColumn ? (
|
|
279
|
+
<BoardColumn
|
|
280
|
+
key={String(activeColumn)}
|
|
281
|
+
index={-1}
|
|
282
|
+
id={String(activeColumn)}
|
|
283
|
+
title={columnLabels?.[activeColumn] ?? String(activeColumn)}
|
|
284
|
+
items={itemMapState[String(activeColumn)] || []}
|
|
285
|
+
ItemComponent={ItemComponent}
|
|
286
|
+
isDragging={true}
|
|
287
|
+
isDragOverColumn={false}
|
|
288
|
+
/>
|
|
289
|
+
) : null}
|
|
290
|
+
</DragOverlay>
|
|
291
|
+
|
|
292
|
+
<SortableContext
|
|
293
|
+
items={columnsProp.map(String)}
|
|
294
|
+
strategy={horizontalListSortingStrategy}
|
|
295
|
+
>
|
|
296
|
+
<div className={cls("p-2 md:p-3 lg:p-4 h-full min-w-full inline-flex", className)}>
|
|
297
|
+
{columnsProp.map((key: COLUMN, index: number) => (
|
|
298
|
+
<BoardColumn
|
|
299
|
+
key={String(key)}
|
|
300
|
+
index={index}
|
|
301
|
+
id={String(key)}
|
|
302
|
+
title={columnLabels?.[key] ?? String(key)}
|
|
303
|
+
color={columnColors?.[key]}
|
|
304
|
+
items={itemMapState[String(key)] || []}
|
|
305
|
+
ItemComponent={ItemComponent}
|
|
306
|
+
isDragging={isDragging}
|
|
307
|
+
isDragOverColumn={String(key) === dragOverColumnId}
|
|
308
|
+
allowReorder={allowColumnReorder}
|
|
309
|
+
loading={columnLoadingState?.[String(key)]?.loading}
|
|
310
|
+
hasMore={columnLoadingState?.[String(key)]?.hasMore}
|
|
311
|
+
totalCount={columnLoadingState?.[String(key)]?.totalCount}
|
|
312
|
+
onLoadMore={onLoadMoreColumn ? () => onLoadMoreColumn(key) : undefined}
|
|
313
|
+
onAddItem={onAddItemToColumn ? () => onAddItemToColumn(key) : undefined}
|
|
314
|
+
style={{
|
|
315
|
+
opacity: activeColumn === key ? 0 : 1
|
|
316
|
+
}}
|
|
317
|
+
/>
|
|
318
|
+
))}
|
|
319
|
+
{AddColumnComponent}
|
|
320
|
+
</div>
|
|
321
|
+
</SortableContext>
|
|
322
|
+
</DndContext>
|
|
323
|
+
);
|
|
324
|
+
}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import React, { memo, useMemo } from "react";
|
|
2
|
+
import { SortableContext, useSortable, verticalListSortingStrategy } from "@dnd-kit/sortable";
|
|
3
|
+
import { CSS } from "@dnd-kit/utilities";
|
|
4
|
+
import { BoardSortableList } from "./BoardSortableList";
|
|
5
|
+
import { BoardColumnTitle } from "./BoardColumnTitle";
|
|
6
|
+
import { BoardItem, BoardItemViewProps } from "./board_types";
|
|
7
|
+
import { AddIcon, ChipColorKey, ChipColorScheme, cls, defaultBorderMixin, IconButton } from "@rebasepro/ui";
|
|
8
|
+
|
|
9
|
+
export interface BoardColumnProps<M extends Record<string, any>> {
|
|
10
|
+
id: string;
|
|
11
|
+
title: string;
|
|
12
|
+
items: BoardItem<M>[];
|
|
13
|
+
index: number;
|
|
14
|
+
ItemComponent: React.ComponentType<BoardItemViewProps<M>>;
|
|
15
|
+
isDragging: boolean;
|
|
16
|
+
isDragOverColumn: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Whether column reordering is allowed (shows drag handle)
|
|
19
|
+
*/
|
|
20
|
+
allowReorder?: boolean;
|
|
21
|
+
/**
|
|
22
|
+
* Whether items are loading for this column
|
|
23
|
+
*/
|
|
24
|
+
loading?: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* Whether there are more items to load
|
|
27
|
+
*/
|
|
28
|
+
hasMore?: boolean;
|
|
29
|
+
/**
|
|
30
|
+
* Callback to load more items
|
|
31
|
+
*/
|
|
32
|
+
onLoadMore?: () => void;
|
|
33
|
+
/**
|
|
34
|
+
* Callback to add a new item to this column
|
|
35
|
+
*/
|
|
36
|
+
onAddItem?: () => void;
|
|
37
|
+
/**
|
|
38
|
+
* Total count of entities in this column
|
|
39
|
+
*/
|
|
40
|
+
totalCount?: number;
|
|
41
|
+
/**
|
|
42
|
+
* Color of the column header indicator
|
|
43
|
+
*/
|
|
44
|
+
color?: ChipColorKey | ChipColorScheme;
|
|
45
|
+
style?: React.CSSProperties;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Memoized to prevent unnecessary re-renders when other columns change
|
|
49
|
+
export const BoardColumn = memo(function BoardColumn<M extends Record<string, any>>({
|
|
50
|
+
id,
|
|
51
|
+
title,
|
|
52
|
+
items,
|
|
53
|
+
ItemComponent,
|
|
54
|
+
isDragging,
|
|
55
|
+
isDragOverColumn,
|
|
56
|
+
allowReorder = false,
|
|
57
|
+
loading = false,
|
|
58
|
+
hasMore = false,
|
|
59
|
+
onLoadMore,
|
|
60
|
+
onAddItem,
|
|
61
|
+
totalCount,
|
|
62
|
+
color,
|
|
63
|
+
style
|
|
64
|
+
}: BoardColumnProps<M>) {
|
|
65
|
+
const {
|
|
66
|
+
setNodeRef,
|
|
67
|
+
attributes,
|
|
68
|
+
listeners,
|
|
69
|
+
isDragging: isColumnBeingDragged,
|
|
70
|
+
transform,
|
|
71
|
+
transition,
|
|
72
|
+
} = useSortable({
|
|
73
|
+
id,
|
|
74
|
+
data: { type: "COLUMN" },
|
|
75
|
+
disabled: !allowReorder
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
// Memoize combined style to avoid object recreation
|
|
79
|
+
const combinedStyle = useMemo(() => ({
|
|
80
|
+
...style,
|
|
81
|
+
transform: CSS.Transform.toString(transform),
|
|
82
|
+
transition,
|
|
83
|
+
zIndex: isColumnBeingDragged ? 2 : 1,
|
|
84
|
+
}), [style, transform, transition, isColumnBeingDragged]);
|
|
85
|
+
|
|
86
|
+
// Only apply drag listeners if reordering is allowed
|
|
87
|
+
const dragListeners = allowReorder ? listeners : {};
|
|
88
|
+
|
|
89
|
+
// Memoize className to avoid recomputation
|
|
90
|
+
const columnClassName = useMemo(() => cls(
|
|
91
|
+
"border h-full w-80 min-w-80 mx-2 flex flex-col rounded-md",
|
|
92
|
+
defaultBorderMixin,
|
|
93
|
+
isColumnBeingDragged ? "ring-2 ring-primary" : ""
|
|
94
|
+
), [isColumnBeingDragged]);
|
|
95
|
+
|
|
96
|
+
const headerClassName = useMemo(() => cls(
|
|
97
|
+
"flex items-center justify-between px-2 rounded-t-md transition-colors duration-200 ease-in-out",
|
|
98
|
+
isColumnBeingDragged
|
|
99
|
+
? "bg-surface-100 dark:bg-surface-900"
|
|
100
|
+
: "bg-surface-50 hover:bg-surface-100 dark:bg-surface-950 dark:hover:bg-surface-900",
|
|
101
|
+
allowReorder ? "cursor-grab" : ""
|
|
102
|
+
), [isColumnBeingDragged, allowReorder]);
|
|
103
|
+
|
|
104
|
+
// Memoize items IDs array to avoid recreating on each render
|
|
105
|
+
const itemIds = useMemo(() => items.map(i => i.id), [items]);
|
|
106
|
+
|
|
107
|
+
return (
|
|
108
|
+
<div
|
|
109
|
+
ref={setNodeRef}
|
|
110
|
+
style={combinedStyle}
|
|
111
|
+
{...attributes}
|
|
112
|
+
className={columnClassName}
|
|
113
|
+
>
|
|
114
|
+
<div
|
|
115
|
+
{...dragListeners}
|
|
116
|
+
className={headerClassName}
|
|
117
|
+
>
|
|
118
|
+
<div className="flex items-center gap-2">
|
|
119
|
+
<BoardColumnTitle aria-label={`${title} item list`} color={color}>
|
|
120
|
+
{title}
|
|
121
|
+
</BoardColumnTitle>
|
|
122
|
+
{totalCount !== undefined && (
|
|
123
|
+
<span className="text-xs text-surface-500 dark:text-surface-400">
|
|
124
|
+
{totalCount}
|
|
125
|
+
</span>
|
|
126
|
+
)}
|
|
127
|
+
</div>
|
|
128
|
+
{onAddItem && (
|
|
129
|
+
<IconButton
|
|
130
|
+
size="small"
|
|
131
|
+
onClick={(e: React.MouseEvent) => {
|
|
132
|
+
e.stopPropagation();
|
|
133
|
+
onAddItem();
|
|
134
|
+
}}
|
|
135
|
+
className="opacity-60 hover:opacity-100"
|
|
136
|
+
>
|
|
137
|
+
<AddIcon size="small" />
|
|
138
|
+
</IconButton>
|
|
139
|
+
)}
|
|
140
|
+
</div>
|
|
141
|
+
<SortableContext
|
|
142
|
+
items={itemIds}
|
|
143
|
+
strategy={verticalListSortingStrategy}
|
|
144
|
+
>
|
|
145
|
+
<BoardSortableList
|
|
146
|
+
columnId={id}
|
|
147
|
+
items={items}
|
|
148
|
+
ItemComponent={ItemComponent}
|
|
149
|
+
isDragging={isDragging}
|
|
150
|
+
isDragOverColumn={isDragOverColumn}
|
|
151
|
+
loading={loading}
|
|
152
|
+
hasMore={hasMore}
|
|
153
|
+
onLoadMore={onLoadMore}
|
|
154
|
+
/>
|
|
155
|
+
</SortableContext>
|
|
156
|
+
</div>
|
|
157
|
+
);
|
|
158
|
+
}) as <M extends Record<string, any>>(props: BoardColumnProps<M>) => React.ReactElement;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { ChipColorKey, ChipColorScheme, getColorSchemeForKey, cls } from "@rebasepro/ui";
|
|
2
|
+
import React, { useMemo } from "react";
|
|
3
|
+
|
|
4
|
+
export interface BoardColumnTitleProps {
|
|
5
|
+
children: React.ReactNode;
|
|
6
|
+
className?: string;
|
|
7
|
+
"aria-label"?: string;
|
|
8
|
+
color?: ChipColorKey | ChipColorScheme;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function BoardColumnTitle({
|
|
12
|
+
children,
|
|
13
|
+
className,
|
|
14
|
+
color,
|
|
15
|
+
...props
|
|
16
|
+
}: BoardColumnTitleProps) {
|
|
17
|
+
const colorScheme = useMemo(() => {
|
|
18
|
+
if (!color) return undefined;
|
|
19
|
+
if (typeof color === "string") {
|
|
20
|
+
return getColorSchemeForKey(color);
|
|
21
|
+
}
|
|
22
|
+
return color;
|
|
23
|
+
}, [color]);
|
|
24
|
+
|
|
25
|
+
return (
|
|
26
|
+
<h4
|
|
27
|
+
className={
|
|
28
|
+
cls("py-3 px-3 transition-colors duration-200 flex-grow select-none relative outline-none focus:outline focus:outline-2 focus:outline-offset-2 flex items-center gap-3",
|
|
29
|
+
"text-sm font-semibold text-surface-800 dark:text-surface-200",
|
|
30
|
+
className)
|
|
31
|
+
}
|
|
32
|
+
{...props}
|
|
33
|
+
>
|
|
34
|
+
{colorScheme && (
|
|
35
|
+
<div
|
|
36
|
+
className="w-3 h-3 rounded-full flex-shrink-0"
|
|
37
|
+
style={{
|
|
38
|
+
backgroundColor: colorScheme.color
|
|
39
|
+
}}
|
|
40
|
+
/>
|
|
41
|
+
)}
|
|
42
|
+
{children}
|
|
43
|
+
</h4>
|
|
44
|
+
);
|
|
45
|
+
}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import React, { memo, useEffect, useMemo, useRef } from "react";
|
|
2
|
+
import { useDroppable } from "@dnd-kit/core";
|
|
3
|
+
import { useSortable } from "@dnd-kit/sortable";
|
|
4
|
+
import { CSS } from "@dnd-kit/utilities";
|
|
5
|
+
import { CircularProgress, cls } from "@rebasepro/ui";
|
|
6
|
+
import { BoardItem, BoardItemViewProps } from "./board_types";
|
|
7
|
+
|
|
8
|
+
interface BoardSortableListProps<M extends Record<string, any>> {
|
|
9
|
+
columnId: string;
|
|
10
|
+
items: BoardItem<M>[];
|
|
11
|
+
ItemComponent: React.ComponentType<BoardItemViewProps<M>>;
|
|
12
|
+
isDragging: boolean;
|
|
13
|
+
isDragOverColumn: boolean;
|
|
14
|
+
loading?: boolean;
|
|
15
|
+
hasMore?: boolean;
|
|
16
|
+
onLoadMore?: () => void;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export function BoardSortableList<M extends Record<string, any>>({
|
|
20
|
+
columnId,
|
|
21
|
+
items,
|
|
22
|
+
ItemComponent,
|
|
23
|
+
isDragging,
|
|
24
|
+
isDragOverColumn,
|
|
25
|
+
loading = false,
|
|
26
|
+
hasMore = false,
|
|
27
|
+
onLoadMore,
|
|
28
|
+
}: BoardSortableListProps<M>) {
|
|
29
|
+
const {
|
|
30
|
+
setNodeRef,
|
|
31
|
+
} = useDroppable({
|
|
32
|
+
id: columnId,
|
|
33
|
+
data: { type: "ITEM-LIST" }
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
// Infinite scroll sentinel ref - must be inside scrollable container
|
|
37
|
+
const sentinelRef = useRef<HTMLDivElement>(null);
|
|
38
|
+
const isLoadingRef = useRef(false);
|
|
39
|
+
isLoadingRef.current = loading;
|
|
40
|
+
const lastLoadTimeRef = useRef(0);
|
|
41
|
+
|
|
42
|
+
// Set up IntersectionObserver for infinite scroll
|
|
43
|
+
useEffect(() => {
|
|
44
|
+
if (!sentinelRef.current || !hasMore || !onLoadMore) return;
|
|
45
|
+
|
|
46
|
+
const sentinel = sentinelRef.current;
|
|
47
|
+
|
|
48
|
+
const observer = new IntersectionObserver(
|
|
49
|
+
(entries) => {
|
|
50
|
+
const now = Date.now();
|
|
51
|
+
if (
|
|
52
|
+
entries[0].isIntersecting &&
|
|
53
|
+
hasMore &&
|
|
54
|
+
!isLoadingRef.current &&
|
|
55
|
+
now - lastLoadTimeRef.current > 500
|
|
56
|
+
) {
|
|
57
|
+
lastLoadTimeRef.current = now;
|
|
58
|
+
onLoadMore();
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
{ threshold: 0.1 }
|
|
62
|
+
);
|
|
63
|
+
|
|
64
|
+
observer.observe(sentinel);
|
|
65
|
+
|
|
66
|
+
// Check if sentinel is already visible when effect runs
|
|
67
|
+
// This handles the case where the sentinel was visible before the observer was created
|
|
68
|
+
const rect = sentinel.getBoundingClientRect();
|
|
69
|
+
const containerRect = sentinel.parentElement?.getBoundingClientRect();
|
|
70
|
+
if (containerRect && rect.top < containerRect.bottom && rect.bottom > containerRect.top) {
|
|
71
|
+
const now = Date.now();
|
|
72
|
+
if (hasMore && !isLoadingRef.current && now - lastLoadTimeRef.current > 500) {
|
|
73
|
+
lastLoadTimeRef.current = now;
|
|
74
|
+
onLoadMore();
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
return () => observer.disconnect();
|
|
79
|
+
}, [hasMore, onLoadMore]);
|
|
80
|
+
|
|
81
|
+
// Memoize className to avoid recomputation on every render
|
|
82
|
+
const containerClassName = useMemo(() => cls(
|
|
83
|
+
"flex flex-col p-2 transition-opacity duration-100 transition-bg ease-linear w-full overflow-y-auto no-scrollbar flex-1 rounded-md",
|
|
84
|
+
isDragging && isDragOverColumn
|
|
85
|
+
? "bg-surface-accent-200 dark:bg-surface-800"
|
|
86
|
+
: isDragging
|
|
87
|
+
? "bg-surface-50 dark:bg-surface-950 hover:bg-surface-accent-100 dark:hover:bg-surface-800"
|
|
88
|
+
: "bg-surface-50 dark:bg-surface-950"
|
|
89
|
+
), [isDragging, isDragOverColumn]);
|
|
90
|
+
|
|
91
|
+
return (
|
|
92
|
+
<div
|
|
93
|
+
ref={setNodeRef}
|
|
94
|
+
className={containerClassName}
|
|
95
|
+
style={{ minHeight: 80 }}
|
|
96
|
+
>
|
|
97
|
+
{items.length === 0 && !loading ? (
|
|
98
|
+
<div className="flex-1 flex items-center justify-center">
|
|
99
|
+
<span className="text-xs text-surface-400 dark:text-surface-500">
|
|
100
|
+
No items
|
|
101
|
+
</span>
|
|
102
|
+
</div>
|
|
103
|
+
) : (
|
|
104
|
+
<>
|
|
105
|
+
{items.map((item, index) => (
|
|
106
|
+
<SortableItem
|
|
107
|
+
key={item.id}
|
|
108
|
+
item={item}
|
|
109
|
+
index={index}
|
|
110
|
+
columnId={columnId}
|
|
111
|
+
ItemComponent={ItemComponent}
|
|
112
|
+
/>
|
|
113
|
+
))}
|
|
114
|
+
{/* Infinite scroll sentinel - inside scrollable container */}
|
|
115
|
+
{(loading || hasMore) && (
|
|
116
|
+
<div ref={sentinelRef} className="flex items-center justify-center py-2 min-h-6">
|
|
117
|
+
{loading && <CircularProgress size="smallest" />}
|
|
118
|
+
</div>
|
|
119
|
+
)}
|
|
120
|
+
</>
|
|
121
|
+
)}
|
|
122
|
+
</div>
|
|
123
|
+
);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
interface SortableItemProps<M extends Record<string, any>> {
|
|
127
|
+
item: BoardItem<M>;
|
|
128
|
+
index: number;
|
|
129
|
+
columnId: string;
|
|
130
|
+
ItemComponent: React.ComponentType<BoardItemViewProps<M>>;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// Memoized to prevent unnecessary re-renders when other items in the list change
|
|
134
|
+
const SortableItem = memo(function SortableItem<M extends Record<string, any>>({
|
|
135
|
+
item,
|
|
136
|
+
index,
|
|
137
|
+
columnId,
|
|
138
|
+
ItemComponent,
|
|
139
|
+
}: SortableItemProps<M>) {
|
|
140
|
+
const {
|
|
141
|
+
setNodeRef,
|
|
142
|
+
attributes,
|
|
143
|
+
listeners,
|
|
144
|
+
isDragging: isItemBeingDragged,
|
|
145
|
+
transform,
|
|
146
|
+
transition,
|
|
147
|
+
} = useSortable({
|
|
148
|
+
id: item.id,
|
|
149
|
+
data: {
|
|
150
|
+
type: "ITEM",
|
|
151
|
+
columnId
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
// Memoize style object to prevent object recreation on each render
|
|
156
|
+
const sortableStyle = useMemo(() => ({
|
|
157
|
+
transform: CSS.Transform.toString(transform),
|
|
158
|
+
transition,
|
|
159
|
+
zIndex: isItemBeingDragged ? 2 : 1,
|
|
160
|
+
opacity: isItemBeingDragged ? 0 : 1,
|
|
161
|
+
}), [transform, transition, isItemBeingDragged]);
|
|
162
|
+
|
|
163
|
+
return (
|
|
164
|
+
<div ref={setNodeRef} style={sortableStyle} {...attributes} {...listeners}>
|
|
165
|
+
<ItemComponent
|
|
166
|
+
item={item}
|
|
167
|
+
isDragging={isItemBeingDragged}
|
|
168
|
+
index={index}
|
|
169
|
+
/>
|
|
170
|
+
</div>
|
|
171
|
+
);
|
|
172
|
+
}) as <M extends Record<string, any>>(props: SortableItemProps<M>) => React.ReactElement;
|