mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Switch components to be static to help with React performance
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
a92c53eb56
commit
1f78c66cc2
@ -3,28 +3,47 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } 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 { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { Namespace } from "../../../common/k8s-api/endpoints";
|
import type { Namespace } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { PodMetricInNamespaceData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-in-namespace.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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 namespaceMetricsInjectable from "./metrics.injectable";
|
import namespaceMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<PodMetricInNamespaceData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedNamespaceMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Namespace> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const NamespaceMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Namespace>>(NonInjectedNamespaceMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(namespaceMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const namespaceMetricsDetailsComponentInjectable = getInjectable({
|
const namespaceMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "namespace-metrics-details-component",
|
id: "namespace-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Namespace>) => (
|
Component: NamespaceMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={ podMetricTabs }
|
|
||||||
object={ object }
|
|
||||||
metrics={ di.inject(namespaceMetricsInjectable, object) }
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Namespace),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Namespace),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,9 +3,12 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } from "@ogre-tools/injectable-react";
|
||||||
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { Ingress } from "../../../common/k8s-api/endpoints";
|
import type { Ingress } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { IngressMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-ingress-metrics.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { kubeObjectDetailItemInjectionToken } from "../kube-object-details/kube-object-detail-items/kube-object-detail-item-injection-token";
|
||||||
@ -13,21 +16,37 @@ import { ResourceMetrics } from "../resource-metrics";
|
|||||||
import { IngressCharts } from "./ingress-charts";
|
import { IngressCharts } from "./ingress-charts";
|
||||||
import ingressMetricsInjectable from "./metrics.injectable";
|
import ingressMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<IngressMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedIngressMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Ingress> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={[
|
||||||
|
"Network",
|
||||||
|
"Duration",
|
||||||
|
]}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<IngressCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const IngressMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Ingress>>(NonInjectedIngressMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(ingressMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const ingressMetricsDetailsComponentInjectable = getInjectable({
|
const ingressMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "ingress-metrics-details-component",
|
id: "ingress-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Ingress>) => (
|
Component: IngressMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={ [
|
|
||||||
"Network",
|
|
||||||
"Duration",
|
|
||||||
] }
|
|
||||||
object={ object }
|
|
||||||
metrics={ di.inject(ingressMetricsInjectable, object) }
|
|
||||||
>
|
|
||||||
<IngressCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Ingress),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Ingress),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,9 +3,12 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } from "@ogre-tools/injectable-react";
|
||||||
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { Node } from "../../../common/k8s-api/endpoints";
|
import type { Node } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { ClusterMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-cluster-metrics-by-node-names.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { kubeObjectDetailItemInjectionToken } from "../kube-object-details/kube-object-detail-items/kube-object-detail-item-injection-token";
|
||||||
@ -13,23 +16,39 @@ import { ResourceMetrics } from "../resource-metrics";
|
|||||||
import nodeMetricsInjectable from "./metrics.injectable";
|
import nodeMetricsInjectable from "./metrics.injectable";
|
||||||
import { NodeCharts } from "./node-charts";
|
import { NodeCharts } from "./node-charts";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<ClusterMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedNodeMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Node> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={[
|
||||||
|
"CPU",
|
||||||
|
"Memory",
|
||||||
|
"Disk",
|
||||||
|
"Pods",
|
||||||
|
]}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<NodeCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const NodeMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Node>>(NonInjectedNodeMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(nodeMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const nodeMetricsDetailsComponentInjectable = getInjectable({
|
const nodeMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "node-metrics-details-component",
|
id: "node-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Node>) => (
|
Component: NodeMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={ [
|
|
||||||
"CPU",
|
|
||||||
"Memory",
|
|
||||||
"Disk",
|
|
||||||
"Pods",
|
|
||||||
] }
|
|
||||||
object={ object }
|
|
||||||
metrics={ di.inject(nodeMetricsInjectable, object) }
|
|
||||||
>
|
|
||||||
<NodeCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Node),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Node),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,49 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } from "@ogre-tools/injectable-react";
|
||||||
|
import { withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
|
import type { PersistentVolumeClaim } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { PersistentVolumeClaimMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-persistent-volume-claim-metrics.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.injectable";
|
||||||
|
import type { KubeObjectDetailsProps } from "../kube-object-details";
|
||||||
import { kubeObjectDetailItemInjectionToken } from "../kube-object-details/kube-object-detail-items/kube-object-detail-item-injection-token";
|
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 persistentVolumeClaimMetricsInjectable from "./metrics.injectable";
|
import persistentVolumeClaimMetricsInjectable from "./metrics.injectable";
|
||||||
import { VolumeClaimDiskChart } from "./volume-claim-disk-chart";
|
import { VolumeClaimDiskChart } from "./volume-claim-disk-chart";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<PersistentVolumeClaimMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedPersistentVolumeClaimMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<PersistentVolumeClaim> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={[
|
||||||
|
"Disk",
|
||||||
|
]}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<VolumeClaimDiskChart />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const PersistentVolumeClaimMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<PersistentVolumeClaim>>(NonInjectedPersistentVolumeClaimMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(persistentVolumeClaimMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const persistentVolumeClaimMetricsDetailsComponentInjectable = getInjectable({
|
const persistentVolumeClaimMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "persistent-volume-claim-metrics-details-component",
|
id: "persistent-volume-claim-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }) => (
|
Component: PersistentVolumeClaimMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={[
|
|
||||||
"Disk",
|
|
||||||
]}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(persistentVolumeClaimMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<VolumeClaimDiskChart />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.VolumeClaim),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.VolumeClaim),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,47 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } 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 { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { DaemonSet } from "../../../common/k8s-api/endpoints";
|
import type { DaemonSet } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { DaemonSetPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-daemon-sets.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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 daemonSetMetricsInjectable from "./metrics.injectable";
|
import daemonSetMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<DaemonSetPodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedDaemonSetMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<DaemonSet> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const DaemonSetMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<DaemonSet>>(NonInjectedDaemonSetMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(daemonSetMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const daemonSetMetricsDetailsComponentInjectable = getInjectable({
|
const daemonSetMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "daemon-set-metrics-details-component",
|
id: "daemon-set-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<DaemonSet>) => (
|
Component: DaemonSetMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(daemonSetMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.DaemonSet),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.DaemonSet),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,47 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import type { IAsyncComputed } 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 { 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 metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<DeploymentPodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedDeploymentMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Deployment> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const DeploymentMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Deployment>>(NonInjectedDeploymentMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(deploymentMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const deploymentMetricsDetailsComponentInjectable = getInjectable({
|
const deploymentMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "deployment-metrics-details-component",
|
id: "deployment-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Deployment>) => (
|
Component: DeploymentMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(deploymentMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Deployment),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Deployment),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,46 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { type IAsyncComputed, 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 { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { Job } from "../../../common/k8s-api/endpoints";
|
import type { Job } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { JobPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-jobs.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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 jobMetricsInjectable from "./metrics.injectable";
|
import jobMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<JobPodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedJobMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Job> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const JobMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Job>>(NonInjectedJobMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(jobMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const jobMetricsDetailsComponentInjectable = getInjectable({
|
const jobMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "job-metrics-details-component",
|
id: "job-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Job>) => (
|
Component: JobMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(jobMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Job),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Job),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,9 +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 { getInjectable } from "@ogre-tools/injectable";
|
import { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { type IAsyncComputed, withInjectables } from "@ogre-tools/injectable-react";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
import { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { Pod } from "../../../common/k8s-api/endpoints";
|
import type { Pod } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { PodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { kubeObjectDetailItemInjectionToken } from "../kube-object-details/kube-object-detail-items/kube-object-detail-item-injection-token";
|
||||||
@ -13,18 +15,34 @@ import { ResourceMetrics } from "../resource-metrics";
|
|||||||
import podMetricsInjectable from "./metrics.injectable";
|
import podMetricsInjectable from "./metrics.injectable";
|
||||||
import { PodCharts, podMetricTabs } from "./pod-charts";
|
import { PodCharts, podMetricTabs } from "./pod-charts";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<PodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedPodMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<Pod> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const PodMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<Pod>>(NonInjectedPodMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(podMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const podMetricsDetailsComponentInjectable = getInjectable({
|
const podMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "pod-metrics-details-container",
|
id: "pod-metrics-details-container",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<Pod>) => (
|
Component: PodMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(podMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Pod),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.Pod),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,46 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { type IAsyncComputed, 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 { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { ReplicaSet } from "../../../common/k8s-api/endpoints";
|
import type { ReplicaSet } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { ReplicaSetPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-replica-sets.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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 replicaSetMetricsInjectable from "./metrics.injectable";
|
import replicaSetMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<ReplicaSetPodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedReplicaSetMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<ReplicaSet> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const ReplicaSetMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<ReplicaSet>>(NonInjectedReplicaSetMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(replicaSetMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const replicaSetMetricsDetailsComponentInjectable = getInjectable({
|
const replicaSetMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "replica-set-metrics-details-component",
|
id: "replica-set-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<ReplicaSet>) => (
|
Component: ReplicaSetMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(replicaSetMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.ReplicaSet),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.ReplicaSet),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
@ -3,28 +3,46 @@
|
|||||||
* 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 { getInjectable } from "@ogre-tools/injectable";
|
||||||
|
import { type IAsyncComputed, 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 { ClusterMetricsResourceType } from "../../../common/cluster-types";
|
||||||
import type { StatefulSet } from "../../../common/k8s-api/endpoints";
|
import type { StatefulSet } from "../../../common/k8s-api/endpoints";
|
||||||
|
import type { StatefulSetPodMetricData } from "../../../common/k8s-api/endpoints/metrics.api/request-pod-metrics-for-stateful-sets.injectable";
|
||||||
import metricsDetailsComponentEnabledInjectable from "../../api/catalog/entity/metrics-details-component-enabled.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 { 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 statefulSetMetricsInjectable from "./metrics.injectable";
|
import statefulSetMetricsInjectable from "./metrics.injectable";
|
||||||
|
|
||||||
|
interface Dependencies {
|
||||||
|
metrics: IAsyncComputed<StatefulSetPodMetricData>;
|
||||||
|
}
|
||||||
|
|
||||||
|
const NonInjectedStatefulSetMetricsDetailsComponent = ({
|
||||||
|
object,
|
||||||
|
metrics,
|
||||||
|
}: KubeObjectDetailsProps<StatefulSet> & Dependencies) => (
|
||||||
|
<ResourceMetrics
|
||||||
|
tabs={podMetricTabs}
|
||||||
|
object={object}
|
||||||
|
metrics={metrics}
|
||||||
|
>
|
||||||
|
<PodCharts />
|
||||||
|
</ResourceMetrics>
|
||||||
|
);
|
||||||
|
|
||||||
|
const StatefulSetMetricsDetailsComponent = withInjectables<Dependencies, KubeObjectDetailsProps<StatefulSet>>(NonInjectedStatefulSetMetricsDetailsComponent, {
|
||||||
|
getProps: (di, props) => ({
|
||||||
|
metrics: di.inject(statefulSetMetricsInjectable, props.object),
|
||||||
|
...props,
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
const statefulSetMetricsDetailsComponentInjectable = getInjectable({
|
const statefulSetMetricsDetailsComponentInjectable = getInjectable({
|
||||||
id: "stateful-set-metrics-details-component",
|
id: "stateful-set-metrics-details-component",
|
||||||
instantiate: (di) => ({
|
instantiate: (di) => ({
|
||||||
Component: ({ object }: KubeObjectDetailsProps<StatefulSet>) => (
|
Component: StatefulSetMetricsDetailsComponent,
|
||||||
<ResourceMetrics
|
|
||||||
tabs={podMetricTabs}
|
|
||||||
object={object}
|
|
||||||
metrics={di.inject(statefulSetMetricsInjectable, object)}
|
|
||||||
>
|
|
||||||
<PodCharts />
|
|
||||||
</ResourceMetrics>
|
|
||||||
),
|
|
||||||
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.StatefulSet),
|
enabled: di.inject(metricsDetailsComponentEnabledInjectable, ClusterMetricsResourceType.StatefulSet),
|
||||||
orderNumber: -1,
|
orderNumber: -1,
|
||||||
}),
|
}),
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user