/** * 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 { ChartDataSets } from "../chart"; import { BarChart, memoryOptions } from "../chart"; import { isMetricsEmpty, normalizeMetrics } from "../../../common/k8s-api/endpoints/metrics.api"; import { NoMetrics } from "../resource-metrics/no-metrics"; import { ResourceMetricsContext } from "../resource-metrics"; import type { LensTheme } from "../../themes/store"; import { withInjectables } from "@ogre-tools/injectable-react"; import type { IComputedValue } from "mobx"; import activeThemeInjectable from "../../themes/active.injectable"; export interface VolumeClaimDiskChartProps {} interface Dependencies { activeTheme: IComputedValue; } const NonInjectedVolumeClaimDiskChart = observer(({ activeTheme, }: Dependencies & VolumeClaimDiskChartProps) => { const { metrics, tab, object } = useContext(ResourceMetricsContext) ?? {}; if (!metrics || !object || !tab) return null; if (isMetricsEmpty(metrics)) return ; const id = object.getId(); const { chartCapacityColor } = activeTheme.get().colors; 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 ( ); }); export const VolumeClaimDiskChart = withInjectables(NonInjectedVolumeClaimDiskChart, { getProps: (di, props) => ({ ...props, activeTheme: di.inject(activeThemeInjectable), }), });