import React, { useContext } from "react"; import { t } from "@lingui/macro"; import { IClusterMetrics, Node } from "../../api/endpoints"; import { BarChart, cpuOptions, memoryOptions } from "../chart"; import { isMetricsEmpty, normalizeMetrics } from "../../api/endpoints/metrics.api"; import { NoMetrics } from "../resource-metrics/no-metrics"; import { IResourceMetricsValue, ResourceMetricsContext } from "../resource-metrics"; import { observer } from "mobx-react"; import { ChartOptions, ChartPoint } from "chart.js"; import { themeStore } from "../../theme.store"; import { _i18n } from "../../i18n"; type IContext = IResourceMetricsValue; export const NodeCharts = observer(() => { const { params: { metrics }, tabId, object } = useContext(ResourceMetricsContext); const id = object.getId(); const { chartCapacityColor } = themeStore.activeTheme.colors; if (!metrics) return null; if (isMetricsEmpty(metrics)) return ; const values = Object.values(metrics).map(metric => normalizeMetrics(metric).data.result[0].values ); const [ memoryUsage, memoryRequests, memoryLimits, memoryCapacity, cpuUsage, cpuRequests, cpuLimits, cpuCapacity, podUsage, podCapacity, fsSize, fsUsage ] = values; const datasets = [ // CPU [ { id: `${id}-cpuUsage`, label: _i18n._(t`Usage`), tooltip: _i18n._(t`CPU cores usage`), borderColor: "#3D90CE", data: cpuUsage.map(([x, y]) => ({ x, y })) }, { id: `${id}-cpuRequests`, label: _i18n._(t`Requests`), tooltip: _i18n._(t`CPU requests`), borderColor: "#30b24d", data: cpuRequests.map(([x, y]) => ({ x, y })) }, { id: `${id}-cpuCapacity`, label: _i18n._(t`Capacity`), tooltip: _i18n._(t`CPU capacity`), borderColor: chartCapacityColor, data: cpuCapacity.map(([x, y]) => ({ x, y })) } ], // Memory [ { id: `${id}-memoryUsage`, label: _i18n._(t`Usage`), tooltip: _i18n._(t`Memory usage`), borderColor: "#c93dce", data: memoryUsage.map(([x, y]) => ({ x, y })) }, { id: "memoryRequests", label: _i18n._(t`Requests`), tooltip: _i18n._(t`Memory requests`), borderColor: "#30b24d", data: memoryRequests.map(([x, y]) => ({ x, y })) }, { id: `${id}-memoryCapacity`, label: _i18n._(t`Capacity`), tooltip: _i18n._(t`Memory capacity`), borderColor: chartCapacityColor, data: memoryCapacity.map(([x, y]) => ({ x, y })) } ], // Disk [ { id: `${id}-fsUsage`, label: _i18n._(t`Usage`), tooltip: _i18n._(t`Node filesystem usage in bytes`), borderColor: "#ffc63d", data: fsUsage.map(([x, y]) => ({ x, y })) }, { id: `${id}-fsSize`, label: _i18n._(t`Size`), tooltip: _i18n._(t`Node filesystem size in bytes`), borderColor: chartCapacityColor, data: fsSize.map(([x, y]) => ({ x, y })) } ], // Pods [ { id: `${id}-podUsage`, label: _i18n._(t`Usage`), tooltip: _i18n._(t`Number of running Pods`), borderColor: "#30b24d", data: podUsage.map(([x, y]) => ({ x, y })) }, { id: `${id}-podCapacity`, label: _i18n._(t`Capacity`), tooltip: _i18n._(t`Node Pods capacity`), borderColor: chartCapacityColor, data: podCapacity.map(([x, y]) => ({ x, y })) } ] ]; const podOptions: ChartOptions = { scales: { yAxes: [{ ticks: { callback: value => value } }] }, tooltips: { callbacks: { label: ({ datasetIndex, index }, { datasets }) => { const { label, data } = datasets[datasetIndex]; const value = data[index] as ChartPoint; return `${label}: ${value.y}`; } } } } const options = [cpuOptions, memoryOptions, memoryOptions, podOptions]; return ( ); })