From 0febf05d8d9b8430428e598cc429b296920d7df5 Mon Sep 17 00:00:00 2001 From: Eizock <8332480+Eizock@users.noreply.github.com> Date: Thu, 12 Jan 2023 21:55:07 +0000 Subject: [PATCH] Add Moonraker (Klipper) widget (#798) * Add Moonraker (Klipper) widget * Fix linting * Removed filename, to adhere to standards * Removed unused translation * fix conditional in moonraker component Co-authored-by: Eizock <> Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com> --- public/locales/en/common.json | 6 ++++ src/widgets/components.js | 1 + src/widgets/moonraker/component.jsx | 51 +++++++++++++++++++++++++++++ src/widgets/moonraker/widget.js | 20 +++++++++++ src/widgets/widgets.js | 2 ++ 5 files changed, 80 insertions(+) create mode 100644 src/widgets/moonraker/component.jsx create mode 100644 src/widgets/moonraker/widget.js diff --git a/public/locales/en/common.json b/public/locales/en/common.json index 032c1dfef..a07633ceb 100644 --- a/public/locales/en/common.json +++ b/public/locales/en/common.json @@ -412,5 +412,11 @@ "memory": "Active Memory", "wanUpload": "WAN Upload", "wanDownload": "WAN Download" + }, + "moonraker": { + "printer_state": "Printer State", + "print_status": "Print Status", + "print_progress": "Progress", + "layers": "Layers" } } diff --git a/src/widgets/components.js b/src/widgets/components.js index 10277732f..d92404606 100644 --- a/src/widgets/components.js +++ b/src/widgets/components.js @@ -23,6 +23,7 @@ const components = { mastodon: dynamic(() => import("./mastodon/component")), miniflux: dynamic(() => import("./miniflux/component")), mikrotik: dynamic(() => import("./mikrotik/component")), + moonraker: dynamic(() => import("./moonraker/component")), navidrome: dynamic(() => import("./navidrome/component")), nextdns: dynamic(() => import("./nextdns/component")), npm: dynamic(() => import("./npm/component")), diff --git a/src/widgets/moonraker/component.jsx b/src/widgets/moonraker/component.jsx new file mode 100644 index 000000000..81bf8b908 --- /dev/null +++ b/src/widgets/moonraker/component.jsx @@ -0,0 +1,51 @@ +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: printStats, error: printStatsError } = useWidgetAPI(widget, "print_stats"); + const { data: displayStatus, error: displayStatsError } = useWidgetAPI(widget, "display_status"); + const { data: webHooks, error: webHooksError } = useWidgetAPI(widget, "webhooks"); + + if (printStatsError || displayStatsError || webHooksError) { + const finalError = printStatsError ?? displayStatsError ?? webHooksError; + return ; + } + + if (!printStats || !displayStatus || !webHooks) { + return ( + + + + ); + } + + if (webHooks.result.status.webhooks.state === "shutdown") { + return ( + + + + ); + } + + let currentLayer = "-"; + let totalLayer = "-"; + if (printStats.result.status.print_stats.info.total_layer !== null) { + currentLayer = printStats.result.status.print_stats.info.current_layer; + totalLayer = printStats.result.status.print_stats.info.total_layer; + } + + return ( + + + + + + ); +} diff --git a/src/widgets/moonraker/widget.js b/src/widgets/moonraker/widget.js new file mode 100644 index 000000000..314a8670e --- /dev/null +++ b/src/widgets/moonraker/widget.js @@ -0,0 +1,20 @@ +import genericProxyHandler from "utils/proxy/handlers/generic"; + +const widget = { + api: "{url}/printer/objects/query?{endpoint}", + proxyHandler: genericProxyHandler, + + mappings: { + print_stats: { + endpoint: "print_stats", + }, + display_status: { + endpoint: "display_status", + }, + webhooks: { + endpoint: "webhooks", + }, + }, +}; + +export default widget; diff --git a/src/widgets/widgets.js b/src/widgets/widgets.js index 3e73e55f3..091a616f1 100644 --- a/src/widgets/widgets.js +++ b/src/widgets/widgets.js @@ -18,6 +18,7 @@ import lidarr from "./lidarr/widget"; import mastodon from "./mastodon/widget"; import miniflux from "./miniflux/widget"; import mikrotik from "./mikrotik/widget"; +import moonraker from "./moonraker/widget"; import navidrome from "./navidrome/widget"; import nextdns from "./nextdns/widget"; import npm from "./npm/widget"; @@ -75,6 +76,7 @@ const widgets = { mastodon, miniflux, mikrotik, + moonraker, navidrome, nextdns, npm,