/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import "./namespace-details.scss"; import React from "react"; import { computed, makeObservable, observable, reaction } from "mobx"; import { disposeOnUnmount, observer } from "mobx-react"; import { DrawerItem } from "../drawer"; import { boundMethod, cssNames, Disposer } from "../../utils"; import { getMetricsForNamespace, type IPodMetrics, Namespace } from "../../../common/k8s-api/endpoints"; import type { KubeObjectDetailsProps } from "../kube-object-details"; import { Link } from "react-router-dom"; import { Spinner } from "../spinner"; import { resourceQuotaStore } from "../+config-resource-quotas/resource-quotas.store"; import { KubeObjectMeta } from "../kube-object-meta"; import { limitRangeStore } from "../+config-limit-ranges/limit-ranges.store"; import { ResourceMetrics } from "../resource-metrics"; import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts"; import { ClusterMetricsResourceType } from "../../../common/cluster-types"; import { getActiveClusterEntity } from "../../api/catalog-entity-registry"; import { getDetailsUrl } from "../kube-detail-params"; import logger from "../../../common/logger"; import type { KubeObjectStore } from "../../../common/k8s-api/kube-object.store"; import type { KubeObject } from "../../../common/k8s-api/kube-object"; import { withInjectables } from "@ogre-tools/injectable-react"; import kubeWatchApiInjectable from "../../kube-watch-api/kube-watch-api.injectable"; export interface NamespaceDetailsProps extends KubeObjectDetailsProps { } interface Dependencies { subscribeStores: (stores: KubeObjectStore[]) => Disposer; } @observer class NonInjectedNamespaceDetails extends React.Component { @observable metrics: IPodMetrics = null; constructor(props: NamespaceDetailsProps & Dependencies) { super(props); makeObservable(this); } componentDidMount() { disposeOnUnmount(this, [ reaction(() => this.props.object, () => { this.metrics = null; }), this.props.subscribeStores([ resourceQuotaStore, limitRangeStore, ]), ]); } @computed get quotas() { const namespace = this.props.object.getName(); return resourceQuotaStore.getAllByNs(namespace); } @computed get limitranges() { const namespace = this.props.object.getName(); return limitRangeStore.getAllByNs(namespace); } @boundMethod async loadMetrics() { this.metrics = await getMetricsForNamespace(this.props.object.getName(), ""); } render() { const { object: namespace } = this.props; if (!namespace) { return null; } if (!(namespace instanceof Namespace)) { logger.error("[NamespaceDetails]: passed object that is not an instanceof Namespace", namespace); return null; } const status = namespace.getStatus(); const isMetricHidden = getActiveClusterEntity()?.isMetricHidden(ClusterMetricsResourceType.Namespace); return (
{!isMetricHidden && ( )} {status} {!this.quotas && resourceQuotaStore.isLoading && } {this.quotas.map(quota => { return ( {quota.getName()} ); })} {!this.limitranges && limitRangeStore.isLoading && } {this.limitranges.map(limitrange => { return ( {limitrange.getName()} ); })}
); } } export const NamespaceDetails = withInjectables( NonInjectedNamespaceDetails, { getProps: (di, props) => ({ subscribeStores: di.inject(kubeWatchApiInjectable).subscribeStores, ...props, }), }, );