/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import "./statefulset-details.scss"; import React from "react"; import { disposeOnUnmount, observer } from "mobx-react"; import { makeObservable, observable, reaction } from "mobx"; import { Badge } from "../badge"; import { DrawerItem } from "../drawer"; import { PodDetailsStatuses } from "../+workloads-pods/pod-details-statuses"; import { PodDetailsTolerations } from "../+workloads-pods/pod-details-tolerations"; import { PodDetailsAffinities } from "../+workloads-pods/pod-details-affinities"; import { podsStore } from "../+workloads-pods/pods.store"; import { statefulSetStore } from "./statefulset.store"; import type { KubeObjectDetailsProps } from "../kube-object-details"; import { getMetricsForStatefulSets, type IPodMetrics, StatefulSet } from "../../../common/k8s-api/endpoints"; import { ResourceMetrics, ResourceMetricsText } from "../resource-metrics"; import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts"; import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { KubeObjectMeta } from "../kube-object-meta"; import { getActiveClusterEntity } from "../../api/catalog-entity-registry"; import { ClusterMetricsResourceType } from "../../../common/cluster-types"; import { boundMethod, Disposer } from "../../utils"; 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"; interface Props extends KubeObjectDetailsProps { } interface Dependencies { subscribeStores: (stores: KubeObjectStore[]) => Disposer } @observer class NonInjectedStatefulSetDetails extends React.Component { @observable metrics: IPodMetrics = null; constructor(props: Props & Dependencies) { super(props); makeObservable(this); } componentDidMount() { disposeOnUnmount(this, [ reaction(() => this.props.object, () => { this.metrics = null; }), this.props.subscribeStores([ podsStore, ]), ]); } @boundMethod async loadMetrics() { const { object: statefulSet } = this.props; this.metrics = await getMetricsForStatefulSets([statefulSet], statefulSet.getNs(), ""); } render() { const { object: statefulSet } = this.props; if (!statefulSet) { return null; } if (!(statefulSet instanceof StatefulSet)) { logger.error("[StatefulSetDetails]: passed object that is not an instanceof StatefulSet", statefulSet); return null; } const images = statefulSet.getImages(); const selectors = statefulSet.getSelectors(); const nodeSelector = statefulSet.getNodeSelectors(); const childPods = statefulSetStore.getChildPods(statefulSet); const isMetricHidden = getActiveClusterEntity()?.isMetricHidden(ClusterMetricsResourceType.StatefulSet); return (
{!isMetricHidden && podsStore.isLoaded && ( )} {selectors.length && { selectors.map(label => ) } } {nodeSelector.length > 0 && { nodeSelector.map(label => ( )) } } {images.length > 0 && { images.map(image =>

{image}

) }
}
); } } export const StatefulSetDetails = withInjectables( NonInjectedStatefulSetDetails, { getProps: (di, props) => ({ subscribeStores: di.inject(kubeWatchApiInjectable).subscribeStores, ...props, }), }, );