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 ChartDual = dynamic(() => import("../components/chart_dual"), { ssr: false }); const defaultPointsLimit = 15; const defaultInterval = (isChart) => (isChart ? 1000 : 5000); export default function Component({ service }) { const { t } = useTranslation(); const { widget } = service; const { chart, metric } = widget; const { refreshInterval = defaultInterval(chart), pointsLimit = defaultPointsLimit, version = 3 } = widget; const rxKey = version === 3 ? "rx" : "bytes_recv"; const txKey = version === 3 ? "tx" : "bytes_sent"; const [, interfaceName] = metric.split(":"); const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit)); const { data, error } = useWidgetAPI(widget, "network", { refreshInterval: Math.max(defaultInterval(chart), refreshInterval), version, }); useEffect(() => { if (data) { const interfaceData = data.find((item) => item[item.key] === interfaceName); if (interfaceData) { setDataPoints((prevDataPoints) => { const newDataPoints = [ ...prevDataPoints, { a: (interfaceData[rxKey] * 8) / interfaceData.time_since_update, b: (interfaceData[txKey] * 8) / interfaceData.time_since_update, }, ]; if (newDataPoints.length > pointsLimit) { newDataPoints.shift(); } return newDataPoints; }); } } }, [data, interfaceName, pointsLimit]); if (error) { return ( ); } if (!data) { return ( - ); } const interfaceData = data.find((item) => item[item.key] === interfaceName); if (!interfaceData) { return ( - ); } return ( {chart && ( t("common.bitrate", { value, maximumFractionDigits: 0, }) } /> )} {interfaceData && interfaceData.interface_name && chart && (
{interfaceData.interface_name}
)}
{t("common.bitrate", { value: (interfaceData[rxKey] * 8) / interfaceData.time_since_update, maximumFractionDigits: 0, })}{" "} {t("docker.rx")}
{!chart && ( {interfaceData && interfaceData.interface_name && (
{interfaceData.interface_name}
)}
)}
{t("common.bitrate", { value: (interfaceData[txKey] * 8) / interfaceData.time_since_update, maximumFractionDigits: 0, })}{" "} {t("docker.tx")}
); }