/** * Copyright (c) OpenLens Authors. All rights reserved. * Licensed under MIT License. See LICENSE in root directory for more information. */ import React, { useContext } from "react"; import { observer } from "mobx-react"; import type { IPvcMetrics, PersistentVolumeClaim } from "../../../common/k8s-api/endpoints"; import { BarChart, ChartDataSets, memoryOptions } from "../chart"; import { isMetricsEmpty, normalizeMetrics } from "../../../common/k8s-api/endpoints/metrics.api"; import { NoMetrics } from "../resource-metrics/no-metrics"; import { IResourceMetricsValue, ResourceMetricsContext } from "../resource-metrics"; import { ThemeStore } from "../../theme.store"; type IContext = IResourceMetricsValue; export const VolumeClaimDiskChart = observer(() => { const { params: { metrics }, object } = useContext(ResourceMetricsContext); const { chartCapacityColor } = ThemeStore.getInstance().activeTheme.colors; const id = object.getId(); if (!metrics) return null; if (isMetricsEmpty(metrics)) return ; const { diskUsage, diskCapacity } = metrics; const usage = normalizeMetrics(diskUsage).data.result[0].values; const capacity = normalizeMetrics(diskCapacity).data.result[0].values; const datasets: ChartDataSets[] = [ { id: `${id}-diskUsage`, label: `Usage`, tooltip: `Volume disk usage`, borderColor: "#ffc63d", data: usage.map(([x, y]) => ({ x, y })), }, { id: `${id}-diskCapacity`, label: `Capacity`, tooltip: `Volume disk capacity`, borderColor: chartCapacityColor, data: capacity.map(([x, y]) => ({ x, y })), }, ]; return ( ); });