import { useTranslation } from "next-i18next"; import Container from "../components/container"; import Block from "../components/block"; import useWidgetAPI from "utils/proxy/use-widget-api"; import ResolvedIcon from "components/resolvedicon"; const statusMap = { R: , // running S: , // sleeping D: , // disk sleep Z: , // zombie T: , // traced t: , // traced X: , // dead }; const defaultInterval = 1000; export default function Component({ service }) { const { t } = useTranslation(); const { widget } = service; const { chart, refreshInterval = defaultInterval, version = 3 } = widget; const memoryInfoKey = version === 3 ? 0 : "data"; const { data, error } = useWidgetAPI(service.widget, `${version}/processlist`, { refreshInterval: Math.max(defaultInterval, refreshInterval), }); if (error) { return ; } if (!data) { return ( - ); } data.splice(chart ? 5 : 1); let headerYPosition = "top-4"; let listYPosition = "bottom-4"; if (chart) { headerYPosition = "-top-6"; listYPosition = "-top-3"; } return (
{t("resources.cpu")}
{t("resources.mem")}
{data.map((item) => (
{statusMap[item.status]}
{item.name}
{item.cpu_percent.toFixed(1)}%
{t("common.bytes", { value: item.memory_info[memoryInfoKey] ?? item.memory_info.wset, maximumFractionDigits: 0, })}
))}
); }