Преглед на файлове

Add widget for Atsumeru self-hosted media server (#1839)

* Add widget for Atsumeru self-hosted media server

* Revert localization

* Update widget.js

---------

Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
AtsumeruDev преди 1 година
родител
ревизия
a6dac34b24
променени са 5 файла, в които са добавени 59 реда и са изтрити 0 реда
  1. 6 0
      public/locales/en/common.json
  2. 36 0
      src/widgets/atsumeru/component.jsx
  3. 14 0
      src/widgets/atsumeru/widget.js
  4. 1 0
      src/widgets/components.js
  5. 2 0
      src/widgets/widgets.js

+ 6 - 0
public/locales/en/common.json

@@ -579,6 +579,12 @@
         "incident": "Incident",
         "m": "m"
     },
+    "atsumeru": {
+        "series": "Series",
+        "archives": "Archives",
+        "chapters": "Chapters",
+        "categories": "Categories"
+    },
     "komga": {
         "libraries": "Libraries",
         "series": "Series",

+ 36 - 0
src/widgets/atsumeru/component.jsx

@@ -0,0 +1,36 @@
+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: infoData, error: infoError } = useWidgetAPI(widget, "info");
+
+  if (infoError) {
+    return <Container service={service} error={infoError} />;
+  }
+
+  if (!infoData) {
+    return (
+      <Container service={service}>
+        <Block label="atsumeru.series" />
+        <Block label="atsumeru.archives" />
+        <Block label="atsumeru.chapters" />
+        <Block label="atsumeru.categories" />
+      </Container>
+    );
+  }
+
+  return (
+    <Container service={service}>
+      <Block label="atsumeru.series" value={t("common.number", { value: infoData.stats.total_series })} />
+      <Block label="atsumeru.archives" value={t("common.number", { value: infoData.stats.total_archives })} />
+      <Block label="atsumeru.chapters" value={t("common.number", { value: infoData.stats.total_chapters })} />
+      <Block label="atsumeru.categories" value={t("common.number", { value: infoData.stats.total_categories })} />
+    </Container>
+  );
+}

+ 14 - 0
src/widgets/atsumeru/widget.js

@@ -0,0 +1,14 @@
+import genericProxyHandler from "utils/proxy/handlers/generic";
+
+const widget = {
+  api: "{url}/api/server/{endpoint}",
+  proxyHandler: genericProxyHandler,
+
+  mappings: {
+    info: {
+      endpoint: "info"
+    }
+  },
+};
+
+export default widget;

+ 1 - 0
src/widgets/components.js

@@ -2,6 +2,7 @@ import dynamic from "next/dynamic";
 
 const components = {
   adguard: dynamic(() => import("./adguard/component")),
+  atsumeru: dynamic(() => import("./atsumeru/component")),
   audiobookshelf: dynamic(() => import("./audiobookshelf/component")),
   authentik: dynamic(() => import("./authentik/component")),
   autobrr: dynamic(() => import("./autobrr/component")),

+ 2 - 0
src/widgets/widgets.js

@@ -1,4 +1,5 @@
 import adguard from "./adguard/widget";
+import atsumeru from "./atsumeru/widget";
 import audiobookshelf from "./audiobookshelf/widget";
 import authentik from "./authentik/widget";
 import autobrr from "./autobrr/widget";
@@ -96,6 +97,7 @@ import urbackup from "./urbackup/widget";
 
 const widgets = {
   adguard,
+  atsumeru,
   audiobookshelf,
   authentik,
   autobrr,