mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Add deployment details metrics injection token
Signed-off-by: Juho Heikka <juho.heikka@gmail.com>
This commit is contained in:
parent
03a87f9549
commit
4401b17af9
@ -3,10 +3,11 @@
|
|||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
*/
|
*/
|
||||||
import { getFeature } from "@k8slens/feature-core";
|
import { getFeature } from "@k8slens/feature-core";
|
||||||
import { clusterOverviewUIBlockInjectionToken, podDetailsContainerMetricsInjectionToken, podDetailsMetricsInjectionToken } from "@k8slens/metrics";
|
import { clusterOverviewUIBlockInjectionToken, deploymentDetailsMetricsInjectionToken, podDetailsContainerMetricsInjectionToken, podDetailsMetricsInjectionToken } from "@k8slens/metrics";
|
||||||
import { getInjectable } from "@ogre-tools/injectable";
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
import { ClusterMetrics } from "../../renderer/components/+cluster/cluster-metrics";
|
import { ClusterMetrics } from "../../renderer/components/+cluster/cluster-metrics";
|
||||||
import { ClusterPieCharts } from "../../renderer/components/+cluster/cluster-pie-charts";
|
import { ClusterPieCharts } from "../../renderer/components/+cluster/cluster-pie-charts";
|
||||||
|
import { DeploymentMetricsDetailsComponent } from "../../renderer/components/+workloads-deployments/metrics-details-component";
|
||||||
import { PodDetailsContainerMetrics } from "../../renderer/components/+workloads-pods/pod-details-container-metrics";
|
import { PodDetailsContainerMetrics } from "../../renderer/components/+workloads-pods/pod-details-container-metrics";
|
||||||
import PodMetricsDetailsComponent from "../../renderer/components/+workloads-pods/pod-metrics-details-component";
|
import PodMetricsDetailsComponent from "../../renderer/components/+workloads-pods/pod-metrics-details-component";
|
||||||
|
|
||||||
@ -36,10 +37,24 @@ const clusterMetricsOverviewBlockInjectable = getInjectable({
|
|||||||
|
|
||||||
const podDetailsMetricsInjectable = getInjectable({
|
const podDetailsMetricsInjectable = getInjectable({
|
||||||
id: "pod-details-metrics-injectable",
|
id: "pod-details-metrics-injectable",
|
||||||
instantiate: () => PodMetricsDetailsComponent,
|
instantiate: () => ({
|
||||||
|
id: "pod-details-metrics",
|
||||||
|
Component: PodMetricsDetailsComponent,
|
||||||
|
}),
|
||||||
injectionToken: podDetailsMetricsInjectionToken,
|
injectionToken: podDetailsMetricsInjectionToken,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const deploymentDetailsMetricsInjectable = getInjectable({
|
||||||
|
id: "deployment-details-metrics-injectable",
|
||||||
|
instantiate: () => ({
|
||||||
|
id: "deployment-details-metrics",
|
||||||
|
Component: DeploymentMetricsDetailsComponent,
|
||||||
|
}),
|
||||||
|
injectionToken: deploymentDetailsMetricsInjectionToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log(deploymentDetailsMetricsInjectable);
|
||||||
|
|
||||||
const podDetailsContainerMetricsInjectable = getInjectable({
|
const podDetailsContainerMetricsInjectable = getInjectable({
|
||||||
id: "pod-details-container-metrics-injectable",
|
id: "pod-details-container-metrics-injectable",
|
||||||
instantiate: () => ({
|
instantiate: () => ({
|
||||||
@ -58,5 +73,6 @@ export const metricsFeature = getFeature({
|
|||||||
|
|
||||||
di.register(podDetailsMetricsInjectable);
|
di.register(podDetailsMetricsInjectable);
|
||||||
di.register(podDetailsContainerMetricsInjectable);
|
di.register(podDetailsContainerMetricsInjectable);
|
||||||
|
di.register(deploymentDetailsMetricsInjectable);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|||||||
@ -2,17 +2,13 @@
|
|||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
*/
|
*/
|
||||||
import { getInjectable } from "@ogre-tools/injectable";
|
|
||||||
import type { IAsyncComputed } from "@ogre-tools/injectable-react";
|
import type { IAsyncComputed } from "@ogre-tools/injectable-react";
|
||||||
import { withInjectables } from "@ogre-tools/injectable-react";
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts";
|
import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts";
|
||||||
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
|
||||||
import type { Deployment } from "../../../common/k8s-api/endpoints";
|
import type { Deployment } from "../../../common/k8s-api/endpoints";
|
||||||
import type { DeploymentPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-deployments.injectable";
|
import type { DeploymentPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-deployments.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
|
||||||
import type { KubeObjectDetailsProps } from "../kube-object-details";
|
import type { KubeObjectDetailsProps } from "../kube-object-details";
|
||||||
import { kubeObjectDetailItemInjectionToken } from "../kube-object-details/kube-object-detail-items/kube-object-detail-item-injection-token";
|
|
||||||
import { ResourceMetrics } from "../resource-metrics";
|
import { ResourceMetrics } from "../resource-metrics";
|
||||||
import deploymentMetricsInjectable from "./metrics.injectable";
|
import deploymentMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
@ -33,21 +29,9 @@ const NonInjectedDeploymentMetricsDetailsComponent = ({
|
|||||||
</ResourceMetrics>
|
</ResourceMetrics>
|
||||||
);
|
);
|
||||||
|
|
||||||
const DeploymentMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Deployment>>(NonInjectedDeploymentMetricsDetailsComponent, {
|
export const DeploymentMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Deployment>>(NonInjectedDeploymentMetricsDetailsComponent, {
|
||||||
getProps: (di, props) => ({
|
getProps: (di, props) => ({
|
||||||
metrics: di.inject(deploymentMetricsInjectable, props.object),
|
metrics: di.inject(deploymentMetricsInjectable, props.object),
|
||||||
...props,
|
...props,
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
|
|
||||||
const deploymentMetricsDetailsComponentInjectable = getInjectable({
|
|
||||||
id: "deployment-metrics-details-component",
|
|
||||||
instantiate: (di) => ({
|
|
||||||
Component: DeploymentMetricsDetailsComponent,
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Deployment),
|
|
||||||
orderNumber: -1,
|
|
||||||
}),
|
|
||||||
injectionToken: kubeObjectDetailItemInjectionToken,
|
|
||||||
});
|
|
||||||
|
|
||||||
export default deploymentMetricsDetailsComponentInjectable;
|
|
||||||
@ -0,0 +1,29 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { ClusterMetricsResourceType } from "../../../../../common/cluster-types";
|
||||||
|
import metricsDetailsComponentEnabledInjectable from "../../../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
||||||
|
import { kubeObjectDetailItemInjectionToken } from "../kube-object-detail-item-injection-token";
|
||||||
|
import { deploymentDetailsMetricsInjectionToken } from "@k8slens/metrics";
|
||||||
|
import { EmptyMetrics } from "./empty-metrics";
|
||||||
|
|
||||||
|
const deploymentMetricsInjectable = getInjectable({
|
||||||
|
id: "deployment-details-metrics",
|
||||||
|
instantiate: (di) => {
|
||||||
|
const deploymentMetrics = di.injectMany(deploymentDetailsMetricsInjectionToken);
|
||||||
|
const first = deploymentMetrics[0];
|
||||||
|
|
||||||
|
const Component = first?.Component ?? EmptyMetrics;
|
||||||
|
|
||||||
|
return {
|
||||||
|
Component,
|
||||||
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Deployment),
|
||||||
|
orderNumber: -1,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
injectionToken: kubeObjectDetailItemInjectionToken,
|
||||||
|
});
|
||||||
|
|
||||||
|
export default deploymentMetricsInjectable;
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
|
*/
|
||||||
|
import React from "react";
|
||||||
|
|
||||||
|
export const EmptyMetrics = () => <></>;
|
||||||
@ -2,22 +2,20 @@
|
|||||||
* Copyright (c) OpenLens Authors. All rights reserved.
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
||||||
* Licensed under MIT License. See LICENSE in root directory for more information.
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
||||||
*/
|
*/
|
||||||
import React from "react";
|
|
||||||
import { podDetailsMetricsInjectionToken } from "@k8slens/metrics";
|
import { podDetailsMetricsInjectionToken } from "@k8slens/metrics";
|
||||||
import { getInjectable } from "@ogre-tools/injectable";
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
import { ClusterMetricsResourceType } from "../../../../common/cluster-types";
|
import { ClusterMetricsResourceType } from "../../../../../common/cluster-types";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
import metricsDetailsComponentEnabledInjectable from "../../../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
||||||
import { kubeObjectDetailItemInjectionToken } from "./kube-object-detail-item-injection-token";
|
import { kubeObjectDetailItemInjectionToken } from "../kube-object-detail-item-injection-token";
|
||||||
|
import { EmptyMetrics } from "./empty-metrics";
|
||||||
const Empty = () => <></>;
|
|
||||||
|
|
||||||
const podMetricsInjectable = getInjectable({
|
const podMetricsInjectable = getInjectable({
|
||||||
id: "kube-object-pod-metrics-injectable",
|
id: "pod-details-pod-metrics",
|
||||||
instantiate: (di) => {
|
instantiate: (di) => {
|
||||||
const podMetrics = di.injectMany(podDetailsMetricsInjectionToken);
|
const podMetrics = di.injectMany(podDetailsMetricsInjectionToken);
|
||||||
const first = podMetrics[0];
|
const first = podMetrics[0];
|
||||||
|
|
||||||
const Component = first ?? Empty;
|
const Component = first?.Component ?? EmptyMetrics;
|
||||||
|
|
||||||
return {
|
return {
|
||||||
Component,
|
Component,
|
||||||
@ -16,16 +16,28 @@ export const clusterOverviewUIBlockInjectionToken = getInjectionToken<ClusterOve
|
|||||||
id: "cluster-overview-ui-block-injection-token",
|
id: "cluster-overview-ui-block-injection-token",
|
||||||
});
|
});
|
||||||
|
|
||||||
export type KubeObjectDetailMetrics = React.ElementType;
|
export type KubeObjectDetailMetricsComponentProps = {
|
||||||
|
object: any;
|
||||||
|
};
|
||||||
|
|
||||||
|
export type KubeObjectDetailMetrics = {
|
||||||
|
id: string;
|
||||||
|
Component: React.ComponentType<KubeObjectDetailMetricsComponentProps>;
|
||||||
|
};
|
||||||
|
|
||||||
export const podDetailsMetricsInjectionToken = getInjectionToken<KubeObjectDetailMetrics>({
|
export const podDetailsMetricsInjectionToken = getInjectionToken<KubeObjectDetailMetrics>({
|
||||||
id: "pod-details-metrics-injection-token",
|
id: "pod-details-metrics-injection-token",
|
||||||
});
|
});
|
||||||
|
|
||||||
|
export const deploymentDetailsMetricsInjectionToken = getInjectionToken<KubeObjectDetailMetrics>({
|
||||||
|
id: "deployment-details-metrics-injection-token",
|
||||||
|
});
|
||||||
|
|
||||||
export interface PodDetailsContainerMetricsComponentProps {
|
export interface PodDetailsContainerMetricsComponentProps {
|
||||||
container: any;
|
container: any;
|
||||||
pod: any;
|
pod: any;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface PodDetailsContainerMetricsComponent {
|
export interface PodDetailsContainerMetricsComponent {
|
||||||
id: string;
|
id: string;
|
||||||
Component: React.ComponentType<PodDetailsContainerMetricsComponentProps>;
|
Component: React.ComponentType<PodDetailsContainerMetricsComponentProps>;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user