/** * Copyright (c) 2021 OpenLens Authors * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ 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 } from "../../utils"; import { getMetricsForNamespace, IPodMetrics, Namespace } from "../../api/endpoints"; import { getDetailsUrl, KubeObjectDetailsProps } from "../kube-object"; import { Link } from "react-router-dom"; import { Spinner } from "../spinner"; import { resourceQuotaStore } from "../+config-resource-quotas/resource-quotas.store"; import { KubeObjectMeta } from "../kube-object/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"; interface Props extends KubeObjectDetailsProps { } @observer export class NamespaceDetails extends React.Component { @observable metrics: IPodMetrics = null; constructor(props: Props) { super(props); makeObservable(this); } @disposeOnUnmount clean = reaction(() => this.props.object, () => { this.metrics = null; }); componentDidMount() { resourceQuotaStore.reloadAll(); limitRangeStore.reloadAll(); } @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; 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()} ); })}
); } }