ydb-embedded-ui 9.3.0 → 9.4.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/dist/components/AutoRefreshControl/i18n/index.d.ts +1 -1
- package/dist/components/Drawer/Drawer.d.ts +2 -1
- package/dist/components/Drawer/Drawer.js +10 -6
- package/dist/components/Drawer/Drawer.js.map +1 -1
- package/dist/components/Drawer/DrawerContext.d.ts +1 -0
- package/dist/components/Drawer/DrawerContext.js +5 -2
- package/dist/components/Drawer/DrawerContext.js.map +1 -1
- package/dist/{containers/Storage → components}/EmptyFilter/EmptyFilter.js +2 -2
- package/dist/components/EmptyFilter/EmptyFilter.js.map +1 -0
- package/dist/{containers/App → components/EmptyFilter}/i18n/index.js +1 -1
- package/dist/components/EmptyFilter/i18n/index.js.map +1 -0
- package/dist/components/EmptyState/EmptyState.d.ts +1 -0
- package/dist/components/EmptyState/EmptyState.js +1 -0
- package/dist/components/EmptyState/EmptyState.js.map +1 -1
- package/dist/components/EmptyState/EmptyState.scss +9 -0
- package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js +3 -2
- package/dist/components/EnableFullscreenButton/EnableFullscreenButton.js.map +1 -1
- package/dist/components/EnableFullscreenButton/i18n/en.json +3 -0
- package/dist/components/EnableFullscreenButton/i18n/index.d.ts +2 -0
- package/dist/components/EnableFullscreenButton/i18n/index.js +5 -0
- package/dist/components/EnableFullscreenButton/i18n/index.js.map +1 -0
- package/dist/components/FixedHeightQuery/FixedHeightQuery.d.ts +9 -0
- package/dist/components/FixedHeightQuery/FixedHeightQuery.js +23 -0
- package/dist/components/FixedHeightQuery/FixedHeightQuery.js.map +1 -0
- package/dist/components/FixedHeightQuery/FixedHeightQuery.scss +42 -0
- package/dist/components/HealthcheckStatus/HealthcheckStatus.d.ts +8 -0
- package/dist/components/HealthcheckStatus/HealthcheckStatus.js +41 -0
- package/dist/components/HealthcheckStatus/HealthcheckStatus.js.map +1 -0
- package/dist/components/HealthcheckStatus/i18n/en.json +7 -0
- package/dist/components/HealthcheckStatus/i18n/index.d.ts +2 -0
- package/dist/components/HealthcheckStatus/i18n/index.js +5 -0
- package/dist/components/HealthcheckStatus/i18n/index.js.map +1 -0
- package/dist/components/PaginatedTable/PaginatedTable.js +21 -21
- package/dist/components/PaginatedTable/PaginatedTable.js.map +1 -1
- package/dist/components/PaginatedTable/PaginatedTableContext.d.ts +3 -1
- package/dist/components/PaginatedTable/PaginatedTableContext.js +3 -2
- package/dist/components/PaginatedTable/PaginatedTableContext.js.map +1 -1
- package/dist/components/PaginatedTable/PaginatedTableWithLayout.d.ts +5 -4
- package/dist/components/PaginatedTable/PaginatedTableWithLayout.js +29 -2
- package/dist/components/PaginatedTable/PaginatedTableWithLayout.js.map +1 -1
- package/dist/components/PaginatedTable/TableChunk.d.ts +3 -2
- package/dist/components/PaginatedTable/TableChunk.js +12 -18
- package/dist/components/PaginatedTable/TableChunk.js.map +1 -1
- package/dist/components/PaginatedTable/TableChunksRenderer.d.ts +21 -0
- package/dist/components/PaginatedTable/TableChunksRenderer.js +96 -0
- package/dist/components/PaginatedTable/TableChunksRenderer.js.map +1 -0
- package/dist/components/PaginatedTable/TableRow.d.ts +2 -1
- package/dist/components/PaginatedTable/TableRow.js +4 -4
- package/dist/components/PaginatedTable/TableRow.js.map +1 -1
- package/dist/components/PaginatedTable/requestBatcher.d.ts +28 -0
- package/dist/components/PaginatedTable/requestBatcher.js +128 -0
- package/dist/components/PaginatedTable/requestBatcher.js.map +1 -0
- package/dist/components/PaginatedTable/useScrollBasedChunks.d.ts +8 -2
- package/dist/components/PaginatedTable/useScrollBasedChunks.js +35 -20
- package/dist/components/PaginatedTable/useScrollBasedChunks.js.map +1 -1
- package/dist/components/ProgressViewer/ProgressViewer.d.ts +2 -1
- package/dist/components/ProgressViewer/ProgressViewer.js +3 -2
- package/dist/components/ProgressViewer/ProgressViewer.js.map +1 -1
- package/dist/components/ResizeableDataTable/ResizeableDataTable.d.ts +3 -2
- package/dist/components/ResizeableDataTable/ResizeableDataTable.js +7 -2
- package/dist/components/ResizeableDataTable/ResizeableDataTable.js.map +1 -1
- package/dist/components/SplitPane/SplitPane.scss +0 -1
- package/dist/components/TableWithControlsLayout/TableWithControlsLayout.d.ts +4 -3
- package/dist/components/TableWithControlsLayout/TableWithControlsLayout.js.map +1 -1
- package/dist/containers/App/Content.js +18 -14
- package/dist/containers/App/Content.js.map +1 -1
- package/dist/containers/Clusters/Clusters.js +19 -7
- package/dist/containers/Clusters/Clusters.js.map +1 -1
- package/dist/containers/Clusters/Clusters.scss +7 -53
- package/dist/containers/Clusters/columns.d.ts +18 -1
- package/dist/containers/Clusters/columns.js +43 -9
- package/dist/containers/Clusters/columns.js.map +1 -1
- package/dist/containers/Clusters/i18n/en.json +3 -1
- package/dist/containers/Clusters/i18n/index.d.ts +1 -1
- package/dist/containers/Clusters/i18n/index.js +1 -2
- package/dist/containers/Clusters/i18n/index.js.map +1 -1
- package/dist/containers/Header/Header.d.ts +1 -5
- package/dist/containers/Header/Header.js +14 -10
- package/dist/containers/Header/Header.js.map +1 -1
- package/dist/containers/Header/Header.scss +1 -1
- package/dist/containers/Header/breadcrumbs.d.ts +3 -1
- package/dist/containers/Header/breadcrumbs.js +18 -6
- package/dist/containers/Header/breadcrumbs.js.map +1 -1
- package/dist/containers/Header/i18n/en.json +3 -1
- package/dist/containers/Header/i18n/index.d.ts +1 -1
- package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js +5 -3
- package/dist/containers/Nodes/PaginatedNodes/GroupedNodesComponent.js.map +1 -1
- package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js +2 -2
- package/dist/containers/Nodes/PaginatedNodes/NodesComponent.js.map +1 -1
- package/dist/containers/Operations/columns.js +2 -2
- package/dist/containers/Operations/columns.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js +4 -2
- package/dist/containers/Storage/PaginatedStorageGroups/GroupedStorageGroupsComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js +2 -2
- package/dist/containers/Storage/PaginatedStorageGroups/StorageGroupsComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/StorageGroupsEmptyDataMessage.js +1 -1
- package/dist/containers/Storage/PaginatedStorageGroupsTable/StorageGroupsEmptyDataMessage.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js +4 -2
- package/dist/containers/Storage/PaginatedStorageNodes/GroupedStorageNodesComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js +2 -2
- package/dist/containers/Storage/PaginatedStorageNodes/StorageNodesComponent.js.map +1 -1
- package/dist/containers/Storage/PaginatedStorageNodesTable/StorageNodesEmptyDataMessage.js +1 -1
- package/dist/containers/Storage/PaginatedStorageNodesTable/StorageNodesEmptyDataMessage.js.map +1 -1
- package/dist/containers/Tablet/components/TabletStorageInfo/i18n/index.d.ts +1 -1
- package/dist/containers/Tablets/TabletsTable.js +3 -1
- package/dist/containers/Tablets/TabletsTable.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.js +30 -29
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckPreview.scss +41 -0
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/en.json +8 -6
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.js +1 -2
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/index.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.d.ts +3 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.js +9 -2
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricCard/MetricCard.scss +7 -0
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.d.ts +2 -2
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.js +27 -8
- package/dist/containers/Tenant/Diagnostics/TenantOverview/MetricsCards/MetricsCards.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js +5 -10
- package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/TenantOverview.scss +1 -5
- package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/en.json +2 -0
- package/dist/containers/Tenant/Diagnostics/TenantOverview/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js +11 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/TopQueriesData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/columns/columns.js +2 -3
- package/dist/containers/Tenant/Diagnostics/TopQueries/columns/columns.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.d.ts +19 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.js +31 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/hooks/useScrollToSelected.js.map +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js +1 -0
- package/dist/containers/Tenant/Diagnostics/TopQueries/utils.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js +3 -3
- package/dist/containers/Tenant/Diagnostics/TopicData/TopicData.js.map +1 -1
- package/dist/containers/Tenant/Diagnostics/TopicData/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/Healthcheck/Healthcheck.d.ts +9 -0
- package/dist/containers/Tenant/Healthcheck/Healthcheck.js +49 -0
- package/dist/containers/Tenant/Healthcheck/Healthcheck.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/Healthcheck.scss +112 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.d.ts +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.js +9 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckFilter.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.d.ts +7 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.js +25 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssue.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.d.ts +9 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.js +67 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/ComputeLocation.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.d.ts +6 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.js +67 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/HealthcheckIssueDetails.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.d.ts +7 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.js +19 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/NodeInfo.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.d.ts +6 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.js +12 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/PoolInfo.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.d.ts +9 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.js +95 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/StorageLocation.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.d.ts +25 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.js +17 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueDetails/utils.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.d.ts +8 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.js +23 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssueTabs.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.d.ts +6 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js +41 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckIssues.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.d.ts +6 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.js +47 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckRefresh.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.d.ts +8 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js +42 -0
- package/dist/containers/Tenant/Healthcheck/components/HealthcheckView.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/i18n/en.json +41 -0
- package/dist/containers/Tenant/Healthcheck/i18n/index.d.ts +2 -0
- package/dist/containers/Tenant/Healthcheck/i18n/index.js +5 -0
- package/dist/containers/Tenant/Healthcheck/i18n/index.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/shared.d.ts +11 -0
- package/dist/containers/Tenant/Healthcheck/shared.js +36 -0
- package/dist/containers/Tenant/Healthcheck/shared.js.map +1 -0
- package/dist/containers/Tenant/Healthcheck/useHealthcheck.d.ts +14 -0
- package/dist/containers/Tenant/Healthcheck/useHealthcheck.js +19 -0
- package/dist/containers/Tenant/Healthcheck/useHealthcheck.js.map +1 -0
- package/dist/containers/Tenant/Query/Preview/components/TopicPreview.js +1 -1
- package/dist/containers/Tenant/Query/Preview/components/TopicPreview.js.map +1 -1
- package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.js +1 -1
- package/dist/containers/Tenant/Query/QueryEditorControls/QueryEditorControls.js.map +1 -1
- package/dist/containers/Tenant/Query/QueryResult/components/QueryInfoDropdown/useQueryInfoMenuItems.js +1 -1
- package/dist/containers/Tenant/Query/QueryResult/components/QueryInfoDropdown/useQueryInfoMenuItems.js.map +1 -1
- package/dist/containers/Tenant/Tenant.js +14 -25
- package/dist/containers/Tenant/Tenant.js.map +1 -1
- package/dist/containers/Tenant/TenantDrawerWrappers.d.ts +7 -0
- package/dist/containers/Tenant/TenantDrawerWrappers.js +47 -0
- package/dist/containers/Tenant/TenantDrawerWrappers.js.map +1 -0
- package/dist/containers/Tenant/TenantPages.d.ts +2 -0
- package/dist/containers/Tenant/TenantPages.js.map +1 -1
- package/dist/containers/Tenant/constants.d.ts +4 -0
- package/dist/containers/Tenant/constants.js +18 -0
- package/dist/containers/Tenant/constants.js.map +1 -0
- package/dist/containers/Tenant/i18n/en.json +7 -1
- package/dist/containers/Tenant/i18n/index.d.ts +1 -1
- package/dist/containers/Tenant/useTenantQueryParams.d.ts +12 -0
- package/dist/containers/Tenant/useTenantQueryParams.js +39 -0
- package/dist/containers/Tenant/useTenantQueryParams.js.map +1 -0
- package/dist/containers/Tenant/utils/schemaActions.js +2 -2
- package/dist/containers/Tenant/utils/schemaActions.js.map +1 -1
- package/dist/containers/Tenants/Tenants.js +8 -2
- package/dist/containers/Tenants/Tenants.js.map +1 -1
- package/dist/containers/UserSettings/i18n/en.json +1 -1
- package/dist/services/api/streaming.js +1 -0
- package/dist/services/api/streaming.js.map +1 -1
- package/dist/store/reducers/capabilities/hooks.d.ts +3 -0
- package/dist/store/reducers/capabilities/hooks.js +9 -0
- package/dist/store/reducers/capabilities/hooks.js.map +1 -1
- package/dist/store/reducers/clusters/selectors.d.ts +1 -2
- package/dist/store/reducers/clusters/selectors.js +0 -28
- package/dist/store/reducers/clusters/selectors.js.map +1 -1
- package/dist/store/reducers/clusters/types.d.ts +0 -10
- package/dist/store/reducers/header/types.d.ts +4 -2
- package/dist/store/reducers/healthcheckInfo/healthcheckInfo.d.ts +631 -331
- package/dist/store/reducers/healthcheckInfo/healthcheckInfo.js +8 -35
- package/dist/store/reducers/healthcheckInfo/healthcheckInfo.js.map +1 -1
- package/dist/store/reducers/healthcheckInfo/types.d.ts +2 -0
- package/dist/store/reducers/healthcheckInfo/utils.d.ts +3 -0
- package/dist/store/reducers/healthcheckInfo/utils.js +34 -0
- package/dist/store/reducers/healthcheckInfo/utils.js.map +1 -1
- package/dist/store/reducers/tableData.d.ts +1 -0
- package/dist/store/reducers/tableData.js +29 -10
- package/dist/store/reducers/tableData.js.map +1 -1
- package/dist/store/reducers/tenant/constants.d.ts +0 -1
- package/dist/store/reducers/tenant/constants.js +0 -1
- package/dist/store/reducers/tenant/constants.js.map +1 -1
- package/dist/store/reducers/tenants/utils.d.ts +2 -1
- package/dist/store/reducers/tenants/utils.js +15 -2
- package/dist/store/reducers/tenants/utils.js.map +1 -1
- package/dist/styles/index.scss +3 -0
- package/dist/types/api/capabilities.d.ts +1 -1
- package/dist/types/api/healthcheck.d.ts +80 -13
- package/dist/types/api/healthcheck.js +1 -0
- package/dist/types/api/healthcheck.js.map +1 -1
- package/dist/types/api/tenant.d.ts +4 -0
- package/dist/types/api/tenant.js.map +1 -1
- package/dist/uiFactory/types.d.ts +18 -0
- package/dist/uiFactory/uiFactory.js +6 -0
- package/dist/uiFactory/uiFactory.js.map +1 -1
- package/dist/utils/createToast.d.ts +2 -9
- package/dist/utils/createToast.js +5 -6
- package/dist/utils/createToast.js.map +1 -1
- package/package.json +1 -1
- package/dist/containers/App/i18n/en.json +0 -3
- package/dist/containers/App/i18n/index.d.ts +0 -2
- package/dist/containers/App/i18n/index.js.map +0 -1
- package/dist/containers/App/i18n/ru.json +0 -3
- package/dist/containers/Clusters/ClustersStatistics.d.ts +0 -7
- package/dist/containers/Clusters/ClustersStatistics.js +0 -10
- package/dist/containers/Clusters/ClustersStatistics.js.map +0 -1
- package/dist/containers/Clusters/i18n/ru.json +0 -15
- package/dist/containers/Storage/EmptyFilter/EmptyFilter.js.map +0 -1
- package/dist/containers/Storage/EmptyFilter/i18n/index.js +0 -6
- package/dist/containers/Storage/EmptyFilter/i18n/index.js.map +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/Healthcheck.scss +0 -106
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.d.ts +0 -6
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.js +0 -34
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/HealthcheckDetails.js.map +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.d.ts +0 -7
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.js +0 -37
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.js.map +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTree.scss +0 -51
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.d.ts +0 -10
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.js +0 -9
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.js.map +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/IssueTreeItem.scss +0 -50
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.d.ts +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.js +0 -2
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/IssuesViewer/IssueTreeItem/index.js.map +0 -1
- package/dist/containers/Tenant/Diagnostics/TenantOverview/Healthcheck/i18n/ru.json +0 -8
- package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.d.ts +0 -15
- package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.js +0 -20
- package/dist/containers/Tenant/Diagnostics/TenantOverview/useHealthcheck.js.map +0 -1
- /package/dist/{containers/Storage → components}/EmptyFilter/EmptyFilter.d.ts +0 -0
- /package/dist/{containers/Storage → components}/EmptyFilter/i18n/en.json +0 -0
- /package/dist/{containers/Storage → components}/EmptyFilter/i18n/index.d.ts +0 -0
- /package/dist/{containers/Storage → components}/EmptyFilter/i18n/ru.json +0 -0
@@ -1,12 +1,13 @@
|
|
1
1
|
import React from 'react';
|
2
|
-
import type {
|
2
|
+
import type { TableWrapperProps } from '../TableWithControlsLayout/TableWithControlsLayout';
|
3
3
|
import type { PaginatedTableState } from './types';
|
4
4
|
export interface PaginatedTableWithLayoutProps {
|
5
|
-
controls
|
5
|
+
controls?: React.ReactNode;
|
6
6
|
table: React.ReactNode;
|
7
|
-
|
7
|
+
tableWrapperProps?: Omit<TableWrapperProps, 'children'>;
|
8
8
|
error?: React.ReactNode;
|
9
9
|
initialState?: Partial<PaginatedTableState>;
|
10
10
|
fullHeight?: boolean;
|
11
|
+
noBatching?: boolean;
|
11
12
|
}
|
12
|
-
export declare const PaginatedTableWithLayout: ({ controls, table,
|
13
|
+
export declare const PaginatedTableWithLayout: ({ controls, table, tableWrapperProps, error, initialState, noBatching, fullHeight, }: PaginatedTableWithLayoutProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,5 +1,32 @@
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
2
|
+
import React from 'react';
|
2
3
|
import { TableWithControlsLayout } from '../TableWithControlsLayout/TableWithControlsLayout';
|
3
|
-
import { PaginatedTableProvider } from './PaginatedTableContext';
|
4
|
-
|
4
|
+
import { PaginatedTableProvider, usePaginatedTableState } from './PaginatedTableContext';
|
5
|
+
const TableWrapper = ({ table, tableWrapperProps, }) => {
|
6
|
+
const { tableState } = usePaginatedTableState();
|
7
|
+
const { sortParams } = tableState;
|
8
|
+
const enhancedTableWrapperProps = React.useMemo(() => {
|
9
|
+
const existingScrollDependencies = (tableWrapperProps === null || tableWrapperProps === void 0 ? void 0 : tableWrapperProps.scrollDependencies) || [];
|
10
|
+
return {
|
11
|
+
...tableWrapperProps,
|
12
|
+
scrollDependencies: [...existingScrollDependencies, sortParams],
|
13
|
+
};
|
14
|
+
}, [tableWrapperProps, sortParams]);
|
15
|
+
return (_jsx(TableWithControlsLayout.Table, { ...enhancedTableWrapperProps, children: table }));
|
16
|
+
};
|
17
|
+
const ControlsSection = ({ controls }) => {
|
18
|
+
if (!controls) {
|
19
|
+
return null;
|
20
|
+
}
|
21
|
+
return _jsx(TableWithControlsLayout.Controls, { children: controls });
|
22
|
+
};
|
23
|
+
const ErrorSection = ({ error }) => {
|
24
|
+
if (!error) {
|
25
|
+
return null;
|
26
|
+
}
|
27
|
+
return _jsx(React.Fragment, { children: error });
|
28
|
+
};
|
29
|
+
export const PaginatedTableWithLayout = ({ controls, table, tableWrapperProps, error, initialState, noBatching, fullHeight = true, }) => {
|
30
|
+
return (_jsx(PaginatedTableProvider, { initialState: initialState, noBatching: noBatching, children: _jsxs(TableWithControlsLayout, { fullHeight: fullHeight, children: [_jsx(ControlsSection, { controls: controls }), _jsx(ErrorSection, { error: error }), _jsx(TableWrapper, { table: table, tableWrapperProps: tableWrapperProps })] }) }));
|
31
|
+
};
|
5
32
|
//# sourceMappingURL=PaginatedTableWithLayout.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"PaginatedTableWithLayout.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/PaginatedTableWithLayout.tsx"],"names":[],"mappings":";
|
1
|
+
{"version":3,"file":"PaginatedTableWithLayout.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/PaginatedTableWithLayout.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,uBAAuB,EAAC,MAAM,oDAAoD,CAAC;AAG3F,OAAO,EAAC,sBAAsB,EAAE,sBAAsB,EAAC,MAAM,yBAAyB,CAAC;AAavF,MAAM,YAAY,GAAG,CAAC,EAClB,KAAK,EACL,iBAAiB,GAIpB,EAAE,EAAE;IACD,MAAM,EAAC,UAAU,EAAC,GAAG,sBAAsB,EAAE,CAAC;IAC9C,MAAM,EAAC,UAAU,EAAC,GAAG,UAAU,CAAC;IAEhC,MAAM,yBAAyB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACjD,MAAM,0BAA0B,GAAG,CAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,kBAAkB,KAAI,EAAE,CAAC;QAE/E,OAAO;YACH,GAAG,iBAAiB;YACpB,kBAAkB,EAAE,CAAC,GAAG,0BAA0B,EAAE,UAAU,CAAC;SAClE,CAAC;IACN,CAAC,EAAE,CAAC,iBAAiB,EAAE,UAAU,CAAC,CAAC,CAAC;IAEpC,OAAO,CACH,KAAC,uBAAuB,CAAC,KAAK,OAAK,yBAAyB,YACvD,KAAK,GACsB,CACnC,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,eAAe,GAAG,CAAC,EAAC,QAAQ,EAA+B,EAAE,EAAE;IACjE,IAAI,CAAC,QAAQ,EAAE,CAAC;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,KAAC,uBAAuB,CAAC,QAAQ,cAAE,QAAQ,GAAoC,CAAC;AAC3F,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,EAAC,KAAK,EAA4B,EAAE,EAAE;IACxD,IAAI,CAAC,KAAK,EAAE,CAAC;QACT,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,OAAO,KAAC,KAAK,CAAC,QAAQ,cAAE,KAAK,GAAkB,CAAC;AACpD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,EACrC,QAAQ,EACR,KAAK,EACL,iBAAiB,EACjB,KAAK,EACL,YAAY,EACZ,UAAU,EACV,UAAU,GAAG,IAAI,GACW,EAAE,EAAE;IAChC,OAAO,CACH,KAAC,sBAAsB,IAAC,YAAY,EAAE,YAAY,EAAE,UAAU,EAAE,UAAU,YACtE,MAAC,uBAAuB,IAAC,UAAU,EAAE,UAAU,aAC3C,KAAC,eAAe,IAAC,QAAQ,EAAE,QAAQ,GAAI,EACvC,KAAC,YAAY,IAAC,KAAK,EAAE,KAAK,GAAI,EAC9B,KAAC,YAAY,IAAC,KAAK,EAAE,KAAK,EAAE,iBAAiB,EAAE,iBAAiB,GAAI,IAC9C,GACL,CAC5B,CAAC;AACN,CAAC,CAAC"}
|
@@ -7,7 +7,8 @@ interface TableChunkProps<T, F> {
|
|
7
7
|
columns: Column<T>[];
|
8
8
|
filters?: F;
|
9
9
|
sortParams?: SortParams;
|
10
|
-
|
10
|
+
shouldFetch: boolean;
|
11
|
+
shouldRender: boolean;
|
11
12
|
tableName: string;
|
12
13
|
fetchData: FetchData<T, F>;
|
13
14
|
getRowClassName?: GetRowClassName<T>;
|
@@ -16,5 +17,5 @@ interface TableChunkProps<T, F> {
|
|
16
17
|
onDataFetched: (data?: PaginatedTableData<T>) => void;
|
17
18
|
keepCache?: boolean;
|
18
19
|
}
|
19
|
-
export declare const TableChunk: <T, F>({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched,
|
20
|
+
export declare const TableChunk: <T, F>({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, shouldFetch, shouldRender, keepCache, }: TableChunkProps<T, F>) => import("react/jsx-runtime").JSX.Element | import("react/jsx-runtime").JSX.Element[] | null;
|
20
21
|
export {};
|
@@ -4,15 +4,17 @@ import { tableDataApi } from '../../store/reducers/tableData';
|
|
4
4
|
import { getArray } from '../../utils';
|
5
5
|
import { useAutoRefreshInterval } from '../../utils/hooks';
|
6
6
|
import { ResponseError } from '../Errors/ResponseError';
|
7
|
+
import { usePaginatedTableState } from './PaginatedTableContext';
|
7
8
|
import { EmptyTableRow, LoadingTableRow, TableRow } from './TableRow';
|
8
9
|
import i18n from './i18n';
|
9
10
|
import { typedMemo } from './utils';
|
10
11
|
const DEBOUNCE_TIMEOUT = 200;
|
11
12
|
// Memoisation prevents chunks rerenders that could cause perfomance issues on big tables
|
12
|
-
export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched,
|
13
|
+
export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calculatedCount, rowHeight, columns, fetchData, tableName, filters, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, shouldFetch, shouldRender, keepCache, }) {
|
13
14
|
var _a;
|
14
15
|
const [isTimeoutActive, setIsTimeoutActive] = React.useState(true);
|
15
16
|
const [autoRefreshInterval] = useAutoRefreshInterval();
|
17
|
+
const { noBatching } = usePaginatedTableState();
|
16
18
|
const columnsIds = columns.map((column) => column.name);
|
17
19
|
const queryParams = {
|
18
20
|
offset: id * chunkSize,
|
@@ -22,16 +24,17 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
|
|
22
24
|
sortParams,
|
23
25
|
columnsIds,
|
24
26
|
tableName,
|
27
|
+
noBatching,
|
25
28
|
};
|
26
29
|
tableDataApi.useFetchTableChunkQuery(queryParams, {
|
27
|
-
skip: isTimeoutActive || !
|
30
|
+
skip: isTimeoutActive || !shouldFetch,
|
28
31
|
pollingInterval: autoRefreshInterval,
|
29
32
|
refetchOnMountOrArgChange: !keepCache,
|
30
33
|
});
|
31
34
|
const { currentData, error } = tableDataApi.endpoints.fetchTableChunk.useQueryState(queryParams);
|
32
35
|
React.useEffect(() => {
|
33
36
|
let timeout = 0;
|
34
|
-
if (
|
37
|
+
if (shouldFetch && isTimeoutActive) {
|
35
38
|
timeout = window.setTimeout(() => {
|
36
39
|
setIsTimeoutActive(false);
|
37
40
|
}, DEBOUNCE_TIMEOUT);
|
@@ -39,9 +42,9 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
|
|
39
42
|
return () => {
|
40
43
|
window.clearTimeout(timeout);
|
41
44
|
};
|
42
|
-
}, [
|
45
|
+
}, [shouldFetch, isTimeoutActive]);
|
43
46
|
React.useEffect(() => {
|
44
|
-
if (currentData
|
47
|
+
if (currentData) {
|
45
48
|
onDataFetched({
|
46
49
|
...currentData,
|
47
50
|
data: currentData.data,
|
@@ -49,17 +52,14 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
|
|
49
52
|
total: currentData.total || 0,
|
50
53
|
});
|
51
54
|
}
|
52
|
-
}, [currentData,
|
55
|
+
}, [currentData, onDataFetched]);
|
53
56
|
const dataLength = ((_a = currentData === null || currentData === void 0 ? void 0 : currentData.data) === null || _a === void 0 ? void 0 : _a.length) || calculatedCount;
|
54
57
|
const renderContent = () => {
|
55
58
|
var _a;
|
56
|
-
if (!isActive) {
|
57
|
-
return null;
|
58
|
-
}
|
59
59
|
if (!currentData) {
|
60
60
|
if (error) {
|
61
61
|
const errorData = error;
|
62
|
-
return (_jsx(EmptyTableRow, { columns: columns, children: renderErrorMessage ? (renderErrorMessage(errorData)) : (_jsx(ResponseError, { error: errorData })) }));
|
62
|
+
return (_jsx(EmptyTableRow, { columns: columns, height: dataLength * rowHeight, children: renderErrorMessage ? (renderErrorMessage(errorData)) : (_jsx(ResponseError, { error: errorData })) }));
|
63
63
|
}
|
64
64
|
else {
|
65
65
|
return getArray(dataLength).map((value) => (_jsx(LoadingTableRow, { columns: columns, height: rowHeight }, value)));
|
@@ -67,16 +67,10 @@ export const TableChunk = typedMemo(function TableChunk({ id, chunkSize, calcula
|
|
67
67
|
}
|
68
68
|
// Data is loaded, but there are no entities in the chunk
|
69
69
|
if (!((_a = currentData.data) === null || _a === void 0 ? void 0 : _a.length)) {
|
70
|
-
return (_jsx(EmptyTableRow, { columns: columns, children: renderEmptyDataMessage ? renderEmptyDataMessage() : i18n('empty') }));
|
70
|
+
return (_jsx(EmptyTableRow, { columns: columns, height: dataLength * rowHeight, children: renderEmptyDataMessage ? renderEmptyDataMessage() : i18n('empty') }));
|
71
71
|
}
|
72
72
|
return currentData.data.map((rowData, index) => (_jsx(TableRow, { row: rowData, columns: columns, height: rowHeight, getRowClassName: getRowClassName }, index)));
|
73
73
|
};
|
74
|
-
return
|
75
|
-
height: `${dataLength * rowHeight}px`,
|
76
|
-
// Default display: table-row-group doesn't work in Safari and breaks the table
|
77
|
-
// display: block works in Safari, but disconnects thead and tbody cell grids
|
78
|
-
// Hack to make it work in all cases
|
79
|
-
display: isActive ? 'table-row-group' : 'block',
|
80
|
-
}, children: renderContent() }));
|
74
|
+
return shouldRender ? renderContent() : null;
|
81
75
|
});
|
82
76
|
//# sourceMappingURL=TableChunk.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"TableChunk.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunk.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAC,YAAY,EAAC,MAAM,gCAAgC,CAAC;AAE5D,OAAO,EAAC,QAAQ,EAAC,MAAM,aAAa,CAAC;AACrC,OAAO,EAAC,sBAAsB,EAAC,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAC,aAAa,EAAE,eAAe,EAAE,QAAQ,EAAC,MAAM,YAAY,CAAC;AACpE,OAAO,IAAI,MAAM,QAAQ,CAAC;AAU1B,OAAO,EAAC,SAAS,EAAC,MAAM,SAAS,CAAC;AAElC,MAAM,gBAAgB,GAAG,GAAG,CAAC;
|
1
|
+
{"version":3,"file":"TableChunk.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunk.tsx"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import type { Column, FetchData, GetRowClassName, PaginatedTableData, RenderEmptyDataMessage, RenderErrorMessage, SortParams } from './types';
|
3
|
+
export interface TableChunksRendererProps<T, F> {
|
4
|
+
scrollContainerRef: React.RefObject<HTMLElement>;
|
5
|
+
tableRef: React.RefObject<HTMLElement>;
|
6
|
+
foundEntities: number;
|
7
|
+
tableOffset: number;
|
8
|
+
chunkSize: number;
|
9
|
+
rowHeight: number;
|
10
|
+
columns: Column<T>[];
|
11
|
+
fetchData: FetchData<T, F>;
|
12
|
+
filters?: F;
|
13
|
+
tableName: string;
|
14
|
+
sortParams?: SortParams;
|
15
|
+
getRowClassName?: GetRowClassName<T>;
|
16
|
+
renderErrorMessage?: RenderErrorMessage;
|
17
|
+
renderEmptyDataMessage?: RenderEmptyDataMessage;
|
18
|
+
onDataFetched: (data?: PaginatedTableData<T>) => void;
|
19
|
+
keepCache: boolean;
|
20
|
+
}
|
21
|
+
export declare const TableChunksRenderer: <T, F>({ scrollContainerRef, tableRef, foundEntities, tableOffset, chunkSize, rowHeight, columns, fetchData, filters, tableName, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, keepCache, }: TableChunksRendererProps<T, F>) => import("react/jsx-runtime").JSX.Element;
|
@@ -0,0 +1,96 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import React from 'react';
|
3
|
+
import { TableChunk } from './TableChunk';
|
4
|
+
import { b } from './shared';
|
5
|
+
import { useScrollBasedChunks } from './useScrollBasedChunks';
|
6
|
+
export const TableChunksRenderer = ({ scrollContainerRef, tableRef, foundEntities, tableOffset, chunkSize, rowHeight, columns, fetchData, filters, tableName, sortParams, getRowClassName, renderErrorMessage, renderEmptyDataMessage, onDataFetched, keepCache, }) => {
|
7
|
+
const chunkStates = useScrollBasedChunks({
|
8
|
+
scrollContainerRef,
|
9
|
+
tableRef,
|
10
|
+
totalItems: foundEntities || 1,
|
11
|
+
rowHeight,
|
12
|
+
chunkSize,
|
13
|
+
tableOffset,
|
14
|
+
});
|
15
|
+
const lastChunkSize = React.useMemo(() => {
|
16
|
+
// If foundEntities = 0, there will only first chunk
|
17
|
+
// Display it with 1 row, to display empty data message
|
18
|
+
if (!foundEntities) {
|
19
|
+
return 1;
|
20
|
+
}
|
21
|
+
return foundEntities % chunkSize || chunkSize;
|
22
|
+
}, [foundEntities, chunkSize]);
|
23
|
+
const findRenderChunkRange = React.useCallback(() => {
|
24
|
+
const firstRenderIndex = chunkStates.findIndex((state) => state.shouldRender);
|
25
|
+
const lastRenderIndex = chunkStates.findLastIndex((state) => state.shouldRender);
|
26
|
+
return { firstRenderIndex, lastRenderIndex };
|
27
|
+
}, [chunkStates]);
|
28
|
+
const findFetchChunkRange = React.useCallback(() => {
|
29
|
+
const firstFetchIndex = chunkStates.findIndex((state) => state.shouldFetch);
|
30
|
+
const lastFetchIndex = chunkStates.findLastIndex((state) => state.shouldFetch);
|
31
|
+
return { firstFetchIndex, lastFetchIndex };
|
32
|
+
}, [chunkStates]);
|
33
|
+
const calculateSeparatorHeight = React.useCallback((startIndex, endIndex) => {
|
34
|
+
let totalHeight = 0;
|
35
|
+
for (let i = startIndex; i < endIndex; i++) {
|
36
|
+
const currentChunkSize = i === chunkStates.length - 1 ? lastChunkSize : chunkSize;
|
37
|
+
totalHeight += currentChunkSize * rowHeight;
|
38
|
+
}
|
39
|
+
return totalHeight;
|
40
|
+
}, [chunkSize, chunkStates.length, lastChunkSize, rowHeight]);
|
41
|
+
const createSeparator = React.useCallback((startIndex, endIndex, key) => {
|
42
|
+
const height = calculateSeparatorHeight(startIndex, endIndex);
|
43
|
+
return (_jsx("tr", { style: { height: `${height}px` }, className: b(key), children: _jsx("td", { colSpan: columns.length, style: { padding: 0, border: 'none' } }) }, key));
|
44
|
+
}, [calculateSeparatorHeight, columns.length]);
|
45
|
+
const createChunk = React.useCallback((chunkIndex) => {
|
46
|
+
const chunkState = chunkStates[chunkIndex];
|
47
|
+
return (_jsx(TableChunk, { id: chunkIndex, calculatedCount: chunkIndex === chunkStates.length - 1 ? lastChunkSize : chunkSize, chunkSize: chunkSize, rowHeight: rowHeight, columns: columns, fetchData: fetchData, filters: filters, tableName: tableName, sortParams: sortParams, getRowClassName: getRowClassName, renderErrorMessage: renderErrorMessage, renderEmptyDataMessage: renderEmptyDataMessage, onDataFetched: onDataFetched, shouldFetch: chunkState.shouldFetch, shouldRender: chunkState.shouldRender, keepCache: keepCache }, chunkIndex));
|
48
|
+
}, [
|
49
|
+
chunkSize,
|
50
|
+
chunkStates,
|
51
|
+
columns,
|
52
|
+
fetchData,
|
53
|
+
filters,
|
54
|
+
getRowClassName,
|
55
|
+
keepCache,
|
56
|
+
lastChunkSize,
|
57
|
+
onDataFetched,
|
58
|
+
renderEmptyDataMessage,
|
59
|
+
renderErrorMessage,
|
60
|
+
rowHeight,
|
61
|
+
sortParams,
|
62
|
+
tableName,
|
63
|
+
]);
|
64
|
+
const renderChunks = React.useCallback(() => {
|
65
|
+
// Chunk states are distrubuted like [null, null, fetch, fetch, render+fetch, render+fetch, fetch, fetch, null, null]
|
66
|
+
// i.e. fetched chunks include rendered chunks
|
67
|
+
const { firstFetchIndex, lastFetchIndex } = findFetchChunkRange();
|
68
|
+
const { firstRenderIndex, lastRenderIndex } = findRenderChunkRange();
|
69
|
+
const elements = [];
|
70
|
+
// No fetch chunks found
|
71
|
+
if (firstFetchIndex === -1) {
|
72
|
+
return elements;
|
73
|
+
}
|
74
|
+
// Beginning separator (for chunks before first render chunk)
|
75
|
+
if (firstRenderIndex > 0) {
|
76
|
+
elements.push(createSeparator(0, firstRenderIndex, 'separator-beginning'));
|
77
|
+
}
|
78
|
+
// All fetch chunks (shouldFetch = true) get rendered as TableChunk components
|
79
|
+
for (let i = firstFetchIndex; i <= lastFetchIndex; i++) {
|
80
|
+
elements.push(createChunk(i));
|
81
|
+
}
|
82
|
+
// End separator (for chunks after last render chunk)
|
83
|
+
if (lastRenderIndex < chunkStates.length - 1) {
|
84
|
+
elements.push(createSeparator(lastRenderIndex + 1, chunkStates.length, 'separator-end'));
|
85
|
+
}
|
86
|
+
return elements;
|
87
|
+
}, [
|
88
|
+
chunkStates.length,
|
89
|
+
createChunk,
|
90
|
+
createSeparator,
|
91
|
+
findFetchChunkRange,
|
92
|
+
findRenderChunkRange,
|
93
|
+
]);
|
94
|
+
return _jsx(React.Fragment, { children: renderChunks() });
|
95
|
+
};
|
96
|
+
//# sourceMappingURL=TableChunksRenderer.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"TableChunksRenderer.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableChunksRenderer.tsx"],"names":[],"mappings":"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"}
|
@@ -14,6 +14,7 @@ export declare const TableRow: <T>({ row, columns, getRowClassName, height }: Ta
|
|
14
14
|
interface EmptyTableRowProps<T> {
|
15
15
|
columns: Column<T>[];
|
16
16
|
children?: React.ReactNode;
|
17
|
+
height: number;
|
17
18
|
}
|
18
|
-
export declare const EmptyTableRow: <T>({ columns, children }: EmptyTableRowProps<T>) => import("react/jsx-runtime").JSX.Element;
|
19
|
+
export declare const EmptyTableRow: <T>({ columns, children, height }: EmptyTableRowProps<T>) => import("react/jsx-runtime").JSX.Element;
|
19
20
|
export {};
|
@@ -12,7 +12,7 @@ const TableRowCell = ({ children, className, height, width, align = DEFAULT_ALIG
|
|
12
12
|
}, children: children }));
|
13
13
|
};
|
14
14
|
export const LoadingTableRow = typedMemo(function ({ columns, height }) {
|
15
|
-
return (_jsx("tr", { className: b('row', { loading: true }), children: columns.map((column) => {
|
15
|
+
return (_jsx("tr", { className: b('row', { loading: true }), style: { height }, children: columns.map((column) => {
|
16
16
|
var _a;
|
17
17
|
const resizeable = (_a = column.resizeable) !== null && _a !== void 0 ? _a : DEFAULT_RESIZEABLE;
|
18
18
|
return (_jsx(TableRowCell, { height: height, width: column.width, align: column.align, className: column.className, resizeable: resizeable, children: _jsx(Skeleton, { className: b('row-skeleton'), style: { width: '80%', height: '50%' } }) }, column.name));
|
@@ -20,13 +20,13 @@ export const LoadingTableRow = typedMemo(function ({ columns, height }) {
|
|
20
20
|
});
|
21
21
|
export const TableRow = ({ row, columns, getRowClassName, height }) => {
|
22
22
|
const additionalClassName = getRowClassName === null || getRowClassName === void 0 ? void 0 : getRowClassName(row);
|
23
|
-
return (_jsx("tr", { className: b('row', additionalClassName), children: columns.map((column) => {
|
23
|
+
return (_jsx("tr", { className: b('row', additionalClassName), style: { height }, children: columns.map((column) => {
|
24
24
|
var _a;
|
25
25
|
const resizeable = (_a = column.resizeable) !== null && _a !== void 0 ? _a : DEFAULT_RESIZEABLE;
|
26
26
|
return (_jsx(TableRowCell, { height: height, width: column.width, align: column.align, className: column.className, resizeable: resizeable, children: column.render({ row }) }, column.name));
|
27
27
|
}) }));
|
28
28
|
};
|
29
|
-
export const EmptyTableRow = ({ columns, children }) => {
|
30
|
-
return (_jsx("tr", { className: b('row', { empty: true }), children: _jsx("td", { colSpan: columns.length, className: b('td'), children: children }) }));
|
29
|
+
export const EmptyTableRow = ({ columns, children, height }) => {
|
30
|
+
return (_jsx("tr", { className: b('row', { empty: true }), style: { height }, children: _jsx("td", { colSpan: columns.length, className: b('td'), children: children }) }));
|
31
31
|
};
|
32
32
|
//# sourceMappingURL=TableRow.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"TableRow.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableRow.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,mBAAmB,CAAC;AAE3C,OAAO,EAAC,aAAa,EAAE,kBAAkB,EAAC,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAC,CAAC,EAAC,MAAM,UAAU,CAAC;AAE3B,OAAO,EAAC,SAAS,EAAC,MAAM,SAAS,CAAC;AAWlC,MAAM,YAAY,GAAG,CAAC,EAClB,QAAQ,EACR,SAAS,EACT,MAAM,EACN,KAAK,EACL,KAAK,GAAG,aAAa,EACrB,UAAU,GACG,EAAE,EAAE;IACjB,OAAO,CACH,aACI,SAAS,EAAE,CAAC,CAAC,UAAU,EAAE,EAAC,KAAK,EAAE,KAAK,EAAC,EAAE,SAAS,CAAC,EACnD,KAAK,EAAE;YACH,MAAM,EAAE,GAAG,MAAM,IAAI;YACrB,KAAK,EAAE,GAAG,KAAK,IAAI;YACnB,gFAAgF;YAChF,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS;SAClD,YAEA,QAAQ,GACR,CACR,CAAC;AACN,CAAC,CAAC;AAOF,MAAM,CAAC,MAAM,eAAe,GAAG,SAAS,CAAC,UAAa,EAAC,OAAO,EAAE,MAAM,EAA0B;IAC5F,OAAO,CACH,aAAI,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,EAAC,OAAO,EAAE,IAAI,EAAC,CAAC,
|
1
|
+
{"version":3,"file":"TableRow.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/TableRow.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,mBAAmB,CAAC;AAE3C,OAAO,EAAC,aAAa,EAAE,kBAAkB,EAAC,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAC,CAAC,EAAC,MAAM,UAAU,CAAC;AAE3B,OAAO,EAAC,SAAS,EAAC,MAAM,SAAS,CAAC;AAWlC,MAAM,YAAY,GAAG,CAAC,EAClB,QAAQ,EACR,SAAS,EACT,MAAM,EACN,KAAK,EACL,KAAK,GAAG,aAAa,EACrB,UAAU,GACG,EAAE,EAAE;IACjB,OAAO,CACH,aACI,SAAS,EAAE,CAAC,CAAC,UAAU,EAAE,EAAC,KAAK,EAAE,KAAK,EAAC,EAAE,SAAS,CAAC,EACnD,KAAK,EAAE;YACH,MAAM,EAAE,GAAG,MAAM,IAAI;YACrB,KAAK,EAAE,GAAG,KAAK,IAAI;YACnB,gFAAgF;YAChF,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS;SAClD,YAEA,QAAQ,GACR,CACR,CAAC;AACN,CAAC,CAAC;AAOF,MAAM,CAAC,MAAM,eAAe,GAAG,SAAS,CAAC,UAAa,EAAC,OAAO,EAAE,MAAM,EAA0B;IAC5F,OAAO,CACH,aAAI,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,EAAC,OAAO,EAAE,IAAI,EAAC,CAAC,EAAE,KAAK,EAAE,EAAC,MAAM,EAAC,YACpD,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;;YACpB,MAAM,UAAU,GAAG,MAAA,MAAM,CAAC,UAAU,mCAAI,kBAAkB,CAAC;YAE3D,OAAO,CACH,KAAC,YAAY,IAET,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,SAAS,EAAE,MAAM,CAAC,SAAS,EAC3B,UAAU,EAAE,UAAU,YAEtB,KAAC,QAAQ,IACL,SAAS,EAAE,CAAC,CAAC,cAAc,CAAC,EAC5B,KAAK,EAAE,EAAC,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAC,GACtC,IAVG,MAAM,CAAC,IAAI,CAWL,CAClB,CAAC;QACN,CAAC,CAAC,GACD,CACR,CAAC;AACN,CAAC,CAAC,CAAC;AASH,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAK,EAAC,GAAG,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,EAAmB,EAAE,EAAE;IACtF,MAAM,mBAAmB,GAAG,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,GAAG,CAAC,CAAC;IAEnD,OAAO,CACH,aAAI,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,mBAAmB,CAAC,EAAE,KAAK,EAAE,EAAC,MAAM,EAAC,YACxD,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;;YACpB,MAAM,UAAU,GAAG,MAAA,MAAM,CAAC,UAAU,mCAAI,kBAAkB,CAAC;YAE3D,OAAO,CACH,KAAC,YAAY,IAET,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,SAAS,EAAE,MAAM,CAAC,SAAS,EAC3B,UAAU,EAAE,UAAU,YAErB,MAAM,CAAC,MAAM,CAAC,EAAC,GAAG,EAAC,CAAC,IAPhB,MAAM,CAAC,IAAI,CAQL,CAClB,CAAC;QACN,CAAC,CAAC,GACD,CACR,CAAC;AACN,CAAC,CAAC;AAQF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAK,EAAC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAwB,EAAE,EAAE;IACpF,OAAO,CACH,aAAI,SAAS,EAAE,CAAC,CAAC,KAAK,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,EAAE,KAAK,EAAE,EAAC,MAAM,EAAC,YACnD,aAAI,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,YAC1C,QAAQ,GACR,GACJ,CACR,CAAC;AACN,CAAC,CAAC"}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
import type { FetchData, PaginatedTableData, SortParams } from './types';
|
2
|
+
interface PaginatedTableParams<T, F> {
|
3
|
+
offset: number;
|
4
|
+
fetchData: FetchData<T, F>;
|
5
|
+
filters: F;
|
6
|
+
limit: number;
|
7
|
+
sortParams?: SortParams;
|
8
|
+
columnsIds: string[];
|
9
|
+
tableName: string;
|
10
|
+
}
|
11
|
+
declare class RequestBatcher {
|
12
|
+
private requestQueue;
|
13
|
+
private batchTimeout;
|
14
|
+
private readonly BATCH_DELAY;
|
15
|
+
queueRequest<T, F>(params: PaginatedTableParams<T, F>, signal?: AbortSignal): Promise<{
|
16
|
+
data: PaginatedTableData<T>;
|
17
|
+
} | {
|
18
|
+
error: unknown;
|
19
|
+
}>;
|
20
|
+
private createBatchKey;
|
21
|
+
private groupConsecutiveRequests;
|
22
|
+
private createBatchGroup;
|
23
|
+
private executeBatch;
|
24
|
+
private splitAndDistributeResponse;
|
25
|
+
private processBatch;
|
26
|
+
}
|
27
|
+
export declare const requestBatcher: RequestBatcher;
|
28
|
+
export {};
|
@@ -0,0 +1,128 @@
|
|
1
|
+
class RequestBatcher {
|
2
|
+
constructor() {
|
3
|
+
this.requestQueue = new Map();
|
4
|
+
this.batchTimeout = null;
|
5
|
+
this.BATCH_DELAY = 50; // ms
|
6
|
+
}
|
7
|
+
queueRequest(params, signal) {
|
8
|
+
return new Promise((resolve, reject) => {
|
9
|
+
const batchKey = this.createBatchKey(params);
|
10
|
+
if (!this.requestQueue.has(batchKey)) {
|
11
|
+
this.requestQueue.set(batchKey, []);
|
12
|
+
}
|
13
|
+
this.requestQueue.get(batchKey).push({
|
14
|
+
params,
|
15
|
+
resolve,
|
16
|
+
reject,
|
17
|
+
signal,
|
18
|
+
});
|
19
|
+
// Reset the batch timeout
|
20
|
+
if (this.batchTimeout) {
|
21
|
+
clearTimeout(this.batchTimeout);
|
22
|
+
}
|
23
|
+
this.batchTimeout = setTimeout(() => {
|
24
|
+
this.processBatch();
|
25
|
+
}, this.BATCH_DELAY);
|
26
|
+
});
|
27
|
+
}
|
28
|
+
createBatchKey(params) {
|
29
|
+
return JSON.stringify({
|
30
|
+
tableName: params.tableName,
|
31
|
+
filters: params.filters,
|
32
|
+
sortParams: params.sortParams,
|
33
|
+
columnsIds: params.columnsIds,
|
34
|
+
limit: params.limit,
|
35
|
+
});
|
36
|
+
}
|
37
|
+
groupConsecutiveRequests(requests) {
|
38
|
+
if (requests.length === 0) {
|
39
|
+
return [];
|
40
|
+
}
|
41
|
+
const sorted = requests.sort((a, b) => a.params.offset - b.params.offset);
|
42
|
+
const groups = [];
|
43
|
+
let currentGroup = [sorted[0]];
|
44
|
+
const limit = sorted[0].params.limit;
|
45
|
+
for (let i = 1; i < sorted.length; i++) {
|
46
|
+
const expectedOffset = currentGroup[currentGroup.length - 1].params.offset + limit;
|
47
|
+
if (sorted[i].params.offset === expectedOffset) {
|
48
|
+
// Consecutive request
|
49
|
+
currentGroup.push(sorted[i]);
|
50
|
+
}
|
51
|
+
else {
|
52
|
+
// Non-consecutive, create a new group
|
53
|
+
groups.push(this.createBatchGroup(currentGroup));
|
54
|
+
currentGroup = [sorted[i]];
|
55
|
+
}
|
56
|
+
}
|
57
|
+
// Add the last group
|
58
|
+
groups.push(this.createBatchGroup(currentGroup));
|
59
|
+
return groups;
|
60
|
+
}
|
61
|
+
createBatchGroup(requests) {
|
62
|
+
const minOffset = Math.min(...requests.map((r) => r.params.offset));
|
63
|
+
const maxOffset = Math.max(...requests.map((r) => r.params.offset));
|
64
|
+
const limit = requests[0].params.limit;
|
65
|
+
const totalLimit = requests.length * limit;
|
66
|
+
return {
|
67
|
+
requests,
|
68
|
+
batchKey: this.createBatchKey(requests[0].params),
|
69
|
+
minOffset,
|
70
|
+
maxOffset,
|
71
|
+
totalLimit,
|
72
|
+
};
|
73
|
+
}
|
74
|
+
async executeBatch(group) {
|
75
|
+
const firstRequest = group.requests[0];
|
76
|
+
const batchParams = {
|
77
|
+
...firstRequest.params,
|
78
|
+
offset: group.minOffset,
|
79
|
+
limit: group.totalLimit,
|
80
|
+
};
|
81
|
+
try {
|
82
|
+
const response = await firstRequest.params.fetchData({
|
83
|
+
limit: batchParams.limit,
|
84
|
+
offset: batchParams.offset,
|
85
|
+
filters: batchParams.filters,
|
86
|
+
sortParams: batchParams.sortParams,
|
87
|
+
columnsIds: batchParams.columnsIds,
|
88
|
+
signal: firstRequest.signal,
|
89
|
+
});
|
90
|
+
// Split the response data among individual requests
|
91
|
+
this.splitAndDistributeResponse(group, response);
|
92
|
+
}
|
93
|
+
catch (error) {
|
94
|
+
// If batch fails, reject all requests in the group
|
95
|
+
group.requests.forEach((request) => {
|
96
|
+
request.resolve({ error });
|
97
|
+
});
|
98
|
+
}
|
99
|
+
}
|
100
|
+
splitAndDistributeResponse(group, batchResponse) {
|
101
|
+
const limit = group.requests[0].params.limit;
|
102
|
+
group.requests.forEach((request, index) => {
|
103
|
+
const startIndex = index * limit;
|
104
|
+
const endIndex = startIndex + limit;
|
105
|
+
const chunkData = batchResponse.data.slice(startIndex, endIndex);
|
106
|
+
const chunkResponse = {
|
107
|
+
...batchResponse,
|
108
|
+
data: chunkData,
|
109
|
+
total: batchResponse.total,
|
110
|
+
found: batchResponse.found,
|
111
|
+
};
|
112
|
+
request.resolve({ data: chunkResponse });
|
113
|
+
});
|
114
|
+
}
|
115
|
+
async processBatch() {
|
116
|
+
const allQueues = Array.from(this.requestQueue.entries());
|
117
|
+
this.requestQueue.clear();
|
118
|
+
this.batchTimeout = null;
|
119
|
+
for (const [_batchKey, requests] of allQueues) {
|
120
|
+
const groups = this.groupConsecutiveRequests(requests);
|
121
|
+
// Execute each group (consecutive chunks) as a separate batch
|
122
|
+
await Promise.all(groups.map((group) => this.executeBatch(group)));
|
123
|
+
}
|
124
|
+
}
|
125
|
+
}
|
126
|
+
// Singleton instance
|
127
|
+
export const requestBatcher = new RequestBatcher();
|
128
|
+
//# sourceMappingURL=requestBatcher.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"requestBatcher.js","sourceRoot":"","sources":["../../../src/components/PaginatedTable/requestBatcher.ts"],"names":[],"mappings":"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"}
|
@@ -5,7 +5,13 @@ interface UseScrollBasedChunksProps {
|
|
5
5
|
totalItems: number;
|
6
6
|
rowHeight: number;
|
7
7
|
chunkSize: number;
|
8
|
-
|
8
|
+
renderOverscan?: number;
|
9
|
+
fetchOverscan?: number;
|
10
|
+
tableOffset: number;
|
9
11
|
}
|
10
|
-
|
12
|
+
interface ChunkState {
|
13
|
+
shouldRender: boolean;
|
14
|
+
shouldFetch: boolean;
|
15
|
+
}
|
16
|
+
export declare const useScrollBasedChunks: ({ scrollContainerRef, tableRef, totalItems, rowHeight, chunkSize, tableOffset, renderOverscan, fetchOverscan, }: UseScrollBasedChunksProps) => ChunkState[];
|
11
17
|
export {};
|