From 4328f0397636801a8e0151f5060d320b85ef20a5 Mon Sep 17 00:00:00 2001 From: Sebastian Malton Date: Mon, 24 Oct 2022 15:10:51 -0400 Subject: [PATCH] Change ingress metrics details to use more injectables Signed-off-by: Sebastian Malton --- .../metrics-details-component.injectable.tsx | 48 +++++++------------ .../+network-ingresses/metrics.injectable.ts | 27 +++++++++++ 2 files changed, 45 insertions(+), 30 deletions(-) create mode 100644 src/renderer/components/+network-ingresses/metrics.injectable.ts diff --git a/src/renderer/components/+network-ingresses/metrics-details-component.injectable.tsx b/src/renderer/components/+network-ingresses/metrics-details-component.injectable.tsx index 64cc187feb..b332c63327 100644 --- a/src/renderer/components/+network-ingresses/metrics-details-component.injectable.tsx +++ b/src/renderer/components/+network-ingresses/metrics-details-component.injectable.tsx @@ -3,46 +3,34 @@ * Licensed under MIT License. See LICENSE in root directory for more information. */ import { getInjectable } from "@ogre-tools/injectable"; -import { asyncComputed } from "@ogre-tools/injectable-react"; -import { computed } from "mobx"; -import { now } from "mobx-utils"; import React from "react"; import { ClusterMetricsResourceType } from "../../../common/cluster-types"; import type { Ingress } from "../../../common/k8s-api/endpoints"; -import requestIngressMetricsInjectable from "../../../common/k8s-api/endpoints/metrics.api/request-ingress-metrics.injectable"; -import getActiveClusterEntityInjectable from "../../api/catalog/entity/get-active-cluster-entity.injectable"; +import enabledMetricsInjectable from "../../api/catalog/entity/metrics-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 { ResourceMetrics } from "../resource-metrics"; import { IngressCharts } from "./ingress-charts"; +import ingressMetricsInjectable from "./metrics.injectable"; const ingressMetricsDetailsComponentInjectable = getInjectable({ id: "ingress-metrics-details-component", - instantiate: (di) => { - const getActiveClusterEntity = di.inject(getActiveClusterEntityInjectable); - const requestIngressMetrics = di.inject(requestIngressMetricsInjectable); - - return { - Component: ({ object }: KubeObjectDetailsProps) => ( - { - now(60 * 1000); // Update every minute - - return requestIngressMetrics(object.getName(), object.getNs()); - })} - > - - - ), - enabled: computed(() => !getActiveClusterEntity()?.isMetricHidden(ClusterMetricsResourceType.Ingress)), - orderNumber: -1, - }; - }, + instantiate: (di) => ({ + Component: ({ object }: KubeObjectDetailsProps) => ( + + + + ), + enabled: di.inject(enabledMetricsInjectable, ClusterMetricsResourceType.Ingress), + orderNumber: -1, + }), injectionToken: kubeObjectDetailItemInjectionToken, }); diff --git a/src/renderer/components/+network-ingresses/metrics.injectable.ts b/src/renderer/components/+network-ingresses/metrics.injectable.ts new file mode 100644 index 0000000000..340905b28c --- /dev/null +++ b/src/renderer/components/+network-ingresses/metrics.injectable.ts @@ -0,0 +1,27 @@ +/** + * Copyright (c) OpenLens Authors. All rights reserved. + * Licensed under MIT License. See LICENSE in root directory for more information. + */ +import { getInjectable, lifecycleEnum } from "@ogre-tools/injectable"; +import { asyncComputed } from "@ogre-tools/injectable-react"; +import { now } from "mobx-utils"; +import type { Ingress } from "../../../common/k8s-api/endpoints"; +import requestIngressMetricsInjectable from "../../../common/k8s-api/endpoints/metrics.api/request-ingress-metrics.injectable"; + +const ingressMetricsInjectable = getInjectable({ + id: "ingress-metrics", + instantiate: (di, ingress) => { + const requestIngressMetrics = di.inject(requestIngressMetricsInjectable); + + return asyncComputed(async () => { + now(60 * 1000); // Update every minute + + return requestIngressMetrics(ingress.getName(), ingress.getNs()); + }); + }, + lifecycle: lifecycleEnum.keyedSingleton({ + getInstanceKey: (di, ingress: Ingress) => ingress.getId(), + }), +}); + +export default ingressMetricsInjectable;