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:
parent
7d14ba5e48
commit
a9a5766920
@ -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;
|
||||||
@ -70,12 +71,13 @@ export interface ClusterModel {
|
|||||||
kubeConfig?: string; // yaml
|
kubeConfig?: string; // yaml
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface ClusterPreferences extends ClusterPrometheusPreferences{
|
export interface ClusterPreferences extends ClusterPrometheusPreferences {
|
||||||
terminalCWD?: string;
|
terminalCWD?: string;
|
||||||
clusterName?: string;
|
clusterName?: string;
|
||||||
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;
|
||||||
|
|||||||
@ -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> {
|
||||||
|
|||||||
@ -0,0 +1,12 @@
|
|||||||
|
.MetricsSelect {
|
||||||
|
$spacing: $padding;
|
||||||
|
--flex-gap: #{$spacing};
|
||||||
|
|
||||||
|
.Badge {
|
||||||
|
margin-top: $spacing;
|
||||||
|
}
|
||||||
|
|
||||||
|
.Button {
|
||||||
|
margin-top: $spacing;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -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>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -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>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -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>;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -53,3 +53,7 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.OnlyClusterIssues {
|
||||||
|
grid-row: row1-start / row2-end;
|
||||||
|
}
|
||||||
|
|||||||
@ -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;
|
||||||
@ -21,4 +23,4 @@
|
|||||||
padding-top: 0;
|
padding-top: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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>
|
||||||
);
|
);
|
||||||
|
|||||||
@ -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">
|
||||||
<ResourceMetrics
|
{!isMetricHidden && (
|
||||||
loader={() => ingressStore.loadMetrics(ingress)}
|
<ResourceMetrics
|
||||||
tabs={metricTabs} object={ingress} params={{ metrics }}
|
loader={() => ingressStore.loadMetrics(ingress)}
|
||||||
>
|
tabs={metricTabs} object={ingress} params={{ metrics }}
|
||||||
<IngressCharts/>
|
>
|
||||||
</ResourceMetrics>
|
<IngressCharts/>
|
||||||
|
</ResourceMetrics>
|
||||||
|
)}
|
||||||
<KubeObjectMeta object={ingress}/>
|
<KubeObjectMeta object={ingress}/>
|
||||||
<DrawerItem name="Ports">
|
<DrawerItem name="Ports">
|
||||||
{ingress.getPorts()}
|
{ingress.getPorts()}
|
||||||
|
|||||||
@ -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 }}
|
||||||
|
|||||||
@ -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">
|
||||||
<ResourceMetrics
|
{!isMetricHidden && (
|
||||||
loader={() => volumeClaimStore.loadMetrics(volumeClaim)}
|
<ResourceMetrics
|
||||||
tabs={metricTabs} object={volumeClaim} params={{ metrics }}
|
loader={() => volumeClaimStore.loadMetrics(volumeClaim)}
|
||||||
>
|
tabs={metricTabs} object={volumeClaim} params={{ metrics }}
|
||||||
<VolumeClaimDiskChart/>
|
>
|
||||||
</ResourceMetrics>
|
<VolumeClaimDiskChart/>
|
||||||
|
</ResourceMetrics>
|
||||||
|
)}
|
||||||
<KubeObjectMeta object={volumeClaim}/>
|
<KubeObjectMeta object={volumeClaim}/>
|
||||||
<DrawerItem name="Access Modes">
|
<DrawerItem name="Access Modes">
|
||||||
{accessModes.join(", ")}
|
{accessModes.join(", ")}
|
||||||
|
|||||||
@ -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 }}
|
||||||
|
|||||||
@ -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 }}
|
||||||
|
|||||||
@ -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>
|
||||||
|
|||||||
@ -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">
|
||||||
<ResourceMetrics
|
{!isMetricHidden && (
|
||||||
loader={() => podsStore.loadMetrics(pod)}
|
<ResourceMetrics
|
||||||
tabs={podMetricTabs} object={pod} params={{ metrics }}
|
loader={() => podsStore.loadMetrics(pod)}
|
||||||
>
|
tabs={podMetricTabs} object={pod} params={{ metrics }}
|
||||||
<PodCharts/>
|
>
|
||||||
</ResourceMetrics>
|
<PodCharts/>
|
||||||
|
</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>
|
||||||
|
|||||||
@ -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 }}
|
||||||
|
|||||||
@ -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 }}
|
||||||
|
|||||||
@ -1,6 +1,7 @@
|
|||||||
.PieChart {
|
.PieChart {
|
||||||
.chart-container {
|
.chart-container {
|
||||||
width: 120px;
|
width: 120px;
|
||||||
|
min-height: 150px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.legend {
|
.legend {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user