mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 09:48:58 -04:00
[Stack Monitoring ] Migrate kibana instances page to react (#113874)
* kibana instances page component * kibana instances route * extract SetupModeProps to remove duplication
This commit is contained in:
parent
308068407d
commit
cf6bb10bb1
10 changed files with 121 additions and 48 deletions
|
@ -25,6 +25,7 @@ import { BeatsInstancesPage } from './pages/beats/instances';
|
|||
import { BeatsInstancePage } from './pages/beats/instance';
|
||||
import { ApmOverviewPage, ApmInstancesPage, ApmInstancePage } from './pages/apm';
|
||||
import { KibanaOverviewPage } from './pages/kibana/overview';
|
||||
import { KibanaInstancesPage } from './pages/kibana/instances';
|
||||
import { ElasticsearchNodesPage } from './pages/elasticsearch/nodes_page';
|
||||
import { ElasticsearchIndicesPage } from './pages/elasticsearch/indices_page';
|
||||
import { ElasticsearchIndexPage } from './pages/elasticsearch/index_page';
|
||||
|
@ -143,6 +144,13 @@ const MonitoringApp: React.FC<{
|
|||
/>
|
||||
|
||||
{/* Kibana Views */}
|
||||
<RouteInit
|
||||
path="/kibana/instances"
|
||||
component={KibanaInstancesPage}
|
||||
codePaths={[CODE_PATH_KIBANA]}
|
||||
fetchAllClusters={false}
|
||||
/>
|
||||
|
||||
<RouteInit
|
||||
path="/kibana"
|
||||
component={KibanaOverviewPage}
|
||||
|
|
|
@ -15,16 +15,10 @@ import { useTable } from '../../hooks/use_table';
|
|||
import { BeatsTemplate } from './beats_template';
|
||||
// @ts-ignore
|
||||
import { Listing } from '../../../components/beats/listing';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { BreadcrumbContainer } from '../../hooks/use_breadcrumbs';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const BeatsInstancesPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { services } = useKibana<{ data: any }>();
|
||||
|
|
|
@ -14,17 +14,12 @@ import { GlobalStateContext } from '../../global_state_context';
|
|||
import { TabMenuItem } from '../page_template';
|
||||
import { Overview } from '../../../components/cluster/overview';
|
||||
import { ExternalConfigContext } from '../../external_config_context';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { STANDALONE_CLUSTER_CLUSTER_UUID } from '../../../../common/constants';
|
||||
import { BreadcrumbContainer } from '../../hooks/use_breadcrumbs';
|
||||
|
||||
const CODE_PATHS = [CODE_PATH_ALL];
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ClusterOverview: React.FC<{}> = () => {
|
||||
const state = useContext(GlobalStateContext);
|
||||
|
|
|
@ -10,19 +10,13 @@ import { useParams } from 'react-router-dom';
|
|||
import { useKibana } from '../../../../../../../src/plugins/kibana_react/public';
|
||||
import { GlobalStateContext } from '../../global_state_context';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { useCharts } from '../../hooks/use_charts';
|
||||
import { ItemTemplate } from './item_template';
|
||||
// @ts-ignore
|
||||
import { AdvancedIndex } from '../../../components/elasticsearch/index/advanced';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ElasticsearchIndexAdvancedPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { services } = useKibana<{ data: any }>();
|
||||
|
|
|
@ -12,7 +12,7 @@ import { GlobalStateContext } from '../../global_state_context';
|
|||
// @ts-ignore
|
||||
import { IndexReact } from '../../../components/elasticsearch/index/index_react';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { useCharts } from '../../hooks/use_charts';
|
||||
import { ItemTemplate } from './item_template';
|
||||
|
@ -21,12 +21,6 @@ import { indicesByNodes } from '../../../components/elasticsearch/shard_allocati
|
|||
// @ts-ignore
|
||||
import { labels } from '../../../components/elasticsearch/shard_allocation/lib/labels';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ElasticsearchIndexPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { services } = useKibana<{ data: any }>();
|
||||
|
|
|
@ -12,17 +12,11 @@ import { useKibana } from '../../../../../../../src/plugins/kibana_react/public'
|
|||
import { GlobalStateContext } from '../../global_state_context';
|
||||
import { ElasticsearchIndices } from '../../../components/elasticsearch';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { useTable } from '../../hooks/use_table';
|
||||
import { useLocalStorage } from '../../hooks/use_local_storage';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ElasticsearchIndicesPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { services } = useKibana<{ data: any }>();
|
||||
|
|
|
@ -12,7 +12,7 @@ import { useKibana } from '../../../../../../../src/plugins/kibana_react/public'
|
|||
import { GlobalStateContext } from '../../global_state_context';
|
||||
import { NodeReact } from '../../../components/elasticsearch';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { useLocalStorage } from '../../hooks/use_local_storage';
|
||||
import { useCharts } from '../../hooks/use_charts';
|
||||
|
@ -20,12 +20,6 @@ import { nodesByIndices } from '../../../components/elasticsearch/shard_allocati
|
|||
// @ts-ignore
|
||||
import { labels } from '../../../components/elasticsearch/shard_allocation/lib/labels';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ElasticsearchNodePage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { zoomInfo, onBrush } = useCharts();
|
||||
|
|
|
@ -13,17 +13,11 @@ import { GlobalStateContext } from '../../global_state_context';
|
|||
import { ExternalConfigContext } from '../../external_config_context';
|
||||
import { ElasticsearchNodes } from '../../../components/elasticsearch';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { SetupModeRenderer } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { useTable } from '../../hooks/use_table';
|
||||
import { BreadcrumbContainer } from '../../hooks/use_breadcrumbs';
|
||||
|
||||
interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
||||
export const ElasticsearchNodesPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const globalState = useContext(GlobalStateContext);
|
||||
const { showCgroupMetricsElasticsearch } = useContext(ExternalConfigContext);
|
||||
|
|
|
@ -0,0 +1,100 @@
|
|||
/*
|
||||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
||||
* or more contributor license agreements. Licensed under the Elastic License
|
||||
* 2.0; you may not use this file except in compliance with the Elastic License
|
||||
* 2.0.
|
||||
*/
|
||||
|
||||
import React, { useContext, useState, useCallback, useEffect } from 'react';
|
||||
import { i18n } from '@kbn/i18n';
|
||||
import { find } from 'lodash';
|
||||
import { ComponentProps } from '../../route_init';
|
||||
import { GlobalStateContext } from '../../global_state_context';
|
||||
import { useKibana } from '../../../../../../../src/plugins/kibana_react/public';
|
||||
import { useTable } from '../../hooks/use_table';
|
||||
import { KibanaTemplate } from './kibana_template';
|
||||
// @ts-ignore
|
||||
import { KibanaInstances } from '../../../components/kibana/instances';
|
||||
// @ts-ignore
|
||||
import { SetupModeRenderer, SetupModeProps } from '../../setup_mode/setup_mode_renderer';
|
||||
import { SetupModeContext } from '../../../components/setup_mode/setup_mode_context';
|
||||
import { BreadcrumbContainer } from '../../hooks/use_breadcrumbs';
|
||||
|
||||
export const KibanaInstancesPage: React.FC<ComponentProps> = ({ clusters }) => {
|
||||
const { cluster_uuid: clusterUuid, ccs } = useContext(GlobalStateContext);
|
||||
const { services } = useKibana<{ data: any }>();
|
||||
const { generate: generateBreadcrumbs } = useContext(BreadcrumbContainer.Context);
|
||||
const { updateTotalItemCount, getPaginationTableProps } = useTable('kibana.instances');
|
||||
const cluster = find(clusters, {
|
||||
cluster_uuid: clusterUuid,
|
||||
}) as any;
|
||||
const [data, setData] = useState({} as any);
|
||||
|
||||
const title = i18n.translate('xpack.monitoring.kibana.instances.routeTitle', {
|
||||
defaultMessage: 'Kibana - Instances',
|
||||
});
|
||||
|
||||
const pageTitle = i18n.translate('xpack.monitoring.kibana.instances.pageTitle', {
|
||||
defaultMessage: 'Kibana instances',
|
||||
});
|
||||
|
||||
useEffect(() => {
|
||||
if (cluster) {
|
||||
generateBreadcrumbs(cluster.cluster_name, {
|
||||
inKibana: true,
|
||||
});
|
||||
}
|
||||
}, [cluster, generateBreadcrumbs]);
|
||||
|
||||
const getPageData = useCallback(async () => {
|
||||
const bounds = services.data?.query.timefilter.timefilter.getBounds();
|
||||
const url = `../api/monitoring/v1/clusters/${clusterUuid}/kibana/instances`;
|
||||
const response = await services.http?.fetch(url, {
|
||||
method: 'POST',
|
||||
body: JSON.stringify({
|
||||
ccs,
|
||||
timeRange: {
|
||||
min: bounds.min.toISOString(),
|
||||
max: bounds.max.toISOString(),
|
||||
},
|
||||
}),
|
||||
});
|
||||
|
||||
setData(response);
|
||||
updateTotalItemCount(response.stats.total);
|
||||
}, [
|
||||
ccs,
|
||||
clusterUuid,
|
||||
services.data?.query.timefilter.timefilter,
|
||||
services.http,
|
||||
updateTotalItemCount,
|
||||
]);
|
||||
|
||||
return (
|
||||
<KibanaTemplate
|
||||
title={title}
|
||||
pageTitle={pageTitle}
|
||||
getPageData={getPageData}
|
||||
data-test-subj="kibanaInstancesPage"
|
||||
>
|
||||
<div data-test-subj="monitoringKibanaInstancesApp">
|
||||
<SetupModeRenderer
|
||||
productName="kibana"
|
||||
render={({ setupMode, flyoutComponent, bottomBarComponent }: SetupModeProps) => (
|
||||
<SetupModeContext.Provider value={{ setupModeSupported: true }}>
|
||||
{flyoutComponent}
|
||||
<KibanaInstances
|
||||
alerts={{}}
|
||||
instances={data.kibanas}
|
||||
setupMode={setupMode}
|
||||
clusterStatus={data.clusterStatus}
|
||||
{...getPaginationTableProps()}
|
||||
/>
|
||||
{bottomBarComponent}
|
||||
</SetupModeContext.Provider>
|
||||
)}
|
||||
/>
|
||||
</div>
|
||||
</KibanaTemplate>
|
||||
);
|
||||
};
|
|
@ -6,3 +6,9 @@
|
|||
*/
|
||||
|
||||
export const SetupModeRenderer: FunctionComponent<Props>;
|
||||
|
||||
export interface SetupModeProps {
|
||||
setupMode: any;
|
||||
flyoutComponent: any;
|
||||
bottomBarComponent: any;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue