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 version = widget.version ?? 1; const { data: systemData, error: systemError } = useWidgetAPI(widget, version === 1 ? "system" : "systemv2"); const { data: interfaceData, error: interfaceError } = useWidgetAPI( widget, version === 1 ? "interface" : "interfacev2", ); const showWanIP = widget.fields?.filter((f) => f !== "wanIP").length <= 4 && widget.fields?.includes("wanIP"); const showDiskUsage = widget.fields?.filter((f) => f !== "disk").length <= 4 && widget.fields?.includes("disk"); if (systemError || interfaceError) { const finalError = systemError ?? interfaceError; return ; } if (!systemData || !interfaceData) { return ( {showWanIP && } {showDiskUsage && } ); } const wan = interfaceData.data.filter((l) => l.hwif === widget.wan)[0]; let memUsage = systemData?.data.mem_usage; let diskUsage = systemData.data.disk_usage; if (version === 1) { memUsage *= 100; diskUsage *= 100; } return ( {t("pfsense.up")} ) : ( {t("pfsense.down")} ) } /> {showWanIP && } {showDiskUsage && } ); }