diff --git a/public/locales/en/common.json b/public/locales/en/common.json index 37ff7baa..98f2b796 100644 --- a/public/locales/en/common.json +++ b/public/locales/en/common.json @@ -483,5 +483,11 @@ "processing": "Processing", "processed": "Processed", "time": "Time" + }, + "grafana": { + "dashboards": "Dashboards", + "datasources": "Data Sources", + "totalalerts": "Total Alerts", + "alertstriggered": "Alerts Triggered" } } \ No newline at end of file diff --git a/src/widgets/components.js b/src/widgets/components.js index 9623c63d..8c5c42e7 100644 --- a/src/widgets/components.js +++ b/src/widgets/components.js @@ -18,6 +18,7 @@ const components = { flood: dynamic(() => import("./flood/component")), gluetun: dynamic(() => import("./gluetun/component")), gotify: dynamic(() => import("./gotify/component")), + grafana: dynamic(() => import("./grafana/component")), hdhomerun: dynamic(() => import("./hdhomerun/component")), homebridge: dynamic(() => import("./homebridge/component")), jackett: dynamic(() => import("./jackett/component")), diff --git a/src/widgets/grafana/component.jsx b/src/widgets/grafana/component.jsx new file mode 100755 index 00000000..98d4c42b --- /dev/null +++ b/src/widgets/grafana/component.jsx @@ -0,0 +1,37 @@ +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: statsData, error: statsError } = useWidgetAPI(widget, "stats"); + const { data: alertsData, error: alertsError } = useWidgetAPI(widget, "alerts"); + + if (statsError || alertsError) { + return ; + } + + if (!statsData || !alertsData) { + return ( + + + + + + + ); + } + + return ( + + + + + a.state === "alerting").length })} /> + + ); +} diff --git a/src/widgets/grafana/widget.js b/src/widgets/grafana/widget.js new file mode 100755 index 00000000..64051925 --- /dev/null +++ b/src/widgets/grafana/widget.js @@ -0,0 +1,20 @@ +import genericProxyHandler from "utils/proxy/handlers/generic"; + +const widget = { + api: "{url}/api/{endpoint}", + proxyHandler: genericProxyHandler, + + mappings: { + alerts: { + endpoint: "alerts", + }, + stats: { + endpoint: "admin/stats", + validate: [ + "dashboards" + ] + }, + }, +}; + +export default widget; \ No newline at end of file diff --git a/src/widgets/widgets.js b/src/widgets/widgets.js index ff2a2787..111da7eb 100644 --- a/src/widgets/widgets.js +++ b/src/widgets/widgets.js @@ -13,6 +13,7 @@ import fileflows from "./fileflows/widget"; import flood from "./flood/widget"; import gluetun from "./gluetun/widget"; import gotify from "./gotify/widget"; +import grafana from "./grafana/widget"; import hdhomerun from "./hdhomerun/widget"; import homebridge from "./homebridge/widget"; import jackett from "./jackett/widget"; @@ -80,6 +81,7 @@ const widgets = { flood, gluetun, gotify, + grafana, hdhomerun, homebridge, jackett,