import { useTranslation } from "next-i18next"; import Container from "components/services/widget/container"; import Block from "components/services/widget/block"; import useWidgetAPI from "utils/proxy/use-widget-api"; export default function Component({ service }) { const { t } = useTranslation(); const { widget } = service; const { data: datastoreData, error: datastoreError } = useWidgetAPI(widget, "status/datastore-usage"); const { data: tasksData, error: tasksError } = useWidgetAPI(widget, "nodes/localhost/tasks"); const { data: hostData, error: hostError } = useWidgetAPI(widget, "nodes/localhost/status"); if (datastoreError || tasksError || hostError) { const finalError = tasksError ?? datastoreError ?? hostError; return ; } if (!datastoreData || !tasksData || !hostData) { return ( ); } const datastoreUsage = datastoreData.data[0].used / datastoreData.data[0].total * 100; const cpuUsage = hostData.data.cpu * 100; const memoryUsage = hostData.data.memory.used / hostData.data.memory.total * 100; const failedTasks = tasksData.total >= 100 ? "99+" : tasksData.total; return ( ); }