import dynamic from "next/dynamic"; import { useState, useEffect } from "react"; import { useTranslation } from "next-i18next"; import Error from "../components/error"; import Container from "../components/container"; import Block from "../components/block"; import useWidgetAPI from "utils/proxy/use-widget-api"; const Chart = dynamic(() => import("../components/chart"), { ssr: false }); const defaultPointsLimit = 15; const defaultInterval = 1000; export default function Component({ service }) { const { t } = useTranslation(); const { widget } = service; const { chart, refreshInterval = defaultInterval, pointsLimit = defaultPointsLimit, version = 3 } = widget; const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit)); const { data, error } = useWidgetAPI(service.widget, `${version}/cpu`, { refreshInterval: Math.max(defaultInterval, refreshInterval), }); const { data: quicklookData, error: quicklookError } = useWidgetAPI(service.widget, `${version}/quicklook`); useEffect(() => { if (data) { setDataPoints((prevDataPoints) => { const newDataPoints = [...prevDataPoints, { value: data.total }]; if (newDataPoints.length > pointsLimit) { newDataPoints.shift(); } return newDataPoints; }); } }, [data, pointsLimit]); if (error) { return ( ); } if (!data) { return ( - ); } return ( {chart && ( t("common.number", { value, style: "unit", unit: "percent", maximumFractionDigits: 0, }) } /> )} {!chart && quicklookData && !quicklookError && (
{quicklookData.cpu_name && quicklookData.cpu_name}
)} {quicklookData && !quicklookError && ( {quicklookData.cpu_name && chart &&
{quicklookData.cpu_name}
}
)}
{t("common.number", { value: data.total, style: "unit", unit: "percent", maximumFractionDigits: 0, })}{" "} {t("resources.used")}
); }