import "./namespace-details.scss"; import React from "react"; import { computed } from "mobx"; import { observer } from "mobx-react"; import { DrawerItem } from "../drawer"; import { cssNames } from "../../utils"; import { 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 { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { limitRangeStore } from "../+config-limit-ranges/limit-ranges.store"; interface Props extends KubeObjectDetailsProps { } @observer export class NamespaceDetails extends React.Component { @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); } componentDidMount() { resourceQuotaStore.reloadAll(); limitRangeStore.reloadAll(); } render() { const { object: namespace } = this.props; if (!namespace) return; const status = namespace.getStatus(); return (
{status} {!this.quotas && resourceQuotaStore.isLoading && } {this.quotas.map(quota => { return ( {quota.getName()} ); })} {!this.limitranges && limitRangeStore.isLoading && } {this.limitranges.map(limitrange => { return ( {limitrange.getName()} ); })}
); } } kubeObjectDetailRegistry.add({ kind: "Namespace", apiVersions: ["v1"], components: { Details: (props) => } });