1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00

Add the ability to hide metrics from the UI (#2036)

This commit is contained in:
Violetta 2021-03-16 17:22:08 +04:00 committed by GitHub
parent 7d14ba5e48
commit a9a5766920
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
19 changed files with 303 additions and 38 deletions

View File

@ -15,6 +15,7 @@ import { handleRequest, requestMain, subscribeToBroadcast, unsubscribeAllFromBro
import _ from "lodash"; import _ from "lodash";
import move from "array-move"; import move from "array-move";
import type { WorkspaceId } from "./workspace-store"; import type { WorkspaceId } from "./workspace-store";
import { ResourceType } from "../renderer/components/+cluster-settings/components/cluster-metrics-setting";
export interface ClusterIconUpload { export interface ClusterIconUpload {
clusterId: string; clusterId: string;
@ -34,7 +35,7 @@ export type ClusterPrometheusMetadata = {
export interface ClusterStoreModel { export interface ClusterStoreModel {
activeCluster?: ClusterId; // last opened cluster activeCluster?: ClusterId; // last opened cluster
clusters?: ClusterModel[] clusters?: ClusterModel[];
} }
export type ClusterId = string; export type ClusterId = string;
@ -76,6 +77,7 @@ export interface ClusterPreferences extends ClusterPrometheusPreferences{
iconOrder?: number; iconOrder?: number;
icon?: string; icon?: string;
httpsProxy?: string; httpsProxy?: string;
hiddenMetrics?: string[];
} }
export interface ClusterPrometheusPreferences { export interface ClusterPrometheusPreferences {
@ -211,6 +213,10 @@ export class ClusterStore extends BaseStore<ClusterStoreModel> {
return this.activeCluster === id; return this.activeCluster === id;
} }
isMetricHidden(resource: ResourceType) {
return Boolean(this.active?.preferences.hiddenMetrics?.includes(resource));
}
@action @action
setActive(id: ClusterId) { setActive(id: ClusterId) {
const clusterId = this.clusters.has(id) ? id : null; const clusterId = this.clusters.has(id) ? id : null;

View File

@ -29,7 +29,7 @@ export interface UserPreferences {
downloadBinariesPath?: string; downloadBinariesPath?: string;
kubectlBinariesPath?: string; kubectlBinariesPath?: string;
openAtLogin?: boolean; openAtLogin?: boolean;
hiddenTableColumns?: Record<string, string[]> hiddenTableColumns?: Record<string, string[]>;
} }
export class UserStore extends BaseStore<UserStoreModel> { export class UserStore extends BaseStore<UserStoreModel> {

View File

@ -0,0 +1,12 @@
.MetricsSelect {
$spacing: $padding;
--flex-gap: #{$spacing};
.Badge {
margin-top: $spacing;
}
.Button {
margin-top: $spacing;
}
}

View File

@ -0,0 +1,118 @@
import "./cluster-metrics-setting.scss";
import React from "react";
import { disposeOnUnmount, observer } from "mobx-react";
import { Select, SelectOption } from "../../select/select";
import { Icon } from "../../icon/icon";
import { Button } from "../../button/button";
import { SubTitle } from "../../layout/sub-title";
import { Cluster } from "../../../../main/cluster";
import { observable, reaction } from "mobx";
interface Props {
cluster: Cluster;
}
export enum ResourceType {
Cluster = "Cluster",
Node = "Node",
Pod = "Pod",
Deployment = "Deployment",
StatefulSet = "StatefulSet",
Container = "Container",
Ingress = "Ingress",
VolumeClaim = "VolumeClaim",
ReplicaSet = "ReplicaSet",
DaemonSet = "DaemonSet",
}
@observer
export class ClusterMetricsSetting extends React.Component<Props> {
@observable hiddenMetrics = observable.set<string>();
componentDidMount() {
this.hiddenMetrics = observable.set<string>(this.props.cluster.preferences.hiddenMetrics ?? []);
disposeOnUnmount(this, [
reaction(() => this.props.cluster.preferences.hiddenMetrics, () => {
this.hiddenMetrics = observable.set<string>(this.props.cluster.preferences.hiddenMetrics ?? []);
}),
]);
}
save = () => {
this.props.cluster.preferences.hiddenMetrics = Array.from(this.hiddenMetrics);
};
onChangeSelect = (values: SelectOption<ResourceType>[]) => {
for (const { value } of values) {
if (this.hiddenMetrics.has(value)) {
this.hiddenMetrics.delete(value);
} else {
this.hiddenMetrics.add(value);
}
}
this.save();
};
onChangeButton = () => {
Object.keys(ResourceType).map(value =>
this.hiddenMetrics.add(value)
);
this.save();
};
reset = () => {
this.hiddenMetrics.clear();
this.save();
};
formatOptionLabel = ({ value: resource }: SelectOption<ResourceType>) => (
<div className="flex gaps align-center">
<span>{resource}</span>
{this.hiddenMetrics.has(resource) && <Icon smallest material="check" className="box right" />}
</div>
);
renderMetricsSelect() {
return (
<>
<Select
className="box grow"
placeholder="Select metrics to hide..."
isMulti
isSearchable
onMenuClose={this.save}
closeMenuOnSelect={false}
controlShouldRenderValue={false}
options={Object.values(ResourceType)}
onChange={this.onChangeSelect}
formatOptionLabel={this.formatOptionLabel}
/>
<Button
primary
label="Hide all metrics"
onClick={this.onChangeButton}
/>
<Button
primary
label="Reset"
onClick={this.reset}
/>
</>
);
}
render() {
return (
<div className="MetricsSelect">
<SubTitle title={"Hide metrics from the UI"}/>
<div className="flex gaps">
{this.renderMetricsSelect()}
</div>
</div>
);
}
}

View File

@ -0,0 +1,63 @@
import "./cluster-metrics-setting.scss";
import React from "react";
import { disposeOnUnmount, observer } from "mobx-react";
import { Cluster } from "../../../../main/cluster";
import { observable, reaction } from "mobx";
import { Badge } from "../../badge/badge";
import { Icon } from "../../icon/icon";
interface Props {
cluster: Cluster;
}
@observer
export class ShowMetricsSetting extends React.Component<Props> {
@observable hiddenMetrics = observable.set<string>();
componentDidMount() {
this.hiddenMetrics = observable.set<string>(this.props.cluster.preferences.hiddenMetrics ?? []);
disposeOnUnmount(this, [
reaction(() => this.props.cluster.preferences.hiddenMetrics, () => {
this.hiddenMetrics = observable.set<string>(this.props.cluster.preferences.hiddenMetrics ?? []);
}),
]);
}
removeMetric(metric: string) {
this.hiddenMetrics.delete(metric);
this.props.cluster.preferences.hiddenMetrics = Array.from(this.hiddenMetrics);
}
renderMetrics() {
return (
Array.from(this.hiddenMetrics).map(name => {
const tooltipId = `${name}`;
return (
<Badge key={name}>
<span id={tooltipId}>{name}</span>
<Icon
smallest
material="clear"
onClick={() => this.removeMetric(name)}
tooltip="Remove"
/>
</Badge>
);
})
);
}
render() {
return (
<div className="MetricsSelect flex wrap gaps">
{this.renderMetrics()}
</div>
);
}
}

View File

@ -7,6 +7,8 @@ import { ClusterProxySetting } from "./components/cluster-proxy-setting";
import { ClusterPrometheusSetting } from "./components/cluster-prometheus-setting"; import { ClusterPrometheusSetting } from "./components/cluster-prometheus-setting";
import { ClusterHomeDirSetting } from "./components/cluster-home-dir-setting"; import { ClusterHomeDirSetting } from "./components/cluster-home-dir-setting";
import { ClusterAccessibleNamespaces } from "./components/cluster-accessible-namespaces"; import { ClusterAccessibleNamespaces } from "./components/cluster-accessible-namespaces";
import { ClusterMetricsSetting } from "./components/cluster-metrics-setting";
import { ShowMetricsSetting } from "./components/show-metrics";
interface Props { interface Props {
cluster: Cluster; cluster: Cluster;
@ -23,6 +25,8 @@ export class General extends React.Component<Props> {
<ClusterPrometheusSetting cluster={this.props.cluster} /> <ClusterPrometheusSetting cluster={this.props.cluster} />
<ClusterHomeDirSetting cluster={this.props.cluster} /> <ClusterHomeDirSetting cluster={this.props.cluster} />
<ClusterAccessibleNamespaces cluster={this.props.cluster} /> <ClusterAccessibleNamespaces cluster={this.props.cluster} />
<ClusterMetricsSetting cluster={this.props.cluster}/>
<ShowMetricsSetting cluster={this.props.cluster}/>
</div>; </div>;
} }
} }

View File

@ -53,3 +53,7 @@
} }
} }
} }
.OnlyClusterIssues {
grid-row: row1-start / row2-end;
}

View File

@ -7,7 +7,9 @@
display: grid; display: grid;
grid-gap: $gridGap; grid-gap: $gridGap;
grid-template-columns: repeat(auto-fit, minmax(500px, 1fr)); grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
grid-template-rows: 1fr 1fr; grid-template-rows:
[row1-start] 1fr
[row2-start] 1fr;
@include media(">1600px") { @include media(">1600px") {
grid-template-columns: 1fr 1fr; grid-template-columns: 1fr 1fr;

View File

@ -5,7 +5,7 @@ import { reaction } from "mobx";
import { disposeOnUnmount, observer } from "mobx-react"; import { disposeOnUnmount, observer } from "mobx-react";
import { nodesStore } from "../+nodes/nodes.store"; import { nodesStore } from "../+nodes/nodes.store";
import { podsStore } from "../+workloads-pods/pods.store"; import { podsStore } from "../+workloads-pods/pods.store";
import { getHostedCluster } from "../../../common/cluster-store"; import { clusterStore, getHostedCluster } from "../../../common/cluster-store";
import { interval } from "../../utils"; import { interval } from "../../utils";
import { TabLayout } from "../layout/tab-layout"; import { TabLayout } from "../layout/tab-layout";
import { Spinner } from "../spinner"; import { Spinner } from "../spinner";
@ -13,6 +13,7 @@ import { ClusterIssues } from "./cluster-issues";
import { ClusterMetrics } from "./cluster-metrics"; import { ClusterMetrics } from "./cluster-metrics";
import { clusterOverviewStore } from "./cluster-overview.store"; import { clusterOverviewStore } from "./cluster-overview.store";
import { ClusterPieCharts } from "./cluster-pie-charts"; import { ClusterPieCharts } from "./cluster-pie-charts";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
@observer @observer
export class ClusterOverview extends React.Component { export class ClusterOverview extends React.Component {
@ -37,19 +38,40 @@ export class ClusterOverview extends React.Component {
this.metricPoller.stop(); this.metricPoller.stop();
} }
renderMetrics(isMetricsHidden: boolean) {
if (isMetricsHidden) {
return null;
}
return (
<>
<ClusterMetrics/>
<ClusterPieCharts/>
</>
);
}
renderClusterOverview(isLoaded: boolean, isMetricsHidden: boolean) {
if (!isLoaded) {
return <Spinner center/>;
}
return (
<>
{this.renderMetrics(isMetricsHidden)}
<ClusterIssues className={isMetricsHidden ? "OnlyClusterIssues" : ""}/>
</>
);
}
render() { render() {
const isLoaded = nodesStore.isLoaded && podsStore.isLoaded; const isLoaded = nodesStore.isLoaded && podsStore.isLoaded;
const isMetricsHidden = clusterStore.isMetricHidden(ResourceType.Cluster);
return ( return (
<TabLayout> <TabLayout>
<div className="ClusterOverview"> <div className="ClusterOverview">
{!isLoaded ? <Spinner center/> : ( {this.renderClusterOverview(isLoaded, isMetricsHidden)}
<>
<ClusterMetrics/>
<ClusterPieCharts/>
<ClusterIssues/>
</>
)}
</div> </div>
</TabLayout> </TabLayout>
); );

View File

@ -4,7 +4,7 @@ import React from "react";
import { disposeOnUnmount, observer } from "mobx-react"; import { disposeOnUnmount, observer } from "mobx-react";
import { reaction } from "mobx"; import { reaction } from "mobx";
import { DrawerItem, DrawerTitle } from "../drawer"; import { DrawerItem, DrawerTitle } from "../drawer";
import { Ingress, ILoadBalancerIngress } from "../../api/endpoints"; import { ILoadBalancerIngress, Ingress } from "../../api/endpoints";
import { Table, TableCell, TableHead, TableRow } from "../table"; import { Table, TableCell, TableHead, TableRow } from "../table";
import { KubeEventDetails } from "../+events/kube-event-details"; import { KubeEventDetails } from "../+events/kube-event-details";
import { ingressStore } from "./ingress.store"; import { ingressStore } from "./ingress.store";
@ -14,6 +14,8 @@ import { IngressCharts } from "./ingress-charts";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { getBackendServiceNamePort } from "../../api/endpoints/ingress.api"; import { getBackendServiceNamePort } from "../../api/endpoints/ingress.api";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<Ingress> { interface Props extends KubeObjectDetailsProps<Ingress> {
} }
@ -106,17 +108,20 @@ export class IngressDetails extends React.Component<Props> {
"Network", "Network",
"Duration", "Duration",
]; ];
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.Ingress);
const { serviceName, servicePort } = ingress.getServiceNamePort(); const { serviceName, servicePort } = ingress.getServiceNamePort();
return ( return (
<div className="IngressDetails"> <div className="IngressDetails">
{!isMetricHidden && (
<ResourceMetrics <ResourceMetrics
loader={() => ingressStore.loadMetrics(ingress)} loader={() => ingressStore.loadMetrics(ingress)}
tabs={metricTabs} object={ingress} params={{ metrics }} tabs={metricTabs} object={ingress} params={{ metrics }}
> >
<IngressCharts/> <IngressCharts/>
</ResourceMetrics> </ResourceMetrics>
)}
<KubeObjectMeta object={ingress}/> <KubeObjectMeta object={ingress}/>
<DrawerItem name="Ports"> <DrawerItem name="Ports">
{ingress.getPorts()} {ingress.getPorts()}

View File

@ -17,6 +17,8 @@ import { PodDetailsList } from "../+workloads-pods/pod-details-list";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { KubeEventDetails } from "../+events/kube-event-details"; import { KubeEventDetails } from "../+events/kube-event-details";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<Node> { interface Props extends KubeObjectDetailsProps<Node> {
} }
@ -52,10 +54,11 @@ export class NodeDetails extends React.Component<Props> {
"Disk", "Disk",
"Pods", "Pods",
]; ];
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.Node);
return ( return (
<div className="NodeDetails"> <div className="NodeDetails">
{podsStore.isLoaded && ( {!isMetricHidden && podsStore.isLoaded && (
<ResourceMetrics <ResourceMetrics
loader={() => nodesStore.loadMetrics(node.getName())} loader={() => nodesStore.loadMetrics(node.getName())}
tabs={metricTabs} object={node} params={{ metrics }} tabs={metricTabs} object={node} params={{ metrics }}

View File

@ -14,6 +14,8 @@ import { VolumeClaimDiskChart } from "./volume-claim-disk-chart";
import { getDetailsUrl, KubeObjectDetailsProps, KubeObjectMeta } from "../kube-object"; import { getDetailsUrl, KubeObjectDetailsProps, KubeObjectMeta } from "../kube-object";
import { PersistentVolumeClaim } from "../../api/endpoints"; import { PersistentVolumeClaim } from "../../api/endpoints";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<PersistentVolumeClaim> { interface Props extends KubeObjectDetailsProps<PersistentVolumeClaim> {
} }
@ -41,15 +43,18 @@ export class PersistentVolumeClaimDetails extends React.Component<Props> {
const metricTabs = [ const metricTabs = [
"Disk" "Disk"
]; ];
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.VolumeClaim);
return ( return (
<div className="PersistentVolumeClaimDetails"> <div className="PersistentVolumeClaimDetails">
{!isMetricHidden && (
<ResourceMetrics <ResourceMetrics
loader={() => volumeClaimStore.loadMetrics(volumeClaim)} loader={() => volumeClaimStore.loadMetrics(volumeClaim)}
tabs={metricTabs} object={volumeClaim} params={{ metrics }} tabs={metricTabs} object={volumeClaim} params={{ metrics }}
> >
<VolumeClaimDiskChart/> <VolumeClaimDiskChart/>
</ResourceMetrics> </ResourceMetrics>
)}
<KubeObjectMeta object={volumeClaim}/> <KubeObjectMeta object={volumeClaim}/>
<DrawerItem name="Access Modes"> <DrawerItem name="Access Modes">
{accessModes.join(", ")} {accessModes.join(", ")}

View File

@ -18,6 +18,8 @@ import { reaction } from "mobx";
import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { PodDetailsList } from "../+workloads-pods/pod-details-list";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<DaemonSet> { interface Props extends KubeObjectDetailsProps<DaemonSet> {
} }
@ -47,10 +49,11 @@ export class DaemonSetDetails extends React.Component<Props> {
const nodeSelector = daemonSet.getNodeSelectors(); const nodeSelector = daemonSet.getNodeSelectors();
const childPods = daemonSetStore.getChildPods(daemonSet); const childPods = daemonSetStore.getChildPods(daemonSet);
const metrics = daemonSetStore.metrics; const metrics = daemonSetStore.metrics;
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.DaemonSet);
return ( return (
<div className="DaemonSetDetails"> <div className="DaemonSetDetails">
{podsStore.isLoaded && ( {!isMetricHidden && podsStore.isLoaded && (
<ResourceMetrics <ResourceMetrics
loader={() => daemonSetStore.loadMetrics(daemonSet)} loader={() => daemonSetStore.loadMetrics(daemonSet)}
tabs={podMetricTabs} object={daemonSet} params={{ metrics }} tabs={podMetricTabs} object={daemonSet} params={{ metrics }}

View File

@ -19,6 +19,8 @@ import { reaction } from "mobx";
import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { PodDetailsList } from "../+workloads-pods/pod-details-list";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<Deployment> { interface Props extends KubeObjectDetailsProps<Deployment> {
} }
@ -47,10 +49,11 @@ export class DeploymentDetails extends React.Component<Props> {
const selectors = deployment.getSelectors(); const selectors = deployment.getSelectors();
const childPods = deploymentStore.getChildPods(deployment); const childPods = deploymentStore.getChildPods(deployment);
const metrics = deploymentStore.metrics; const metrics = deploymentStore.metrics;
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.Deployment);
return ( return (
<div className="DeploymentDetails"> <div className="DeploymentDetails">
{podsStore.isLoaded && ( {!isMetricHidden && podsStore.isLoaded && (
<ResourceMetrics <ResourceMetrics
loader={() => deploymentStore.loadMetrics(deployment)} loader={() => deploymentStore.loadMetrics(deployment)}
tabs={podMetricTabs} object={deployment} params={{ metrics }} tabs={podMetricTabs} object={deployment} params={{ metrics }}

View File

@ -11,6 +11,8 @@ import { PodContainerPort } from "./pod-container-port";
import { ResourceMetrics } from "../resource-metrics"; import { ResourceMetrics } from "../resource-metrics";
import { IMetrics } from "../../api/endpoints/metrics.api"; import { IMetrics } from "../../api/endpoints/metrics.api";
import { ContainerCharts } from "./container-charts"; import { ContainerCharts } from "./container-charts";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props { interface Props {
pod: Pod; pod: Pod;
@ -63,13 +65,14 @@ export class PodDetailsContainer extends React.Component<Props> {
"Memory", "Memory",
"Filesystem", "Filesystem",
]; ];
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.Container);
return ( return (
<div className="PodDetailsContainer"> <div className="PodDetailsContainer">
<div className="pod-container-title"> <div className="pod-container-title">
<StatusBrick className={cssNames(state, { ready })}/>{name} <StatusBrick className={cssNames(state, { ready })}/>{name}
</div> </div>
{!isInitContainer && {!isMetricHidden && !isInitContainer &&
<ResourceMetrics tabs={metricTabs} params={{ metrics }}> <ResourceMetrics tabs={metricTabs} params={{ metrics }}>
<ContainerCharts/> <ContainerCharts/>
</ResourceMetrics> </ResourceMetrics>

View File

@ -22,6 +22,8 @@ import { getItemMetrics } from "../../api/endpoints/metrics.api";
import { PodCharts, podMetricTabs } from "./pod-charts"; import { PodCharts, podMetricTabs } from "./pod-charts";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<Pod> { interface Props extends KubeObjectDetailsProps<Pod> {
} }
@ -66,15 +68,18 @@ export class PodDetails extends React.Component<Props> {
const nodeSelector = pod.getNodeSelectors(); const nodeSelector = pod.getNodeSelectors();
const volumes = pod.getVolumes(); const volumes = pod.getVolumes();
const metrics = podsStore.metrics; const metrics = podsStore.metrics;
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.Pod);
return ( return (
<div className="PodDetails"> <div className="PodDetails">
{!isMetricHidden && (
<ResourceMetrics <ResourceMetrics
loader={() => podsStore.loadMetrics(pod)} loader={() => podsStore.loadMetrics(pod)}
tabs={podMetricTabs} object={pod} params={{ metrics }} tabs={podMetricTabs} object={pod} params={{ metrics }}
> >
<PodCharts/> <PodCharts/>
</ResourceMetrics> </ResourceMetrics>
)}
<KubeObjectMeta object={pod}/> <KubeObjectMeta object={pod}/>
<DrawerItem name="Status"> <DrawerItem name="Status">
<span className={cssNames("status", kebabCase(pod.getStatusMessage()))}>{pod.getStatusMessage()}</span> <span className={cssNames("status", kebabCase(pod.getStatusMessage()))}>{pod.getStatusMessage()}</span>

View File

@ -17,6 +17,8 @@ import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts";
import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { PodDetailsList } from "../+workloads-pods/pod-details-list";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<ReplicaSet> { interface Props extends KubeObjectDetailsProps<ReplicaSet> {
} }
@ -47,10 +49,11 @@ export class ReplicaSetDetails extends React.Component<Props> {
const nodeSelector = replicaSet.getNodeSelectors(); const nodeSelector = replicaSet.getNodeSelectors();
const images = replicaSet.getImages(); const images = replicaSet.getImages();
const childPods = replicaSetStore.getChildPods(replicaSet); const childPods = replicaSetStore.getChildPods(replicaSet);
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.ReplicaSet);
return ( return (
<div className="ReplicaSetDetails"> <div className="ReplicaSetDetails">
{podsStore.isLoaded && ( {!isMetricHidden && podsStore.isLoaded && (
<ResourceMetrics <ResourceMetrics
loader={() => replicaSetStore.loadMetrics(replicaSet)} loader={() => replicaSetStore.loadMetrics(replicaSet)}
tabs={podMetricTabs} object={replicaSet} params={{ metrics }} tabs={podMetricTabs} object={replicaSet} params={{ metrics }}

View File

@ -18,6 +18,8 @@ import { PodCharts, podMetricTabs } from "../+workloads-pods/pod-charts";
import { PodDetailsList } from "../+workloads-pods/pod-details-list"; import { PodDetailsList } from "../+workloads-pods/pod-details-list";
import { KubeObjectMeta } from "../kube-object/kube-object-meta"; import { KubeObjectMeta } from "../kube-object/kube-object-meta";
import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry"; import { kubeObjectDetailRegistry } from "../../api/kube-object-detail-registry";
import { ResourceType } from "../+cluster-settings/components/cluster-metrics-setting";
import { clusterStore } from "../../../common/cluster-store";
interface Props extends KubeObjectDetailsProps<StatefulSet> { interface Props extends KubeObjectDetailsProps<StatefulSet> {
} }
@ -46,10 +48,11 @@ export class StatefulSetDetails extends React.Component<Props> {
const nodeSelector = statefulSet.getNodeSelectors(); const nodeSelector = statefulSet.getNodeSelectors();
const childPods = statefulSetStore.getChildPods(statefulSet); const childPods = statefulSetStore.getChildPods(statefulSet);
const metrics = statefulSetStore.metrics; const metrics = statefulSetStore.metrics;
const isMetricHidden = clusterStore.isMetricHidden(ResourceType.StatefulSet);
return ( return (
<div className="StatefulSetDetails"> <div className="StatefulSetDetails">
{podsStore.isLoaded && ( {!isMetricHidden && podsStore.isLoaded && (
<ResourceMetrics <ResourceMetrics
loader={() => statefulSetStore.loadMetrics(statefulSet)} loader={() => statefulSetStore.loadMetrics(statefulSet)}
tabs={podMetricTabs} object={statefulSet} params={{ metrics }} tabs={podMetricTabs} object={statefulSet} params={{ metrics }}

View File

@ -1,6 +1,7 @@
.PieChart { .PieChart {
.chart-container { .chart-container {
width: 120px; width: 120px;
min-height: 150px;
} }
.legend { .legend {