{t("common.bitrate", {
- value: (interfaceData.tx * 8) / interfaceData.time_since_update,
+ value: (interfaceData[txKey] * 8) / interfaceData.time_since_update,
maximumFractionDigits: 0,
})}{" "}
{t("docker.tx")}
diff --git a/src/widgets/glances/metrics/process.jsx b/src/widgets/glances/metrics/process.jsx
index 0b2e8e4b..24b447cb 100644
--- a/src/widgets/glances/metrics/process.jsx
+++ b/src/widgets/glances/metrics/process.jsx
@@ -22,10 +22,13 @@ const defaultInterval = 1000;
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
- const { chart, refreshInterval = defaultInterval } = widget;
+ const { chart, refreshInterval = defaultInterval, version = 3 } = widget;
+
+ const memoryInfoKey = version === 3 ? 0 : "data";
const { data, error } = useWidgetAPI(service.widget, "processlist", {
refreshInterval: Math.max(defaultInterval, refreshInterval),
+ version,
});
if (error) {
@@ -66,7 +69,7 @@ export default function Component({ service }) {
{item.cpu_percent.toFixed(1)}%
{t("common.bytes", {
- value: item.memory_info[0],
+ value: item.memory_info[memoryInfoKey],
maximumFractionDigits: 0,
})}
diff --git a/src/widgets/glances/metrics/sensor.jsx b/src/widgets/glances/metrics/sensor.jsx
index 60ea07c8..9dc28bb1 100644
--- a/src/widgets/glances/metrics/sensor.jsx
+++ b/src/widgets/glances/metrics/sensor.jsx
@@ -16,13 +16,14 @@ const defaultInterval = 1000;
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
- const { chart, refreshInterval = defaultInterval, pointsLimit = defaultPointsLimit } = widget;
+ const { chart, refreshInterval = defaultInterval, pointsLimit = defaultPointsLimit, version = 3 } = widget;
const [, sensorName] = widget.metric.split(":");
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit));
const { data, error } = useWidgetAPI(service.widget, "sensors", {
refreshInterval: Math.max(defaultInterval, refreshInterval),
+ version,
});
useEffect(() => {
diff --git a/src/widgets/glances/widget.js b/src/widgets/glances/widget.js
index 3da1c6d1..a824e4c1 100644
--- a/src/widgets/glances/widget.js
+++ b/src/widgets/glances/widget.js
@@ -1,7 +1,7 @@
import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
const widget = {
- api: "{url}/api/3/{endpoint}",
+ api: "{url}/api/{version}/{endpoint}",
proxyHandler: credentialedProxyHandler,
};
From d4c0e482d3e233bea9de23b17b1060e80bf84c7b Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Thu, 28 Mar 2024 15:39:40 -0500
Subject: [PATCH 049/136] Feature: crowdsec widget (#3197)
---
docs/widgets/services/crowdsec.md | 19 +++++++
mkdocs.yml | 1 +
public/locales/en/common.json | 4 ++
src/widgets/components.js | 1 +
src/widgets/crowdsec/component.jsx | 34 +++++++++++
src/widgets/crowdsec/proxy.js | 90 ++++++++++++++++++++++++++++++
src/widgets/crowdsec/widget.js | 18 ++++++
src/widgets/widgets.js | 2 +
8 files changed, 169 insertions(+)
create mode 100644 docs/widgets/services/crowdsec.md
create mode 100644 src/widgets/crowdsec/component.jsx
create mode 100644 src/widgets/crowdsec/proxy.js
create mode 100644 src/widgets/crowdsec/widget.js
diff --git a/docs/widgets/services/crowdsec.md b/docs/widgets/services/crowdsec.md
new file mode 100644
index 00000000..608367df
--- /dev/null
+++ b/docs/widgets/services/crowdsec.md
@@ -0,0 +1,19 @@
+---
+title: Crowdsec
+description: Crowdsec Widget Configuration
+---
+
+Learn more about [Crowdsec](https://crowdsec.net).
+
+See the [crowdsec docs](https://docs.crowdsec.net/docs/local_api/intro/#machines) for information about registering a machine,
+in most instances you can use the default credentials (`/etc/crowdsec/local_api_credentials.yaml`).
+
+Allowed fields: ["alerts", "bans"]
+
+```yaml
+widget:
+ type: crowdsec
+ url: http://crowdsechostorip:port
+ username: localhost # machine_id in crowdsec
+ passowrd: password
+```
diff --git a/mkdocs.yml b/mkdocs.yml
index a0994fad..e58cb1e4 100644
--- a/mkdocs.yml
+++ b/mkdocs.yml
@@ -44,6 +44,7 @@ nav:
- widgets/services/channelsdvrserver.md
- widgets/services/cloudflared.md
- widgets/services/coin-market-cap.md
+ - widgets/services/crowdsec.md
- widgets/services/customapi.md
- widgets/services/deluge.md
- widgets/services/diskstation.md
diff --git a/public/locales/en/common.json b/public/locales/en/common.json
index c7339c0b..98daae9e 100644
--- a/public/locales/en/common.json
+++ b/public/locales/en/common.json
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/src/widgets/components.js b/src/widgets/components.js
index f3d567bb..8c85bd77 100644
--- a/src/widgets/components.js
+++ b/src/widgets/components.js
@@ -15,6 +15,7 @@ const components = {
channelsdvrserver: dynamic(() => import("./channelsdvrserver/component")),
cloudflared: dynamic(() => import("./cloudflared/component")),
coinmarketcap: dynamic(() => import("./coinmarketcap/component")),
+ crowdsec: dynamic(() => import("./crowdsec/component")),
iframe: dynamic(() => import("./iframe/component")),
customapi: dynamic(() => import("./customapi/component")),
deluge: dynamic(() => import("./deluge/component")),
diff --git a/src/widgets/crowdsec/component.jsx b/src/widgets/crowdsec/component.jsx
new file mode 100644
index 00000000..9565ee73
--- /dev/null
+++ b/src/widgets/crowdsec/component.jsx
@@ -0,0 +1,34 @@
+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: alerts, error: alertsError } = useWidgetAPI(widget, "alerts");
+ const { data: bans, error: bansError } = useWidgetAPI(widget, "bans");
+
+ if (alertsError || bansError) {
+ return
;
+ }
+
+ if (!alerts || !bans) {
+ return (
+
+
+
+
+ );
+ }
+
+ return (
+
+
+
+
+ );
+}
diff --git a/src/widgets/crowdsec/proxy.js b/src/widgets/crowdsec/proxy.js
new file mode 100644
index 00000000..a367e716
--- /dev/null
+++ b/src/widgets/crowdsec/proxy.js
@@ -0,0 +1,90 @@
+import cache from "memory-cache";
+
+import { httpProxy } from "utils/proxy/http";
+import { formatApiCall } from "utils/proxy/api-helpers";
+import getServiceWidget from "utils/config/service-helpers";
+import createLogger from "utils/logger";
+import widgets from "widgets/widgets";
+
+const proxyName = "crowdsecProxyHandler";
+const logger = createLogger(proxyName);
+const sessionTokenCacheKey = `${proxyName}__sessionToken`;
+
+async function login(widget, service) {
+ const url = formatApiCall(widgets[widget.type].loginURL, widget);
+ const [status, , data] = await httpProxy(url, {
+ method: "POST",
+ headers: {
+ "Content-Type": "application/json",
+ "User-Agent": "Mozilla/5.0", // Crowdsec requires a user-agent
+ },
+ body: JSON.stringify({
+ machine_id: widget.username,
+ password: widget.password,
+ scenarios: [],
+ }),
+ });
+
+ const dataParsed = JSON.parse(data);
+
+ if (!(status === 200) || !dataParsed.token) {
+ logger.error("Failed to login to Crowdsec API, status: %d", status);
+ cache.del(`${sessionTokenCacheKey}.${service}`);
+ }
+ cache.put(`${sessionTokenCacheKey}.${service}`, dataParsed.token, new Date(dataParsed.expire) - new Date());
+}
+
+export default async function crowdsecProxyHandler(req, res) {
+ const { group, service, endpoint } = req.query;
+
+ if (!group || !service) {
+ logger.error("Invalid or missing service '%s' or group '%s'", service, group);
+ return res.status(400).json({ error: "Invalid proxy service type" });
+ }
+
+ const widget = await getServiceWidget(group, service);
+ if (!widget || !widgets[widget.type].api) {
+ logger.error("Invalid or missing widget for service '%s' in group '%s'", service, group);
+ return res.status(400).json({ error: "Invalid widget configuration" });
+ }
+
+ if (!cache.get(`${sessionTokenCacheKey}.${service}`)) {
+ await login(widget, service);
+ }
+
+ const token = cache.get(`${sessionTokenCacheKey}.${service}`);
+ if (!token) {
+ return res.status(500).json({ error: "Failed to authenticate with Crowdsec" });
+ }
+
+ const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint, ...widget }));
+
+ try {
+ const params = {
+ method: "GET",
+ headers: {
+ "User-Agent": "Mozilla/5.0", // Crowdsec requires a user-agent
+ "Content-Type": "application/json",
+ Authorization: `Bearer ${token}`,
+ },
+ };
+
+ logger.debug("Calling Crowdsec API endpoint: %s", endpoint);
+
+ if (endpoint.indexOf("decisions") === 0) {
+ delete params.headers.Authorization;
+ }
+
+ const [status, , data] = await httpProxy(url, params);
+
+ if (status !== 200) {
+ logger.error("Error calling Crowdsec API: %d. Data: %s", status, data);
+ return res.status(status).json({ error: "Crowdsec API Error", data });
+ }
+
+ return res.status(status).send(data);
+ } catch (error) {
+ logger.error("Exception calling Crowdsec API: %s", error.message);
+ return res.status(500).json({ error: "Crowdsec API Error", message: error.message });
+ }
+}
diff --git a/src/widgets/crowdsec/widget.js b/src/widgets/crowdsec/widget.js
new file mode 100644
index 00000000..d29fa1f1
--- /dev/null
+++ b/src/widgets/crowdsec/widget.js
@@ -0,0 +1,18 @@
+import crowdsecProxyHandler from "./proxy";
+
+const widget = {
+ api: "{url}/v1/{endpoint}",
+ loginURL: "{url}/v1/watchers/login",
+ proxyHandler: crowdsecProxyHandler,
+
+ mappings: {
+ alerts: {
+ endpoint: "alerts",
+ },
+ bans: {
+ endpoint: "alerts?decision_type=ban&origin=crowdsec&has_active_decision=1",
+ },
+ },
+};
+
+export default widget;
diff --git a/src/widgets/widgets.js b/src/widgets/widgets.js
index a9cae230..6e02d932 100644
--- a/src/widgets/widgets.js
+++ b/src/widgets/widgets.js
@@ -12,6 +12,7 @@ import changedetectionio from "./changedetectionio/widget";
import channelsdvrserver from "./channelsdvrserver/widget";
import cloudflared from "./cloudflared/widget";
import coinmarketcap from "./coinmarketcap/widget";
+import crowdsec from "./crowdsec/widget";
import customapi from "./customapi/widget";
import deluge from "./deluge/widget";
import diskstation from "./diskstation/widget";
@@ -125,6 +126,7 @@ const widgets = {
channelsdvrserver,
cloudflared,
coinmarketcap,
+ crowdsec,
customapi,
deluge,
diskstation,
From 97d193faf12a18142d5e2f117f67db5df7f5eb65 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Thu, 28 Mar 2024 13:41:29 -0700
Subject: [PATCH 050/136] Fix crowdsec widget with no bans / alerts
---
src/widgets/crowdsec/component.jsx | 6 +++---
src/widgets/crowdsec/proxy.js | 4 ----
2 files changed, 3 insertions(+), 7 deletions(-)
diff --git a/src/widgets/crowdsec/component.jsx b/src/widgets/crowdsec/component.jsx
index 9565ee73..2e98cee9 100644
--- a/src/widgets/crowdsec/component.jsx
+++ b/src/widgets/crowdsec/component.jsx
@@ -16,7 +16,7 @@ export default function Component({ service }) {
return
;
}
- if (!alerts || !bans) {
+ if (!alerts && !bans) {
return (
@@ -27,8 +27,8 @@ export default function Component({ service }) {
return (
-
-
+
+
);
}
diff --git a/src/widgets/crowdsec/proxy.js b/src/widgets/crowdsec/proxy.js
index a367e716..e78fbc5e 100644
--- a/src/widgets/crowdsec/proxy.js
+++ b/src/widgets/crowdsec/proxy.js
@@ -71,10 +71,6 @@ export default async function crowdsecProxyHandler(req, res) {
logger.debug("Calling Crowdsec API endpoint: %s", endpoint);
- if (endpoint.indexOf("decisions") === 0) {
- delete params.headers.Authorization;
- }
-
const [status, , data] = await httpProxy(url, params);
if (status !== 200) {
From b0d57866a0ed0e2507d12ca480c17e0bb8cc0199 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Fri, 29 Mar 2024 06:32:25 -0700
Subject: [PATCH 051/136] Fix glances service widgets handling of default
version
---
src/widgets/glances/metrics/cpu.jsx | 5 ++---
src/widgets/glances/metrics/disk.jsx | 3 +--
src/widgets/glances/metrics/fs.jsx | 3 +--
src/widgets/glances/metrics/gpu.jsx | 3 +--
src/widgets/glances/metrics/info.jsx | 6 ++----
src/widgets/glances/metrics/memory.jsx | 3 +--
src/widgets/glances/metrics/net.jsx | 5 ++---
src/widgets/glances/metrics/process.jsx | 3 +--
src/widgets/glances/metrics/sensor.jsx | 3 +--
src/widgets/glances/widget.js | 2 +-
10 files changed, 13 insertions(+), 23 deletions(-)
diff --git a/src/widgets/glances/metrics/cpu.jsx b/src/widgets/glances/metrics/cpu.jsx
index bd12dc29..553517ba 100644
--- a/src/widgets/glances/metrics/cpu.jsx
+++ b/src/widgets/glances/metrics/cpu.jsx
@@ -20,12 +20,11 @@ export default function Component({ service }) {
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(service.widget, "cpu", {
+ const { data, error } = useWidgetAPI(service.widget, `${version}/cpu`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
- const { data: quicklookData, error: quicklookError } = useWidgetAPI(service.widget, "quicklook", { version });
+ const { data: quicklookData, error: quicklookError } = useWidgetAPI(service.widget, `${version}/quicklook`);
useEffect(() => {
if (data) {
diff --git a/src/widgets/glances/metrics/disk.jsx b/src/widgets/glances/metrics/disk.jsx
index 662822ef..04a5071f 100644
--- a/src/widgets/glances/metrics/disk.jsx
+++ b/src/widgets/glances/metrics/disk.jsx
@@ -24,9 +24,8 @@ export default function Component({ service }) {
);
const [ratePoints, setRatePoints] = useState(new Array(pointsLimit).fill({ a: 0, b: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(service.widget, "diskio", {
+ const { data, error } = useWidgetAPI(service.widget, `${version}/diskio`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
const calculateRates = (d) =>
diff --git a/src/widgets/glances/metrics/fs.jsx b/src/widgets/glances/metrics/fs.jsx
index 1a26c2ab..3ec7eb6c 100644
--- a/src/widgets/glances/metrics/fs.jsx
+++ b/src/widgets/glances/metrics/fs.jsx
@@ -15,9 +15,8 @@ export default function Component({ service }) {
const [, fsName] = widget.metric.split("fs:");
const diskUnits = widget.diskUnits === "bbytes" ? "common.bbytes" : "common.bytes";
- const { data, error } = useWidgetAPI(widget, "fs", {
+ const { data, error } = useWidgetAPI(widget, `${version}/fs`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
if (error) {
diff --git a/src/widgets/glances/metrics/gpu.jsx b/src/widgets/glances/metrics/gpu.jsx
index cc8504fa..174ae2e0 100644
--- a/src/widgets/glances/metrics/gpu.jsx
+++ b/src/widgets/glances/metrics/gpu.jsx
@@ -21,9 +21,8 @@ export default function Component({ service }) {
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ a: 0, b: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(widget, "gpu", {
+ const { data, error } = useWidgetAPI(widget, `${version}/gpu`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
useEffect(() => {
diff --git a/src/widgets/glances/metrics/info.jsx b/src/widgets/glances/metrics/info.jsx
index a90cbdb5..1ee47b98 100644
--- a/src/widgets/glances/metrics/info.jsx
+++ b/src/widgets/glances/metrics/info.jsx
@@ -76,14 +76,12 @@ export default function Component({ service }) {
const { widget } = service;
const { chart, refreshInterval = defaultInterval, version = 3 } = widget;
- const { data: quicklookData, errorL: quicklookError } = useWidgetAPI(service.widget, "quicklook", {
+ const { data: quicklookData, errorL: quicklookError } = useWidgetAPI(service.widget, `${version}/quicklook`, {
refreshInterval,
- version,
});
- const { data: systemData, errorL: systemError } = useWidgetAPI(service.widget, "system", {
+ const { data: systemData, errorL: systemError } = useWidgetAPI(service.widget, `${version}/system`, {
refreshInterval: defaultSystemInterval,
- version,
});
if (quicklookError) {
diff --git a/src/widgets/glances/metrics/memory.jsx b/src/widgets/glances/metrics/memory.jsx
index 87ec0f78..49046a5f 100644
--- a/src/widgets/glances/metrics/memory.jsx
+++ b/src/widgets/glances/metrics/memory.jsx
@@ -21,9 +21,8 @@ export default function Component({ service }) {
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(service.widget, "mem", {
+ const { data, error } = useWidgetAPI(service.widget, `${version}/mem`, {
refreshInterval: Math.max(defaultInterval(chart), refreshInterval),
- version,
});
useEffect(() => {
diff --git a/src/widgets/glances/metrics/net.jsx b/src/widgets/glances/metrics/net.jsx
index a51c8388..c1ec937e 100644
--- a/src/widgets/glances/metrics/net.jsx
+++ b/src/widgets/glances/metrics/net.jsx
@@ -26,9 +26,8 @@ export default function Component({ service }) {
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(widget, "network", {
+ const { data, error } = useWidgetAPI(widget, `${version}/network`, {
refreshInterval: Math.max(defaultInterval(chart), refreshInterval),
- version,
});
useEffect(() => {
@@ -51,7 +50,7 @@ export default function Component({ service }) {
});
}
}
- }, [data, interfaceName, pointsLimit]);
+ }, [data, interfaceName, pointsLimit, rxKey, txKey]);
if (error) {
return (
diff --git a/src/widgets/glances/metrics/process.jsx b/src/widgets/glances/metrics/process.jsx
index 24b447cb..b242535e 100644
--- a/src/widgets/glances/metrics/process.jsx
+++ b/src/widgets/glances/metrics/process.jsx
@@ -26,9 +26,8 @@ export default function Component({ service }) {
const memoryInfoKey = version === 3 ? 0 : "data";
- const { data, error } = useWidgetAPI(service.widget, "processlist", {
+ const { data, error } = useWidgetAPI(service.widget, `${version}/processlist`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
if (error) {
diff --git a/src/widgets/glances/metrics/sensor.jsx b/src/widgets/glances/metrics/sensor.jsx
index 9dc28bb1..e0f679c1 100644
--- a/src/widgets/glances/metrics/sensor.jsx
+++ b/src/widgets/glances/metrics/sensor.jsx
@@ -21,9 +21,8 @@ export default function Component({ service }) {
const [dataPoints, setDataPoints] = useState(new Array(pointsLimit).fill({ value: 0 }, 0, pointsLimit));
- const { data, error } = useWidgetAPI(service.widget, "sensors", {
+ const { data, error } = useWidgetAPI(service.widget, `${version}/sensors`, {
refreshInterval: Math.max(defaultInterval, refreshInterval),
- version,
});
useEffect(() => {
diff --git a/src/widgets/glances/widget.js b/src/widgets/glances/widget.js
index a824e4c1..3357cf28 100644
--- a/src/widgets/glances/widget.js
+++ b/src/widgets/glances/widget.js
@@ -1,7 +1,7 @@
import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
const widget = {
- api: "{url}/api/{version}/{endpoint}",
+ api: "{url}/api/{endpoint}",
proxyHandler: credentialedProxyHandler,
};
From 29ac7bfea7af2e19af38c88f9c583be1806abbb0 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Sun, 31 Mar 2024 20:34:46 -0700
Subject: [PATCH 052/136] Feature: Support pi-hole v6 (#3207)
---
docs/widgets/services/pihole.md | 1 +
src/utils/config/service-helpers.js | 8 ++-
src/widgets/pihole/component.jsx | 2 +-
src/widgets/pihole/proxy.js | 95 +++++++++++++++++++++++++++++
src/widgets/pihole/widget.js | 14 ++---
5 files changed, 107 insertions(+), 13 deletions(-)
create mode 100644 src/widgets/pihole/proxy.js
diff --git a/docs/widgets/services/pihole.md b/docs/widgets/services/pihole.md
index 8079d1b1..90d5926c 100644
--- a/docs/widgets/services/pihole.md
+++ b/docs/widgets/services/pihole.md
@@ -15,6 +15,7 @@ Note: by default the "blocked" and "blocked_percent" fields are merged e.g. "1,2
widget:
type: pihole
url: http://pi.hole.or.ip
+ version: 6 # required if running v6 or higher, defaults to 5
key: yourpiholeapikey # optional
```
diff --git a/src/utils/config/service-helpers.js b/src/utils/config/service-helpers.js
index bee7db4e..bea28278 100644
--- a/src/utils/config/service-helpers.js
+++ b/src/utils/config/service-helpers.js
@@ -393,8 +393,10 @@ export function cleanServiceGroups(groups) {
enableBlocks,
enableNowPlaying,
- // glances
+ // glances, pihole
version,
+
+ // glances
chart,
metric,
pointsLimit,
@@ -528,8 +530,10 @@ export function cleanServiceGroups(groups) {
if (snapshotHost) cleanedService.widget.snapshotHost = snapshotHost;
if (snapshotPath) cleanedService.widget.snapshotPath = snapshotPath;
}
- if (type === "glances") {
+ if (["glances", "pihole"].includes(type)) {
if (version) cleanedService.widget.version = version;
+ }
+ if (type === "glances") {
if (metric) cleanedService.widget.metric = metric;
if (chart !== undefined) {
cleanedService.widget.chart = chart;
diff --git a/src/widgets/pihole/component.jsx b/src/widgets/pihole/component.jsx
index a36071a1..4d95b4ac 100644
--- a/src/widgets/pihole/component.jsx
+++ b/src/widgets/pihole/component.jsx
@@ -9,7 +9,7 @@ export default function Component({ service }) {
const { widget } = service;
- const { data: piholeData, error: piholeError } = useWidgetAPI(widget, "summaryRaw");
+ const { data: piholeData, error: piholeError } = useWidgetAPI(widget);
if (piholeError) {
return ;
diff --git a/src/widgets/pihole/proxy.js b/src/widgets/pihole/proxy.js
new file mode 100644
index 00000000..724d4943
--- /dev/null
+++ b/src/widgets/pihole/proxy.js
@@ -0,0 +1,95 @@
+import cache from "memory-cache";
+
+import { httpProxy } from "utils/proxy/http";
+import { formatApiCall } from "utils/proxy/api-helpers";
+import getServiceWidget from "utils/config/service-helpers";
+import createLogger from "utils/logger";
+import widgets from "widgets/widgets";
+
+const proxyName = "piholeProxyHandler";
+const logger = createLogger(proxyName);
+const sessionSIDCacheKey = `${proxyName}__sessionSID`;
+
+async function login(widget, service) {
+ const url = formatApiCall(widgets[widget.type].api, { ...widget, endpoint: "auth" });
+ const [status, , data] = await httpProxy(url, {
+ method: "POST",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ password: widget.key,
+ }),
+ });
+
+ const dataParsed = JSON.parse(data);
+
+ if (status !== 200 || !dataParsed.session) {
+ logger.error("Failed to login to Pi-Hole API, status: %d", status);
+ cache.del(`${sessionSIDCacheKey}.${service}`);
+ } else {
+ cache.put(`${sessionSIDCacheKey}.${service}`, dataParsed.session.sid, dataParsed.session.validity);
+ }
+}
+
+export default async function piholeProxyHandler(req, res) {
+ const { group, service } = req.query;
+ let endpoint = "stats/summary";
+
+ if (!group || !service) {
+ logger.error("Invalid or missing service '%s' or group '%s'", service, group);
+ return res.status(400).json({ error: "Invalid proxy service type" });
+ }
+
+ const widget = await getServiceWidget(group, service);
+ if (!widget) {
+ logger.error("Invalid or missing widget for service '%s' in group '%s'", service, group);
+ return res.status(400).json({ error: "Invalid widget configuration" });
+ }
+
+ let status;
+ let data;
+ if (!widget.version || widget.version < 6) {
+ // pihole v5
+ endpoint = "summaryRaw";
+ [status, , data] = await httpProxy(formatApiCall(widgets[widget.type].apiv5, { ...widget, endpoint }));
+ return res.status(status).send(data);
+ }
+
+ // pihole v6
+ if (!cache.get(`${sessionSIDCacheKey}.${service}`)) {
+ await login(widget, service);
+ }
+
+ const sid = cache.get(`${sessionSIDCacheKey}.${service}`);
+ if (!sid) {
+ return res.status(500).json({ error: "Failed to authenticate with Pi-hole" });
+ }
+
+ try {
+ logger.debug("Calling Pi-hole API endpoint: %s", endpoint);
+
+ [status, , data] = await httpProxy(formatApiCall(widgets[widget.type].api, { ...widget, endpoint }), {
+ headers: {
+ "Content-Type": "application/json",
+ "X-FTL-SID": sid,
+ },
+ });
+
+ if (status !== 200) {
+ logger.error("Error calling Pi-Hole API: %d. Data: %s", status, data);
+ return res.status(status).json({ error: "Pi-Hole API Error", data });
+ }
+
+ const dataParsed = JSON.parse(data);
+ return res.status(status).json({
+ domains_being_blocked: dataParsed.gravity.domains_being_blocked,
+ ads_blocked_today: dataParsed.queries.blocked,
+ ads_percentage_today: dataParsed.queries.percent_blocked,
+ dns_queries_today: dataParsed.queries.total,
+ });
+ } catch (error) {
+ logger.error("Exception calling Pi-Hole API: %s", error.message);
+ return res.status(500).json({ error: "Pi-Hole API Error", message: error.message });
+ }
+}
diff --git a/src/widgets/pihole/widget.js b/src/widgets/pihole/widget.js
index 10b30b1a..54c84832 100644
--- a/src/widgets/pihole/widget.js
+++ b/src/widgets/pihole/widget.js
@@ -1,15 +1,9 @@
-import genericProxyHandler from "utils/proxy/handlers/generic";
+import piholeProxyHandler from "./proxy";
const widget = {
- api: "{url}/admin/api.php?{endpoint}&auth={key}",
- proxyHandler: genericProxyHandler,
-
- mappings: {
- summaryRaw: {
- endpoint: "summaryRaw",
- validate: ["dns_queries_today", "ads_blocked_today", "ads_percentage_today", "domains_being_blocked"],
- },
- },
+ api: "{url}/api/{endpoint}",
+ apiv5: "{url}/admin/api.php?{endpoint}&auth={key}",
+ proxyHandler: piholeProxyHandler,
};
export default widget;
From 212e517ebbccfb5b3636d808dd95de447ea5f725 Mon Sep 17 00:00:00 2001
From: Jalin Wang
Date: Mon, 1 Apr 2024 22:23:52 +0800
Subject: [PATCH 053/136] Chore: fix ypos in the PR template (#3209)
---------
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
---
.github/PULL_REQUEST_TEMPLATE.md | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md
index 1cad352a..bf4fa386 100644
--- a/.github/PULL_REQUEST_TEMPLATE.md
+++ b/.github/PULL_REQUEST_TEMPLATE.md
@@ -1,12 +1,12 @@
## Proposed change
Closes # (issue)
From dd819ad6777874af3d33c419cc87cb7b214383f7 Mon Sep 17 00:00:00 2001
From: Jalin Wang
Date: Mon, 1 Apr 2024 22:25:14 +0800
Subject: [PATCH 054/136] Documentation: correct link for Docker automatic
service discovery (#3208)
---
README.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/README.md b/README.md
index 5bc61685..d137ba5e 100644
--- a/README.md
+++ b/README.md
@@ -41,7 +41,7 @@ With features like quick search, bookmarks, weather support, a wide range of int
## Docker Integration
-Homepage has built-in support for Docker, and can automatically discover and add services to the homepage based on labels. See the [Docker](https://gethomepage.dev/latest/installation/docker/) page for more information.
+Homepage has built-in support for Docker, and can automatically discover and add services to the homepage based on labels. See the [Docker Service Discovery](https://gethomepage.dev/latest/configs/docker/#automatic-service-discovery) page for more information.
## Service Widgets
From 29447c55ffe99bfe9b941354cc3763caad254e15 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Mon, 1 Apr 2024 07:49:58 -0700
Subject: [PATCH 055/136] Fix: remove invalid form attribute (#3210)
---
src/components/widgets/widget/container_form.jsx | 6 +-----
1 file changed, 1 insertion(+), 5 deletions(-)
diff --git a/src/components/widgets/widget/container_form.jsx b/src/components/widgets/widget/container_form.jsx
index 3b2c02e2..68cbd64b 100644
--- a/src/components/widgets/widget/container_form.jsx
+++ b/src/components/widgets/widget/container_form.jsx
@@ -2,11 +2,7 @@ import { getAllClasses, getInnerBlock, getBottomBlock } from "./container";
export default function ContainerForm({ children = [], options, additionalClassNames = "", callback }) {
return (
-
From 6f07acab15c39bad4b7492faddfbf7e31fa1d5fd Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 1 Apr 2024 10:17:34 -0700
Subject: [PATCH 056/136] Chore(deps): Bump follow-redirects from 1.15.5 to
1.15.6 (#3211)
Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.15.5 to 1.15.6.
- [Release notes](https://github.com/follow-redirects/follow-redirects/releases)
- [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.15.5...v1.15.6)
---
updated-dependencies:
- dependency-name: follow-redirects
dependency-type: direct:production
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
package-lock.json | 8 ++++----
package.json | 2 +-
pnpm-lock.yaml | 8 ++++----
3 files changed, 9 insertions(+), 9 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index 49e57222..77de4d84 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -14,7 +14,7 @@
"classnames": "^2.5.1",
"compare-versions": "^6.1.0",
"dockerode": "^4.0.2",
- "follow-redirects": "^1.15.5",
+ "follow-redirects": "^1.15.6",
"gamedig": "^4.3.1",
"i18next": "^21.10.0",
"js-yaml": "^4.1.0",
@@ -3040,9 +3040,9 @@
"integrity": "sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw=="
},
"node_modules/follow-redirects": {
- "version": "1.15.5",
- "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz",
- "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==",
+ "version": "1.15.6",
+ "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz",
+ "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==",
"funding": [
{
"type": "individual",
diff --git a/package.json b/package.json
index 35d388a5..1b9ef162 100644
--- a/package.json
+++ b/package.json
@@ -16,7 +16,7 @@
"classnames": "^2.5.1",
"compare-versions": "^6.1.0",
"dockerode": "^4.0.2",
- "follow-redirects": "^1.15.5",
+ "follow-redirects": "^1.15.6",
"gamedig": "^4.3.1",
"i18next": "^21.10.0",
"js-yaml": "^4.1.0",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 08a5004a..837bfe0b 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -24,8 +24,8 @@ dependencies:
specifier: ^4.0.2
version: 4.0.2
follow-redirects:
- specifier: ^1.15.5
- version: 1.15.5
+ specifier: ^1.15.6
+ version: 1.15.6
gamedig:
specifier: ^4.3.1
version: 4.3.1
@@ -2045,8 +2045,8 @@ packages:
resolution: {integrity: sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==}
dev: false
- /follow-redirects@1.15.5:
- resolution: {integrity: sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==}
+ /follow-redirects@1.15.6:
+ resolution: {integrity: sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==}
engines: {node: '>=4.0'}
peerDependencies:
debug: '*'
From 0d7b77260f8a050292b345cd782df314a412e71c Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 1 Apr 2024 10:18:28 -0700
Subject: [PATCH 057/136] Chore(deps-dev): Bump postcss from 8.4.35 to 8.4.38
(#3212)
Bumps [postcss](https://github.com/postcss/postcss) from 8.4.35 to 8.4.38.
- [Release notes](https://github.com/postcss/postcss/releases)
- [Changelog](https://github.com/postcss/postcss/blob/main/CHANGELOG.md)
- [Commits](https://github.com/postcss/postcss/compare/8.4.35...8.4.38)
---
updated-dependencies:
- dependency-name: postcss
dependency-type: direct:development
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
package-lock.json | 16 ++++++++--------
package.json | 2 +-
pnpm-lock.yaml | 48 ++++++++++++++++++++++++++---------------------
3 files changed, 36 insertions(+), 30 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index 77de4d84..d86fea34 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -52,7 +52,7 @@
"eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-react": "^7.33.2",
"eslint-plugin-react-hooks": "^4.6.0",
- "postcss": "^8.4.35",
+ "postcss": "^8.4.38",
"prettier": "^3.2.5",
"tailwind-scrollbar": "^3.0.5",
"tailwindcss": "^3.4.1",
@@ -5229,9 +5229,9 @@
}
},
"node_modules/postcss": {
- "version": "8.4.35",
- "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.35.tgz",
- "integrity": "sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA==",
+ "version": "8.4.38",
+ "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz",
+ "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==",
"dev": true,
"funding": [
{
@@ -5250,7 +5250,7 @@
"dependencies": {
"nanoid": "^3.3.7",
"picocolors": "^1.0.0",
- "source-map-js": "^1.0.2"
+ "source-map-js": "^1.2.0"
},
"engines": {
"node": "^10 || ^12 || >=14"
@@ -6051,9 +6051,9 @@
}
},
"node_modules/source-map-js": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
- "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz",
+ "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==",
"engines": {
"node": ">=0.10.0"
}
diff --git a/package.json b/package.json
index 1b9ef162..40328c3a 100644
--- a/package.json
+++ b/package.json
@@ -54,7 +54,7 @@
"eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-react": "^7.33.2",
"eslint-plugin-react-hooks": "^4.6.0",
- "postcss": "^8.4.35",
+ "postcss": "^8.4.38",
"prettier": "^3.2.5",
"tailwind-scrollbar": "^3.0.5",
"tailwindcss": "^3.4.1",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 837bfe0b..bd16107c 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -110,7 +110,7 @@ devDependencies:
version: 0.5.7(tailwindcss@3.4.1)
autoprefixer:
specifier: ^10.4.17
- version: 10.4.17(postcss@8.4.35)
+ version: 10.4.17(postcss@8.4.38)
eslint:
specifier: ^8.57.0
version: 8.57.0
@@ -139,8 +139,8 @@ devDependencies:
specifier: ^4.6.0
version: 4.6.0(eslint@8.57.0)
postcss:
- specifier: ^8.4.35
- version: 8.4.35
+ specifier: ^8.4.38
+ version: 8.4.38
prettier:
specifier: ^3.2.5
version: 3.2.5
@@ -849,7 +849,7 @@ packages:
resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==}
dev: false
- /autoprefixer@10.4.17(postcss@8.4.35):
+ /autoprefixer@10.4.17(postcss@8.4.38):
resolution: {integrity: sha512-/cpVNRLSfhOtcGflT13P2794gVSgmPgTR+erw5ifnMLZb0UnSlkK4tquLmkd3BhA+nLo5tX8Cu0upUsGKvKbmg==}
engines: {node: ^10 || ^12 || >=14}
hasBin: true
@@ -861,7 +861,7 @@ packages:
fraction.js: 4.3.7
normalize-range: 0.1.2
picocolors: 1.0.0
- postcss: 8.4.35
+ postcss: 8.4.38
postcss-value-parser: 4.2.0
dev: true
@@ -3362,29 +3362,29 @@ packages:
engines: {node: '>= 6'}
dev: true
- /postcss-import@15.1.0(postcss@8.4.35):
+ /postcss-import@15.1.0(postcss@8.4.38):
resolution: {integrity: sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==}
engines: {node: '>=14.0.0'}
peerDependencies:
postcss: ^8.0.0
dependencies:
- postcss: 8.4.35
+ postcss: 8.4.38
postcss-value-parser: 4.2.0
read-cache: 1.0.0
resolve: 1.22.8
dev: true
- /postcss-js@4.0.1(postcss@8.4.35):
+ /postcss-js@4.0.1(postcss@8.4.38):
resolution: {integrity: sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==}
engines: {node: ^12 || ^14 || >= 16}
peerDependencies:
postcss: ^8.4.21
dependencies:
camelcase-css: 2.0.1
- postcss: 8.4.35
+ postcss: 8.4.38
dev: true
- /postcss-load-config@4.0.2(postcss@8.4.35):
+ /postcss-load-config@4.0.2(postcss@8.4.38):
resolution: {integrity: sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==}
engines: {node: '>= 14'}
peerDependencies:
@@ -3397,17 +3397,17 @@ packages:
optional: true
dependencies:
lilconfig: 3.0.0
- postcss: 8.4.35
+ postcss: 8.4.38
yaml: 2.3.4
dev: true
- /postcss-nested@6.0.1(postcss@8.4.35):
+ /postcss-nested@6.0.1(postcss@8.4.38):
resolution: {integrity: sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==}
engines: {node: '>=12.0'}
peerDependencies:
postcss: ^8.2.14
dependencies:
- postcss: 8.4.35
+ postcss: 8.4.38
postcss-selector-parser: 6.0.15
dev: true
@@ -3432,13 +3432,13 @@ packages:
source-map-js: 1.0.2
dev: false
- /postcss@8.4.35:
- resolution: {integrity: sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA==}
+ /postcss@8.4.38:
+ resolution: {integrity: sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==}
engines: {node: ^10 || ^12 || >=14}
dependencies:
nanoid: 3.3.7
picocolors: 1.0.0
- source-map-js: 1.0.2
+ source-map-js: 1.2.0
dev: true
/prelude-ls@1.2.1:
@@ -3928,6 +3928,12 @@ packages:
/source-map-js@1.0.2:
resolution: {integrity: sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==}
engines: {node: '>=0.10.0'}
+ dev: false
+
+ /source-map-js@1.2.0:
+ resolution: {integrity: sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==}
+ engines: {node: '>=0.10.0'}
+ dev: true
/split-ca@1.0.1:
resolution: {integrity: sha512-Q5thBSxp5t8WPTTJQS59LrGqOZqOsrhDGDVm8azCqIBjSBd7nd9o2PM+mDulQQkh8h//4U6hFZnc/mul8t5pWQ==}
@@ -4168,11 +4174,11 @@ packages:
normalize-path: 3.0.0
object-hash: 3.0.0
picocolors: 1.0.0
- postcss: 8.4.35
- postcss-import: 15.1.0(postcss@8.4.35)
- postcss-js: 4.0.1(postcss@8.4.35)
- postcss-load-config: 4.0.2(postcss@8.4.35)
- postcss-nested: 6.0.1(postcss@8.4.35)
+ postcss: 8.4.38
+ postcss-import: 15.1.0(postcss@8.4.38)
+ postcss-js: 4.0.1(postcss@8.4.38)
+ postcss-load-config: 4.0.2(postcss@8.4.38)
+ postcss-nested: 6.0.1(postcss@8.4.38)
postcss-selector-parser: 6.0.15
resolve: 1.22.8
sucrase: 3.35.0
From 2ebcb311e89c0b412ffa3a5629f46ce83c696c46 Mon Sep 17 00:00:00 2001
From: Luca Herrero
Date: Mon, 1 Apr 2024 23:17:56 +0200
Subject: [PATCH 058/136] Fix: homebridge widget with numeric username or
password (#3220)
---
src/widgets/homebridge/proxy.js | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/widgets/homebridge/proxy.js b/src/widgets/homebridge/proxy.js
index 2803415a..17dc8635 100644
--- a/src/widgets/homebridge/proxy.js
+++ b/src/widgets/homebridge/proxy.js
@@ -14,7 +14,7 @@ async function login(widget, service) {
const endpoint = "auth/login";
const api = widgets?.[widget.type]?.api;
const loginUrl = new URL(formatApiCall(api, { endpoint, ...widget }));
- const loginBody = { username: widget.username, password: widget.password };
+ const loginBody = { username: widget.username.toString(), password: widget.password.toString() };
const headers = { "Content-Type": "application/json" };
// eslint-disable-next-line no-unused-vars
const [status, contentType, data, responseHeaders] = await httpProxy(loginUrl, {
From cdfb5a11f771f82f320a9ea1b7be69e375d2ed2f Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 1 Apr 2024 14:18:07 -0700
Subject: [PATCH 059/136] Chore(deps): Bump recharts from 2.12.2 to 2.12.3
(#3215)
Bumps [recharts](https://github.com/recharts/recharts) from 2.12.2 to 2.12.3.
- [Release notes](https://github.com/recharts/recharts/releases)
- [Changelog](https://github.com/recharts/recharts/blob/3.x/CHANGELOG.md)
- [Commits](https://github.com/recharts/recharts/compare/v2.12.2...v2.12.3)
---
updated-dependencies:
- dependency-name: recharts
dependency-type: direct:production
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
package-lock.json | 8 ++++----
package.json | 2 +-
pnpm-lock.yaml | 8 ++++----
3 files changed, 9 insertions(+), 9 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index d86fea34..08bccb1c 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -31,7 +31,7 @@
"react-dom": "^18.2.0",
"react-i18next": "^11.18.6",
"react-icons": "^4.12.0",
- "recharts": "^2.12.2",
+ "recharts": "^2.12.3",
"rrule": "^2.8.1",
"swr": "^1.3.0",
"systeminformation": "^5.22.0",
@@ -5604,9 +5604,9 @@
}
},
"node_modules/recharts": {
- "version": "2.12.2",
- "resolved": "https://registry.npmjs.org/recharts/-/recharts-2.12.2.tgz",
- "integrity": "sha512-9bpxjXSF5g81YsKkTSlaX7mM4b6oYI1mIYck6YkUcWuL3tomADccI51/6thY4LmvhYuRTwpfrOvE80Zc3oBRfQ==",
+ "version": "2.12.3",
+ "resolved": "https://registry.npmjs.org/recharts/-/recharts-2.12.3.tgz",
+ "integrity": "sha512-vE/F7wTlokf5mtCqVDJlVKelCjliLSJ+DJxj79XlMREm7gpV7ljwbrwE3CfeaoDlOaLX+6iwHaVRn9587YkwIg==",
"dependencies": {
"clsx": "^2.0.0",
"eventemitter3": "^4.0.1",
diff --git a/package.json b/package.json
index 40328c3a..08f619f9 100644
--- a/package.json
+++ b/package.json
@@ -33,7 +33,7 @@
"react-dom": "^18.2.0",
"react-i18next": "^11.18.6",
"react-icons": "^4.12.0",
- "recharts": "^2.12.2",
+ "recharts": "^2.12.3",
"rrule": "^2.8.1",
"swr": "^1.3.0",
"systeminformation": "^5.22.0",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index bd16107c..65bc25d3 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -75,8 +75,8 @@ dependencies:
specifier: ^4.12.0
version: 4.12.0(react@18.2.0)
recharts:
- specifier: ^2.12.2
- version: 2.12.2(react-dom@18.2.0)(react@18.2.0)
+ specifier: ^2.12.3
+ version: 2.12.3(react-dom@18.2.0)(react@18.2.0)
rrule:
specifier: ^2.8.1
version: 2.8.1
@@ -3642,8 +3642,8 @@ packages:
decimal.js-light: 2.5.1
dev: false
- /recharts@2.12.2(react-dom@18.2.0)(react@18.2.0):
- resolution: {integrity: sha512-9bpxjXSF5g81YsKkTSlaX7mM4b6oYI1mIYck6YkUcWuL3tomADccI51/6thY4LmvhYuRTwpfrOvE80Zc3oBRfQ==}
+ /recharts@2.12.3(react-dom@18.2.0)(react@18.2.0):
+ resolution: {integrity: sha512-vE/F7wTlokf5mtCqVDJlVKelCjliLSJ+DJxj79XlMREm7gpV7ljwbrwE3CfeaoDlOaLX+6iwHaVRn9587YkwIg==}
engines: {node: '>=14'}
peerDependencies:
react: ^16.0.0 || ^17.0.0 || ^18.0.0
From 43bbb69d53ac2aab22cce28f747cebf9acd94c77 Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 1 Apr 2024 14:18:29 -0700
Subject: [PATCH 060/136] Chore(deps-dev): Bump eslint-plugin-react from 7.33.2
to 7.34.1 (#3213)
Bumps [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) from 7.33.2 to 7.34.1.
- [Release notes](https://github.com/jsx-eslint/eslint-plugin-react/releases)
- [Changelog](https://github.com/jsx-eslint/eslint-plugin-react/blob/v7.34.1/CHANGELOG.md)
- [Commits](https://github.com/jsx-eslint/eslint-plugin-react/compare/v7.33.2...v7.34.1)
---
updated-dependencies:
- dependency-name: eslint-plugin-react
dependency-type: direct:development
update-type: version-update:semver-minor
...
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
package-lock.json | 618 ++++++++++++++++++++++++++++++----------------
package.json | 2 +-
pnpm-lock.yaml | 469 +++++++++++++++++++++++++++++++++--
3 files changed, 843 insertions(+), 246 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index 08bccb1c..2a8a6a37 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -50,7 +50,7 @@
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-jsx-a11y": "^6.8.0",
"eslint-plugin-prettier": "^4.2.1",
- "eslint-plugin-react": "^7.33.2",
+ "eslint-plugin-react": "^7.34.1",
"eslint-plugin-react-hooks": "^4.6.0",
"postcss": "^8.4.38",
"prettier": "^3.2.5",
@@ -990,13 +990,16 @@
}
},
"node_modules/array-buffer-byte-length": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz",
- "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==",
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz",
+ "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "is-array-buffer": "^3.0.1"
+ "call-bind": "^1.0.5",
+ "is-array-buffer": "^3.0.4"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -1030,6 +1033,26 @@
"node": ">=8"
}
},
+ "node_modules/array.prototype.findlast": {
+ "version": "1.2.5",
+ "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz",
+ "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.7",
+ "define-properties": "^1.2.1",
+ "es-abstract": "^1.23.2",
+ "es-errors": "^1.3.0",
+ "es-object-atoms": "^1.0.0",
+ "es-shim-unscopables": "^1.0.2"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
"node_modules/array.prototype.findlastindex": {
"version": "1.2.3",
"resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.3.tgz",
@@ -1085,31 +1108,44 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/array.prototype.tosorted": {
+ "node_modules/array.prototype.toreversed": {
"version": "1.1.2",
- "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.2.tgz",
- "integrity": "sha512-HuQCHOlk1Weat5jzStICBCd83NxiIMwqDg/dHEsoefabn/hJRj5pVdWcPUSpRrwhwxZOsQassMpgN/xRYFBMIg==",
+ "resolved": "https://registry.npmjs.org/array.prototype.toreversed/-/array.prototype.toreversed-1.1.2.tgz",
+ "integrity": "sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA==",
"dev": true,
"dependencies": {
"call-bind": "^1.0.2",
"define-properties": "^1.2.0",
"es-abstract": "^1.22.1",
- "es-shim-unscopables": "^1.0.0",
- "get-intrinsic": "^1.2.1"
+ "es-shim-unscopables": "^1.0.0"
+ }
+ },
+ "node_modules/array.prototype.tosorted": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.3.tgz",
+ "integrity": "sha512-/DdH4TiTmOKzyQbp/eadcCVexiCb36xJg7HshYOYJnNZFDj33GEv0P7GxsynpShhq4OLYJzbGcBDkLsDt7MnNg==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.5",
+ "define-properties": "^1.2.1",
+ "es-abstract": "^1.22.3",
+ "es-errors": "^1.1.0",
+ "es-shim-unscopables": "^1.0.2"
}
},
"node_modules/arraybuffer.prototype.slice": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz",
- "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==",
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz",
+ "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==",
"dev": true,
"dependencies": {
- "array-buffer-byte-length": "^1.0.0",
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1",
- "get-intrinsic": "^1.2.1",
- "is-array-buffer": "^3.0.2",
+ "array-buffer-byte-length": "^1.0.1",
+ "call-bind": "^1.0.5",
+ "define-properties": "^1.2.1",
+ "es-abstract": "^1.22.3",
+ "es-errors": "^1.2.1",
+ "get-intrinsic": "^1.2.3",
+ "is-array-buffer": "^3.0.4",
"is-shared-array-buffer": "^1.0.2"
},
"engines": {
@@ -1159,15 +1195,6 @@
"resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz",
"integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q=="
},
- "node_modules/asynciterator.prototype": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/asynciterator.prototype/-/asynciterator.prototype-1.0.0.tgz",
- "integrity": "sha512-wwHYEIS0Q80f5mosx3L/dfG5t5rjEa9Ft51GTaNt862EnpyGHpgz2RkZvLPp1oF5TnAiTohkEKVEu8pQPJI7Vg==",
- "dev": true,
- "dependencies": {
- "has-symbols": "^1.0.3"
- }
- },
"node_modules/asynckit": {
"version": "0.4.0",
"resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
@@ -1211,10 +1238,13 @@
}
},
"node_modules/available-typed-arrays": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz",
- "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==",
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz",
+ "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==",
"dev": true,
+ "dependencies": {
+ "possible-typed-array-names": "^1.0.0"
+ },
"engines": {
"node": ">= 0.4"
},
@@ -1474,14 +1504,19 @@
}
},
"node_modules/call-bind": {
- "version": "1.0.5",
- "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz",
- "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==",
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz",
+ "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==",
"dev": true,
"dependencies": {
+ "es-define-property": "^1.0.0",
+ "es-errors": "^1.3.0",
"function-bind": "^1.1.2",
- "get-intrinsic": "^1.2.1",
- "set-function-length": "^1.1.1"
+ "get-intrinsic": "^1.2.4",
+ "set-function-length": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -1950,6 +1985,57 @@
"node": ">=0.10"
}
},
+ "node_modules/data-view-buffer": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz",
+ "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.6",
+ "es-errors": "^1.3.0",
+ "is-data-view": "^1.0.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/data-view-byte-length": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz",
+ "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.7",
+ "es-errors": "^1.3.0",
+ "is-data-view": "^1.0.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "node_modules/data-view-byte-offset": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz",
+ "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.6",
+ "es-errors": "^1.3.0",
+ "is-data-view": "^1.0.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
"node_modules/debug": {
"version": "4.3.4",
"resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz",
@@ -2011,17 +2097,20 @@
}
},
"node_modules/define-data-property": {
- "version": "1.1.1",
- "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz",
- "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==",
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz",
+ "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==",
"dev": true,
"dependencies": {
- "get-intrinsic": "^1.2.1",
- "gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.0"
+ "es-define-property": "^1.0.0",
+ "es-errors": "^1.3.0",
+ "gopd": "^1.0.1"
},
"engines": {
"node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/define-properties": {
@@ -2241,50 +2330,57 @@
}
},
"node_modules/es-abstract": {
- "version": "1.22.3",
- "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz",
- "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==",
+ "version": "1.23.3",
+ "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz",
+ "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==",
"dev": true,
"dependencies": {
- "array-buffer-byte-length": "^1.0.0",
- "arraybuffer.prototype.slice": "^1.0.2",
- "available-typed-arrays": "^1.0.5",
- "call-bind": "^1.0.5",
- "es-set-tostringtag": "^2.0.1",
+ "array-buffer-byte-length": "^1.0.1",
+ "arraybuffer.prototype.slice": "^1.0.3",
+ "available-typed-arrays": "^1.0.7",
+ "call-bind": "^1.0.7",
+ "data-view-buffer": "^1.0.1",
+ "data-view-byte-length": "^1.0.1",
+ "data-view-byte-offset": "^1.0.0",
+ "es-define-property": "^1.0.0",
+ "es-errors": "^1.3.0",
+ "es-object-atoms": "^1.0.0",
+ "es-set-tostringtag": "^2.0.3",
"es-to-primitive": "^1.2.1",
"function.prototype.name": "^1.1.6",
- "get-intrinsic": "^1.2.2",
- "get-symbol-description": "^1.0.0",
+ "get-intrinsic": "^1.2.4",
+ "get-symbol-description": "^1.0.2",
"globalthis": "^1.0.3",
"gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.0",
- "has-proto": "^1.0.1",
+ "has-property-descriptors": "^1.0.2",
+ "has-proto": "^1.0.3",
"has-symbols": "^1.0.3",
- "hasown": "^2.0.0",
- "internal-slot": "^1.0.5",
- "is-array-buffer": "^3.0.2",
+ "hasown": "^2.0.2",
+ "internal-slot": "^1.0.7",
+ "is-array-buffer": "^3.0.4",
"is-callable": "^1.2.7",
- "is-negative-zero": "^2.0.2",
+ "is-data-view": "^1.0.1",
+ "is-negative-zero": "^2.0.3",
"is-regex": "^1.1.4",
- "is-shared-array-buffer": "^1.0.2",
+ "is-shared-array-buffer": "^1.0.3",
"is-string": "^1.0.7",
- "is-typed-array": "^1.1.12",
+ "is-typed-array": "^1.1.13",
"is-weakref": "^1.0.2",
"object-inspect": "^1.13.1",
"object-keys": "^1.1.1",
- "object.assign": "^4.1.4",
- "regexp.prototype.flags": "^1.5.1",
- "safe-array-concat": "^1.0.1",
- "safe-regex-test": "^1.0.0",
- "string.prototype.trim": "^1.2.8",
- "string.prototype.trimend": "^1.0.7",
- "string.prototype.trimstart": "^1.0.7",
- "typed-array-buffer": "^1.0.0",
- "typed-array-byte-length": "^1.0.0",
- "typed-array-byte-offset": "^1.0.0",
- "typed-array-length": "^1.0.4",
+ "object.assign": "^4.1.5",
+ "regexp.prototype.flags": "^1.5.2",
+ "safe-array-concat": "^1.1.2",
+ "safe-regex-test": "^1.0.3",
+ "string.prototype.trim": "^1.2.9",
+ "string.prototype.trimend": "^1.0.8",
+ "string.prototype.trimstart": "^1.0.8",
+ "typed-array-buffer": "^1.0.2",
+ "typed-array-byte-length": "^1.0.1",
+ "typed-array-byte-offset": "^1.0.2",
+ "typed-array-length": "^1.0.6",
"unbox-primitive": "^1.0.2",
- "which-typed-array": "^1.1.13"
+ "which-typed-array": "^1.1.15"
},
"engines": {
"node": ">= 0.4"
@@ -2293,37 +2389,73 @@
"url": "https://github.com/sponsors/ljharb"
}
},
- "node_modules/es-iterator-helpers": {
- "version": "1.0.15",
- "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.15.tgz",
- "integrity": "sha512-GhoY8uYqd6iwUl2kgjTm4CZAf6oo5mHK7BPqx3rKgx893YSsy0LGHV6gfqqQvZt/8xM8xeOnfXBCfqclMKkJ5g==",
+ "node_modules/es-define-property": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz",
+ "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==",
"dev": true,
"dependencies": {
- "asynciterator.prototype": "^1.0.0",
- "call-bind": "^1.0.2",
+ "get-intrinsic": "^1.2.4"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ }
+ },
+ "node_modules/es-errors": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
+ "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ }
+ },
+ "node_modules/es-iterator-helpers": {
+ "version": "1.0.18",
+ "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.18.tgz",
+ "integrity": "sha512-scxAJaewsahbqTYrGKJihhViaM6DDZDDoucfvzNbK0pOren1g/daDQ3IAhzn+1G14rBG7w+i5N+qul60++zlKA==",
+ "dev": true,
+ "dependencies": {
+ "call-bind": "^1.0.7",
"define-properties": "^1.2.1",
- "es-abstract": "^1.22.1",
- "es-set-tostringtag": "^2.0.1",
- "function-bind": "^1.1.1",
- "get-intrinsic": "^1.2.1",
+ "es-abstract": "^1.23.0",
+ "es-errors": "^1.3.0",
+ "es-set-tostringtag": "^2.0.3",
+ "function-bind": "^1.1.2",
+ "get-intrinsic": "^1.2.4",
"globalthis": "^1.0.3",
- "has-property-descriptors": "^1.0.0",
- "has-proto": "^1.0.1",
+ "has-property-descriptors": "^1.0.2",
+ "has-proto": "^1.0.3",
"has-symbols": "^1.0.3",
- "internal-slot": "^1.0.5",
+ "internal-slot": "^1.0.7",
"iterator.prototype": "^1.1.2",
- "safe-array-concat": "^1.0.1"
+ "safe-array-concat": "^1.1.2"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ }
+ },
+ "node_modules/es-object-atoms": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz",
+ "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==",
+ "dev": true,
+ "dependencies": {
+ "es-errors": "^1.3.0"
+ },
+ "engines": {
+ "node": ">= 0.4"
}
},
"node_modules/es-set-tostringtag": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz",
- "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==",
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz",
+ "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==",
"dev": true,
"dependencies": {
- "get-intrinsic": "^1.2.2",
- "has-tostringtag": "^1.0.0",
- "hasown": "^2.0.0"
+ "get-intrinsic": "^1.2.4",
+ "has-tostringtag": "^1.0.2",
+ "hasown": "^2.0.1"
},
"engines": {
"node": ">= 0.4"
@@ -2699,27 +2831,29 @@
}
},
"node_modules/eslint-plugin-react": {
- "version": "7.33.2",
- "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.33.2.tgz",
- "integrity": "sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw==",
+ "version": "7.34.1",
+ "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.34.1.tgz",
+ "integrity": "sha512-N97CxlouPT1AHt8Jn0mhhN2RrADlUAsk1/atcT2KyA/l9Q/E6ll7OIGwNumFmWfZ9skV3XXccYS19h80rHtgkw==",
"dev": true,
"dependencies": {
- "array-includes": "^3.1.6",
- "array.prototype.flatmap": "^1.3.1",
- "array.prototype.tosorted": "^1.1.1",
+ "array-includes": "^3.1.7",
+ "array.prototype.findlast": "^1.2.4",
+ "array.prototype.flatmap": "^1.3.2",
+ "array.prototype.toreversed": "^1.1.2",
+ "array.prototype.tosorted": "^1.1.3",
"doctrine": "^2.1.0",
- "es-iterator-helpers": "^1.0.12",
+ "es-iterator-helpers": "^1.0.17",
"estraverse": "^5.3.0",
"jsx-ast-utils": "^2.4.1 || ^3.0.0",
"minimatch": "^3.1.2",
- "object.entries": "^1.1.6",
- "object.fromentries": "^2.0.6",
- "object.hasown": "^1.1.2",
- "object.values": "^1.1.6",
+ "object.entries": "^1.1.7",
+ "object.fromentries": "^2.0.7",
+ "object.hasown": "^1.1.3",
+ "object.values": "^1.1.7",
"prop-types": "^15.8.1",
- "resolve": "^2.0.0-next.4",
+ "resolve": "^2.0.0-next.5",
"semver": "^6.3.1",
- "string.prototype.matchall": "^4.0.8"
+ "string.prototype.matchall": "^4.0.10"
},
"engines": {
"node": ">=4"
@@ -3256,16 +3390,20 @@
}
},
"node_modules/get-intrinsic": {
- "version": "1.2.2",
- "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz",
- "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==",
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz",
+ "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==",
"dev": true,
"dependencies": {
+ "es-errors": "^1.3.0",
"function-bind": "^1.1.2",
"has-proto": "^1.0.1",
"has-symbols": "^1.0.3",
"hasown": "^2.0.0"
},
+ "engines": {
+ "node": ">= 0.4"
+ },
"funding": {
"url": "https://github.com/sponsors/ljharb"
}
@@ -3282,13 +3420,14 @@
}
},
"node_modules/get-symbol-description": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz",
- "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==",
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz",
+ "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "get-intrinsic": "^1.1.1"
+ "call-bind": "^1.0.5",
+ "es-errors": "^1.3.0",
+ "get-intrinsic": "^1.2.4"
},
"engines": {
"node": ">= 0.4"
@@ -3468,21 +3607,21 @@
}
},
"node_modules/has-property-descriptors": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz",
- "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==",
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz",
+ "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==",
"dev": true,
"dependencies": {
- "get-intrinsic": "^1.2.2"
+ "es-define-property": "^1.0.0"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/has-proto": {
- "version": "1.0.1",
- "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz",
- "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==",
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz",
+ "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==",
"dev": true,
"engines": {
"node": ">= 0.4"
@@ -3504,12 +3643,12 @@
}
},
"node_modules/has-tostringtag": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz",
- "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==",
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz",
+ "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==",
"dev": true,
"dependencies": {
- "has-symbols": "^1.0.2"
+ "has-symbols": "^1.0.3"
},
"engines": {
"node": ">= 0.4"
@@ -3519,9 +3658,9 @@
}
},
"node_modules/hasown": {
- "version": "2.0.0",
- "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz",
- "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==",
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz",
+ "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==",
"dependencies": {
"function-bind": "^1.1.2"
},
@@ -3728,12 +3867,12 @@
"integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
},
"node_modules/internal-slot": {
- "version": "1.0.6",
- "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz",
- "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==",
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz",
+ "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==",
"dev": true,
"dependencies": {
- "get-intrinsic": "^1.2.2",
+ "es-errors": "^1.3.0",
"hasown": "^2.0.0",
"side-channel": "^1.0.4"
},
@@ -3758,14 +3897,16 @@
}
},
"node_modules/is-array-buffer": {
- "version": "3.0.2",
- "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz",
- "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==",
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz",
+ "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==",
"dev": true,
"dependencies": {
"call-bind": "^1.0.2",
- "get-intrinsic": "^1.2.0",
- "is-typed-array": "^1.1.10"
+ "get-intrinsic": "^1.2.1"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -3854,6 +3995,21 @@
"url": "https://github.com/sponsors/ljharb"
}
},
+ "node_modules/is-data-view": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz",
+ "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==",
+ "dev": true,
+ "dependencies": {
+ "is-typed-array": "^1.1.13"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
"node_modules/is-date-object": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz",
@@ -3936,9 +4092,9 @@
}
},
"node_modules/is-negative-zero": {
- "version": "2.0.2",
- "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz",
- "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==",
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz",
+ "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==",
"dev": true,
"engines": {
"node": ">= 0.4"
@@ -4006,12 +4162,15 @@
}
},
"node_modules/is-shared-array-buffer": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz",
- "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==",
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz",
+ "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2"
+ "call-bind": "^1.0.7"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -4059,12 +4218,12 @@
}
},
"node_modules/is-typed-array": {
- "version": "1.1.12",
- "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz",
- "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==",
+ "version": "1.1.13",
+ "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz",
+ "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==",
"dev": true,
"dependencies": {
- "which-typed-array": "^1.1.11"
+ "which-typed-array": "^1.1.14"
},
"engines": {
"node": ">= 0.4"
@@ -5228,6 +5387,15 @@
"node": ">= 6"
}
},
+ "node_modules/possible-typed-array-names": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz",
+ "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==",
+ "dev": true,
+ "engines": {
+ "node": ">= 0.4"
+ }
+ },
"node_modules/postcss": {
"version": "8.4.38",
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz",
@@ -5670,14 +5838,15 @@
"integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw=="
},
"node_modules/regexp.prototype.flags": {
- "version": "1.5.1",
- "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz",
- "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==",
+ "version": "1.5.2",
+ "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz",
+ "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "set-function-name": "^2.0.0"
+ "call-bind": "^1.0.6",
+ "define-properties": "^1.2.1",
+ "es-errors": "^1.3.0",
+ "set-function-name": "^2.0.1"
},
"engines": {
"node": ">= 0.4"
@@ -5844,13 +6013,13 @@
}
},
"node_modules/safe-array-concat": {
- "version": "1.1.0",
- "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.0.tgz",
- "integrity": "sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==",
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz",
+ "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.5",
- "get-intrinsic": "^1.2.2",
+ "call-bind": "^1.0.7",
+ "get-intrinsic": "^1.2.4",
"has-symbols": "^1.0.3",
"isarray": "^2.0.5"
},
@@ -5881,13 +6050,13 @@
]
},
"node_modules/safe-regex-test": {
- "version": "1.0.2",
- "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.2.tgz",
- "integrity": "sha512-83S9w6eFq12BBIJYvjMux6/dkirb8+4zJRA9cxNBVb7Wq5fJBW+Xze48WqR8pxua7bDuAaaAxtVVd4Idjp1dBQ==",
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz",
+ "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.5",
- "get-intrinsic": "^1.2.2",
+ "call-bind": "^1.0.6",
+ "es-errors": "^1.3.0",
"is-regex": "^1.1.4"
},
"engines": {
@@ -5945,16 +6114,17 @@
}
},
"node_modules/set-function-length": {
- "version": "1.2.0",
- "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.0.tgz",
- "integrity": "sha512-4DBHDoyHlM1IRPGYcoxexgh67y4ueR53FKV1yyxwFMY7aCqcN/38M1+SwZ/qJQ8iLv7+ck385ot4CcisOAPT9w==",
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz",
+ "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==",
"dev": true,
"dependencies": {
- "define-data-property": "^1.1.1",
+ "define-data-property": "^1.1.4",
+ "es-errors": "^1.3.0",
"function-bind": "^1.1.2",
- "get-intrinsic": "^1.2.2",
+ "get-intrinsic": "^1.2.4",
"gopd": "^1.0.1",
- "has-property-descriptors": "^1.0.1"
+ "has-property-descriptors": "^1.0.2"
},
"engines": {
"node": ">= 0.4"
@@ -6263,14 +6433,15 @@
}
},
"node_modules/string.prototype.trim": {
- "version": "1.2.8",
- "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz",
- "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==",
+ "version": "1.2.9",
+ "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz",
+ "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
+ "call-bind": "^1.0.7",
+ "define-properties": "^1.2.1",
+ "es-abstract": "^1.23.0",
+ "es-object-atoms": "^1.0.0"
},
"engines": {
"node": ">= 0.4"
@@ -6280,28 +6451,31 @@
}
},
"node_modules/string.prototype.trimend": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz",
- "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==",
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz",
+ "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
+ "call-bind": "^1.0.7",
+ "define-properties": "^1.2.1",
+ "es-object-atoms": "^1.0.0"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/string.prototype.trimstart": {
- "version": "1.0.7",
- "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz",
- "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==",
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz",
+ "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "define-properties": "^1.2.0",
- "es-abstract": "^1.22.1"
+ "call-bind": "^1.0.7",
+ "define-properties": "^1.2.1",
+ "es-object-atoms": "^1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -6844,29 +7018,30 @@
}
},
"node_modules/typed-array-buffer": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz",
- "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==",
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz",
+ "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
- "get-intrinsic": "^1.2.1",
- "is-typed-array": "^1.1.10"
+ "call-bind": "^1.0.7",
+ "es-errors": "^1.3.0",
+ "is-typed-array": "^1.1.13"
},
"engines": {
"node": ">= 0.4"
}
},
"node_modules/typed-array-byte-length": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz",
- "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==",
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz",
+ "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
+ "call-bind": "^1.0.7",
"for-each": "^0.3.3",
- "has-proto": "^1.0.1",
- "is-typed-array": "^1.1.10"
+ "gopd": "^1.0.1",
+ "has-proto": "^1.0.3",
+ "is-typed-array": "^1.1.13"
},
"engines": {
"node": ">= 0.4"
@@ -6876,16 +7051,17 @@
}
},
"node_modules/typed-array-byte-offset": {
- "version": "1.0.0",
- "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz",
- "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==",
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz",
+ "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==",
"dev": true,
"dependencies": {
- "available-typed-arrays": "^1.0.5",
- "call-bind": "^1.0.2",
+ "available-typed-arrays": "^1.0.7",
+ "call-bind": "^1.0.7",
"for-each": "^0.3.3",
- "has-proto": "^1.0.1",
- "is-typed-array": "^1.1.10"
+ "gopd": "^1.0.1",
+ "has-proto": "^1.0.3",
+ "is-typed-array": "^1.1.13"
},
"engines": {
"node": ">= 0.4"
@@ -6895,14 +7071,20 @@
}
},
"node_modules/typed-array-length": {
- "version": "1.0.4",
- "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz",
- "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==",
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz",
+ "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==",
"dev": true,
"dependencies": {
- "call-bind": "^1.0.2",
+ "call-bind": "^1.0.7",
"for-each": "^0.3.3",
- "is-typed-array": "^1.1.9"
+ "gopd": "^1.0.1",
+ "has-proto": "^1.0.3",
+ "is-typed-array": "^1.1.13",
+ "possible-typed-array-names": "^1.0.0"
+ },
+ "engines": {
+ "node": ">= 0.4"
},
"funding": {
"url": "https://github.com/sponsors/ljharb"
@@ -7168,16 +7350,16 @@
}
},
"node_modules/which-typed-array": {
- "version": "1.1.13",
- "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz",
- "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==",
+ "version": "1.1.15",
+ "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz",
+ "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==",
"dev": true,
"dependencies": {
- "available-typed-arrays": "^1.0.5",
- "call-bind": "^1.0.4",
+ "available-typed-arrays": "^1.0.7",
+ "call-bind": "^1.0.7",
"for-each": "^0.3.3",
"gopd": "^1.0.1",
- "has-tostringtag": "^1.0.0"
+ "has-tostringtag": "^1.0.2"
},
"engines": {
"node": ">= 0.4"
diff --git a/package.json b/package.json
index 08f619f9..466a4cff 100644
--- a/package.json
+++ b/package.json
@@ -52,7 +52,7 @@
"eslint-plugin-import": "^2.29.1",
"eslint-plugin-jsx-a11y": "^6.8.0",
"eslint-plugin-prettier": "^4.2.1",
- "eslint-plugin-react": "^7.33.2",
+ "eslint-plugin-react": "^7.34.1",
"eslint-plugin-react-hooks": "^4.6.0",
"postcss": "^8.4.38",
"prettier": "^3.2.5",
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index 65bc25d3..d87dbdf4 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -116,7 +116,7 @@ devDependencies:
version: 8.57.0
eslint-config-airbnb:
specifier: ^19.0.4
- version: 19.0.4(eslint-plugin-import@2.29.1)(eslint-plugin-jsx-a11y@6.8.0)(eslint-plugin-react-hooks@4.6.0)(eslint-plugin-react@7.33.2)(eslint@8.57.0)
+ version: 19.0.4(eslint-plugin-import@2.29.1)(eslint-plugin-jsx-a11y@6.8.0)(eslint-plugin-react-hooks@4.6.0)(eslint-plugin-react@7.34.1)(eslint@8.57.0)
eslint-config-next:
specifier: ^12.3.4
version: 12.3.4(eslint@8.57.0)(typescript@4.9.5)
@@ -133,8 +133,8 @@ devDependencies:
specifier: ^4.2.1
version: 4.2.1(eslint-config-prettier@9.1.0)(eslint@8.57.0)(prettier@3.2.5)
eslint-plugin-react:
- specifier: ^7.33.2
- version: 7.33.2(eslint@8.57.0)
+ specifier: ^7.34.1
+ version: 7.34.1(eslint@8.57.0)
eslint-plugin-react-hooks:
specifier: ^4.6.0
version: 4.6.0(eslint@8.57.0)
@@ -744,6 +744,14 @@ packages:
is-array-buffer: 3.0.2
dev: true
+ /array-buffer-byte-length@1.0.1:
+ resolution: {integrity: sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ is-array-buffer: 3.0.4
+ dev: true
+
/array-includes@3.1.7:
resolution: {integrity: sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==}
engines: {node: '>= 0.4'}
@@ -760,6 +768,18 @@ packages:
engines: {node: '>=8'}
dev: true
+ /array.prototype.findlast@1.2.5:
+ resolution: {integrity: sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-abstract: 1.23.3
+ es-errors: 1.3.0
+ es-object-atoms: 1.0.0
+ es-shim-unscopables: 1.0.2
+ dev: true
+
/array.prototype.findlastindex@1.2.3:
resolution: {integrity: sha512-LzLoiOMAxvy+Gd3BAq3B7VeIgPdo+Q8hthvKtXybMvRV0jrXfJM/t8mw7nNlpEcVlVUnCnM2KSX4XU5HmpodOA==}
engines: {node: '>= 0.4'}
@@ -791,14 +811,23 @@ packages:
es-shim-unscopables: 1.0.2
dev: true
- /array.prototype.tosorted@1.1.2:
- resolution: {integrity: sha512-HuQCHOlk1Weat5jzStICBCd83NxiIMwqDg/dHEsoefabn/hJRj5pVdWcPUSpRrwhwxZOsQassMpgN/xRYFBMIg==}
+ /array.prototype.toreversed@1.1.2:
+ resolution: {integrity: sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA==}
dependencies:
call-bind: 1.0.5
define-properties: 1.2.1
es-abstract: 1.22.3
es-shim-unscopables: 1.0.2
- get-intrinsic: 1.2.2
+ dev: true
+
+ /array.prototype.tosorted@1.1.3:
+ resolution: {integrity: sha512-/DdH4TiTmOKzyQbp/eadcCVexiCb36xJg7HshYOYJnNZFDj33GEv0P7GxsynpShhq4OLYJzbGcBDkLsDt7MnNg==}
+ dependencies:
+ call-bind: 1.0.5
+ define-properties: 1.2.1
+ es-abstract: 1.22.3
+ es-errors: 1.3.0
+ es-shim-unscopables: 1.0.2
dev: true
/arraybuffer.prototype.slice@1.0.2:
@@ -814,6 +843,20 @@ packages:
is-shared-array-buffer: 1.0.2
dev: true
+ /arraybuffer.prototype.slice@1.0.3:
+ resolution: {integrity: sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ array-buffer-byte-length: 1.0.1
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-abstract: 1.23.3
+ es-errors: 1.3.0
+ get-intrinsic: 1.2.4
+ is-array-buffer: 3.0.4
+ is-shared-array-buffer: 1.0.3
+ dev: true
+
/asn1@0.2.6:
resolution: {integrity: sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ==}
dependencies:
@@ -870,6 +913,13 @@ packages:
engines: {node: '>= 0.4'}
dev: true
+ /available-typed-arrays@1.0.7:
+ resolution: {integrity: sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ possible-typed-array-names: 1.0.0
+ dev: true
+
/aws-sign2@0.7.0:
resolution: {integrity: sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==}
dev: false
@@ -1012,6 +1062,17 @@ packages:
set-function-length: 1.2.0
dev: true
+ /call-bind@1.0.7:
+ resolution: {integrity: sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ es-define-property: 1.0.0
+ es-errors: 1.3.0
+ function-bind: 1.1.2
+ get-intrinsic: 1.2.4
+ set-function-length: 1.2.2
+ dev: true
+
/callsites@3.1.0:
resolution: {integrity: sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==}
engines: {node: '>=6'}
@@ -1305,6 +1366,33 @@ packages:
assert-plus: 1.0.0
dev: false
+ /data-view-buffer@1.0.1:
+ resolution: {integrity: sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ is-data-view: 1.0.1
+ dev: true
+
+ /data-view-byte-length@1.0.1:
+ resolution: {integrity: sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ is-data-view: 1.0.1
+ dev: true
+
+ /data-view-byte-offset@1.0.0:
+ resolution: {integrity: sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ is-data-view: 1.0.1
+ dev: true
+
/debug@3.2.7:
resolution: {integrity: sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==}
peerDependencies:
@@ -1356,6 +1444,15 @@ packages:
has-property-descriptors: 1.0.1
dev: true
+ /define-data-property@1.1.4:
+ resolution: {integrity: sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ es-define-property: 1.0.0
+ es-errors: 1.3.0
+ gopd: 1.0.1
+ dev: true
+
/define-properties@1.2.1:
resolution: {integrity: sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==}
engines: {node: '>= 0.4'}
@@ -1549,6 +1646,70 @@ packages:
which-typed-array: 1.1.13
dev: true
+ /es-abstract@1.23.3:
+ resolution: {integrity: sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ array-buffer-byte-length: 1.0.1
+ arraybuffer.prototype.slice: 1.0.3
+ available-typed-arrays: 1.0.7
+ call-bind: 1.0.7
+ data-view-buffer: 1.0.1
+ data-view-byte-length: 1.0.1
+ data-view-byte-offset: 1.0.0
+ es-define-property: 1.0.0
+ es-errors: 1.3.0
+ es-object-atoms: 1.0.0
+ es-set-tostringtag: 2.0.3
+ es-to-primitive: 1.2.1
+ function.prototype.name: 1.1.6
+ get-intrinsic: 1.2.4
+ get-symbol-description: 1.0.2
+ globalthis: 1.0.3
+ gopd: 1.0.1
+ has-property-descriptors: 1.0.2
+ has-proto: 1.0.3
+ has-symbols: 1.0.3
+ hasown: 2.0.2
+ internal-slot: 1.0.7
+ is-array-buffer: 3.0.4
+ is-callable: 1.2.7
+ is-data-view: 1.0.1
+ is-negative-zero: 2.0.3
+ is-regex: 1.1.4
+ is-shared-array-buffer: 1.0.3
+ is-string: 1.0.7
+ is-typed-array: 1.1.13
+ is-weakref: 1.0.2
+ object-inspect: 1.13.1
+ object-keys: 1.1.1
+ object.assign: 4.1.5
+ regexp.prototype.flags: 1.5.2
+ safe-array-concat: 1.1.2
+ safe-regex-test: 1.0.3
+ string.prototype.trim: 1.2.9
+ string.prototype.trimend: 1.0.8
+ string.prototype.trimstart: 1.0.8
+ typed-array-buffer: 1.0.2
+ typed-array-byte-length: 1.0.1
+ typed-array-byte-offset: 1.0.2
+ typed-array-length: 1.0.6
+ unbox-primitive: 1.0.2
+ which-typed-array: 1.1.15
+ dev: true
+
+ /es-define-property@1.0.0:
+ resolution: {integrity: sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ get-intrinsic: 1.2.4
+ dev: true
+
+ /es-errors@1.3.0:
+ resolution: {integrity: sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==}
+ engines: {node: '>= 0.4'}
+ dev: true
+
/es-iterator-helpers@1.0.15:
resolution: {integrity: sha512-GhoY8uYqd6iwUl2kgjTm4CZAf6oo5mHK7BPqx3rKgx893YSsy0LGHV6gfqqQvZt/8xM8xeOnfXBCfqclMKkJ5g==}
dependencies:
@@ -1568,6 +1729,33 @@ packages:
safe-array-concat: 1.1.0
dev: true
+ /es-iterator-helpers@1.0.18:
+ resolution: {integrity: sha512-scxAJaewsahbqTYrGKJihhViaM6DDZDDoucfvzNbK0pOren1g/daDQ3IAhzn+1G14rBG7w+i5N+qul60++zlKA==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-abstract: 1.23.3
+ es-errors: 1.3.0
+ es-set-tostringtag: 2.0.3
+ function-bind: 1.1.2
+ get-intrinsic: 1.2.4
+ globalthis: 1.0.3
+ has-property-descriptors: 1.0.2
+ has-proto: 1.0.3
+ has-symbols: 1.0.3
+ internal-slot: 1.0.7
+ iterator.prototype: 1.1.2
+ safe-array-concat: 1.1.2
+ dev: true
+
+ /es-object-atoms@1.0.0:
+ resolution: {integrity: sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ es-errors: 1.3.0
+ dev: true
+
/es-set-tostringtag@2.0.2:
resolution: {integrity: sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==}
engines: {node: '>= 0.4'}
@@ -1577,6 +1765,15 @@ packages:
hasown: 2.0.0
dev: true
+ /es-set-tostringtag@2.0.3:
+ resolution: {integrity: sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ get-intrinsic: 1.2.4
+ has-tostringtag: 1.0.2
+ hasown: 2.0.2
+ dev: true
+
/es-shim-unscopables@1.0.2:
resolution: {integrity: sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==}
dependencies:
@@ -1617,7 +1814,7 @@ packages:
semver: 6.3.1
dev: true
- /eslint-config-airbnb@19.0.4(eslint-plugin-import@2.29.1)(eslint-plugin-jsx-a11y@6.8.0)(eslint-plugin-react-hooks@4.6.0)(eslint-plugin-react@7.33.2)(eslint@8.57.0):
+ /eslint-config-airbnb@19.0.4(eslint-plugin-import@2.29.1)(eslint-plugin-jsx-a11y@6.8.0)(eslint-plugin-react-hooks@4.6.0)(eslint-plugin-react@7.34.1)(eslint@8.57.0):
resolution: {integrity: sha512-T75QYQVQX57jiNgpF9r1KegMICE94VYwoFQyMGhrvc+lB8YF2E/M/PYDaQe1AJcWaEgqLE+ErXV1Og/+6Vyzew==}
engines: {node: ^10.12.0 || ^12.22.0 || ^14.17.0 || >=16.0.0}
peerDependencies:
@@ -1631,7 +1828,7 @@ packages:
eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1)(eslint@8.57.0)
eslint-plugin-import: 2.29.1(@typescript-eslint/parser@5.62.0)(eslint-import-resolver-typescript@2.7.1)(eslint@8.57.0)
eslint-plugin-jsx-a11y: 6.8.0(eslint@8.57.0)
- eslint-plugin-react: 7.33.2(eslint@8.57.0)
+ eslint-plugin-react: 7.34.1(eslint@8.57.0)
eslint-plugin-react-hooks: 4.6.0(eslint@8.57.0)
object.assign: 4.1.5
object.entries: 1.1.7
@@ -1654,7 +1851,7 @@ packages:
eslint-import-resolver-typescript: 2.7.1(eslint-plugin-import@2.29.1)(eslint@8.57.0)
eslint-plugin-import: 2.29.1(@typescript-eslint/parser@5.62.0)(eslint-import-resolver-typescript@2.7.1)(eslint@8.57.0)
eslint-plugin-jsx-a11y: 6.8.0(eslint@8.57.0)
- eslint-plugin-react: 7.33.2(eslint@8.57.0)
+ eslint-plugin-react: 7.34.1(eslint@8.57.0)
eslint-plugin-react-hooks: 4.6.0(eslint@8.57.0)
typescript: 4.9.5
transitivePeerDependencies:
@@ -1815,17 +2012,19 @@ packages:
eslint: 8.57.0
dev: true
- /eslint-plugin-react@7.33.2(eslint@8.57.0):
- resolution: {integrity: sha512-73QQMKALArI8/7xGLNI/3LylrEYrlKZSb5C9+q3OtOewTnMQi5cT+aE9E41sLCmli3I9PGGmD1yiZydyo4FEPw==}
+ /eslint-plugin-react@7.34.1(eslint@8.57.0):
+ resolution: {integrity: sha512-N97CxlouPT1AHt8Jn0mhhN2RrADlUAsk1/atcT2KyA/l9Q/E6ll7OIGwNumFmWfZ9skV3XXccYS19h80rHtgkw==}
engines: {node: '>=4'}
peerDependencies:
eslint: ^3 || ^4 || ^5 || ^6 || ^7 || ^8
dependencies:
array-includes: 3.1.7
+ array.prototype.findlast: 1.2.5
array.prototype.flatmap: 1.3.2
- array.prototype.tosorted: 1.1.2
+ array.prototype.toreversed: 1.1.2
+ array.prototype.tosorted: 1.1.3
doctrine: 2.1.0
- es-iterator-helpers: 1.0.15
+ es-iterator-helpers: 1.0.18
eslint: 8.57.0
estraverse: 5.3.0
jsx-ast-utils: 3.3.5
@@ -2120,9 +2319,9 @@ packages:
resolution: {integrity: sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==}
engines: {node: '>= 0.4'}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
define-properties: 1.2.1
- es-abstract: 1.22.3
+ es-abstract: 1.23.3
functions-have-names: 1.2.3
dev: true
@@ -2166,6 +2365,17 @@ packages:
hasown: 2.0.0
dev: true
+ /get-intrinsic@1.2.4:
+ resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ es-errors: 1.3.0
+ function-bind: 1.1.2
+ has-proto: 1.0.3
+ has-symbols: 1.0.3
+ hasown: 2.0.0
+ dev: true
+
/get-stream@6.0.1:
resolution: {integrity: sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==}
engines: {node: '>=10'}
@@ -2179,6 +2389,15 @@ packages:
get-intrinsic: 1.2.2
dev: true
+ /get-symbol-description@1.0.2:
+ resolution: {integrity: sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ get-intrinsic: 1.2.4
+ dev: true
+
/getpass@0.1.7:
resolution: {integrity: sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==}
dependencies:
@@ -2261,7 +2480,7 @@ packages:
/gopd@1.0.1:
resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==}
dependencies:
- get-intrinsic: 1.2.2
+ get-intrinsic: 1.2.4
dev: true
/got@12.6.1:
@@ -2314,11 +2533,22 @@ packages:
get-intrinsic: 1.2.2
dev: true
+ /has-property-descriptors@1.0.2:
+ resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==}
+ dependencies:
+ es-define-property: 1.0.0
+ dev: true
+
/has-proto@1.0.1:
resolution: {integrity: sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==}
engines: {node: '>= 0.4'}
dev: true
+ /has-proto@1.0.3:
+ resolution: {integrity: sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==}
+ engines: {node: '>= 0.4'}
+ dev: true
+
/has-symbols@1.0.3:
resolution: {integrity: sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==}
engines: {node: '>= 0.4'}
@@ -2331,12 +2561,26 @@ packages:
has-symbols: 1.0.3
dev: true
+ /has-tostringtag@1.0.2:
+ resolution: {integrity: sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ has-symbols: 1.0.3
+ dev: true
+
/hasown@2.0.0:
resolution: {integrity: sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==}
engines: {node: '>= 0.4'}
dependencies:
function-bind: 1.1.2
+ /hasown@2.0.2:
+ resolution: {integrity: sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ function-bind: 1.1.2
+ dev: true
+
/hoist-non-react-statics@3.3.2:
resolution: {integrity: sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==}
dependencies:
@@ -2463,6 +2707,15 @@ packages:
side-channel: 1.0.4
dev: true
+ /internal-slot@1.0.7:
+ resolution: {integrity: sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ es-errors: 1.3.0
+ hasown: 2.0.0
+ side-channel: 1.0.4
+ dev: true
+
/internmap@2.0.3:
resolution: {integrity: sha512-5Hh7Y1wQbvY5ooGgPbDaL5iYLAPzMTUrjMulskHLH6wnv/A+1q5rgEaiuqEjB+oxGXIVZs1FF+R/KPN3ZSQYYg==}
engines: {node: '>=12'}
@@ -2481,6 +2734,14 @@ packages:
is-typed-array: 1.1.12
dev: true
+ /is-array-buffer@3.0.4:
+ resolution: {integrity: sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ get-intrinsic: 1.2.4
+ dev: true
+
/is-arrayish@0.3.2:
resolution: {integrity: sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==}
dev: false
@@ -2509,7 +2770,7 @@ packages:
resolution: {integrity: sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==}
engines: {node: '>= 0.4'}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
has-tostringtag: 1.0.0
dev: true
@@ -2523,6 +2784,13 @@ packages:
dependencies:
hasown: 2.0.0
+ /is-data-view@1.0.1:
+ resolution: {integrity: sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ is-typed-array: 1.1.13
+ dev: true
+
/is-date-object@1.0.5:
resolution: {integrity: sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==}
engines: {node: '>= 0.4'}
@@ -2538,7 +2806,7 @@ packages:
/is-finalizationregistry@1.0.2:
resolution: {integrity: sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
dev: true
/is-fullwidth-code-point@3.0.0:
@@ -2569,6 +2837,11 @@ packages:
engines: {node: '>= 0.4'}
dev: true
+ /is-negative-zero@2.0.3:
+ resolution: {integrity: sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==}
+ engines: {node: '>= 0.4'}
+ dev: true
+
/is-number-object@1.0.7:
resolution: {integrity: sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==}
engines: {node: '>= 0.4'}
@@ -2590,7 +2863,7 @@ packages:
resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==}
engines: {node: '>= 0.4'}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
has-tostringtag: 1.0.0
dev: true
@@ -2604,6 +2877,13 @@ packages:
call-bind: 1.0.5
dev: true
+ /is-shared-array-buffer@1.0.3:
+ resolution: {integrity: sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ dev: true
+
/is-stream@2.0.1:
resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==}
engines: {node: '>=8'}
@@ -2630,6 +2910,13 @@ packages:
which-typed-array: 1.1.13
dev: true
+ /is-typed-array@1.1.13:
+ resolution: {integrity: sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ which-typed-array: 1.1.15
+ dev: true
+
/is-typedarray@1.0.0:
resolution: {integrity: sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==}
dev: false
@@ -2641,14 +2928,14 @@ packages:
/is-weakref@1.0.2:
resolution: {integrity: sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
dev: true
/is-weakset@2.0.2:
resolution: {integrity: sha512-t2yVvttHkQktwnNNmBQ98AhENLdPUTDTE21uPqAQ0ARwQfGeQKRVS0NNurH7bTf7RrvcVn1OOge45CnBeHCSmg==}
dependencies:
- call-bind: 1.0.5
- get-intrinsic: 1.2.2
+ call-bind: 1.0.7
+ get-intrinsic: 1.2.4
dev: true
/isarray@0.0.1:
@@ -2682,7 +2969,7 @@ packages:
resolution: {integrity: sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==}
dependencies:
define-properties: 1.2.1
- get-intrinsic: 1.2.2
+ get-intrinsic: 1.2.4
has-symbols: 1.0.3
reflect.getprototypeof: 1.0.4
set-function-name: 2.0.1
@@ -3362,6 +3649,11 @@ packages:
engines: {node: '>= 6'}
dev: true
+ /possible-typed-array-names@1.0.0:
+ resolution: {integrity: sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==}
+ engines: {node: '>= 0.4'}
+ dev: true
+
/postcss-import@15.1.0(postcss@8.4.38):
resolution: {integrity: sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==}
engines: {node: '>=14.0.0'}
@@ -3672,10 +3964,10 @@ packages:
resolution: {integrity: sha512-ECkTw8TmJwW60lOTR+ZkODISW6RQ8+2CL3COqtiJKLd6MmB45hN51HprHFziKLGkAuTGQhBb91V8cy+KHlaCjw==}
engines: {node: '>= 0.4'}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
define-properties: 1.2.1
- es-abstract: 1.22.3
- get-intrinsic: 1.2.2
+ es-abstract: 1.23.3
+ get-intrinsic: 1.2.4
globalthis: 1.0.3
which-builtin-type: 1.1.3
dev: true
@@ -3692,6 +3984,16 @@ packages:
set-function-name: 2.0.1
dev: true
+ /regexp.prototype.flags@1.5.2:
+ resolution: {integrity: sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-errors: 1.3.0
+ set-function-name: 2.0.1
+ dev: true
+
/request@2.88.2:
resolution: {integrity: sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==}
engines: {node: '>= 6'}
@@ -3793,6 +4095,16 @@ packages:
isarray: 2.0.5
dev: true
+ /safe-array-concat@1.1.2:
+ resolution: {integrity: sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==}
+ engines: {node: '>=0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ get-intrinsic: 1.2.4
+ has-symbols: 1.0.3
+ isarray: 2.0.5
+ dev: true
+
/safe-buffer@5.1.2:
resolution: {integrity: sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==}
dev: false
@@ -3810,6 +4122,15 @@ packages:
is-regex: 1.1.4
dev: true
+ /safe-regex-test@1.0.3:
+ resolution: {integrity: sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ is-regex: 1.1.4
+ dev: true
+
/safe-stable-stringify@2.4.3:
resolution: {integrity: sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==}
engines: {node: '>=10'}
@@ -3864,6 +4185,18 @@ packages:
has-property-descriptors: 1.0.1
dev: true
+ /set-function-length@1.2.2:
+ resolution: {integrity: sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ define-data-property: 1.1.4
+ es-errors: 1.3.0
+ function-bind: 1.1.2
+ get-intrinsic: 1.2.4
+ gopd: 1.0.1
+ has-property-descriptors: 1.0.2
+ dev: true
+
/set-function-name@2.0.1:
resolution: {integrity: sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==}
engines: {node: '>= 0.4'}
@@ -4029,6 +4362,16 @@ packages:
es-abstract: 1.22.3
dev: true
+ /string.prototype.trim@1.2.9:
+ resolution: {integrity: sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-abstract: 1.23.3
+ es-object-atoms: 1.0.0
+ dev: true
+
/string.prototype.trimend@1.0.7:
resolution: {integrity: sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==}
dependencies:
@@ -4037,6 +4380,14 @@ packages:
es-abstract: 1.22.3
dev: true
+ /string.prototype.trimend@1.0.8:
+ resolution: {integrity: sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-object-atoms: 1.0.0
+ dev: true
+
/string.prototype.trimstart@1.0.7:
resolution: {integrity: sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==}
dependencies:
@@ -4045,6 +4396,15 @@ packages:
es-abstract: 1.22.3
dev: true
+ /string.prototype.trimstart@1.0.8:
+ resolution: {integrity: sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ define-properties: 1.2.1
+ es-object-atoms: 1.0.0
+ dev: true
+
/string_decoder@0.10.31:
resolution: {integrity: sha512-ev2QzSzWPYmy9GuqfIVildA4OdcGLeFZQrq5ys6RtiuF+RQQiZWr8TZNyAcuVXyQRYfEO+MsoB/1BuQVhOJuoQ==}
dev: false
@@ -4356,6 +4716,15 @@ packages:
is-typed-array: 1.1.12
dev: true
+ /typed-array-buffer@1.0.2:
+ resolution: {integrity: sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ es-errors: 1.3.0
+ is-typed-array: 1.1.13
+ dev: true
+
/typed-array-byte-length@1.0.0:
resolution: {integrity: sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==}
engines: {node: '>= 0.4'}
@@ -4366,6 +4735,17 @@ packages:
is-typed-array: 1.1.12
dev: true
+ /typed-array-byte-length@1.0.1:
+ resolution: {integrity: sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ for-each: 0.3.3
+ gopd: 1.0.1
+ has-proto: 1.0.3
+ is-typed-array: 1.1.13
+ dev: true
+
/typed-array-byte-offset@1.0.0:
resolution: {integrity: sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==}
engines: {node: '>= 0.4'}
@@ -4377,6 +4757,18 @@ packages:
is-typed-array: 1.1.12
dev: true
+ /typed-array-byte-offset@1.0.2:
+ resolution: {integrity: sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ available-typed-arrays: 1.0.7
+ call-bind: 1.0.7
+ for-each: 0.3.3
+ gopd: 1.0.1
+ has-proto: 1.0.3
+ is-typed-array: 1.1.13
+ dev: true
+
/typed-array-length@1.0.4:
resolution: {integrity: sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==}
dependencies:
@@ -4385,6 +4777,18 @@ packages:
is-typed-array: 1.1.12
dev: true
+ /typed-array-length@1.0.6:
+ resolution: {integrity: sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ call-bind: 1.0.7
+ for-each: 0.3.3
+ gopd: 1.0.1
+ has-proto: 1.0.3
+ is-typed-array: 1.1.13
+ possible-typed-array-names: 1.0.0
+ dev: true
+
/typescript@4.9.5:
resolution: {integrity: sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==}
engines: {node: '>=4.2.0'}
@@ -4394,7 +4798,7 @@ packages:
/unbox-primitive@1.0.2:
resolution: {integrity: sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==}
dependencies:
- call-bind: 1.0.5
+ call-bind: 1.0.7
has-bigints: 1.0.2
has-symbols: 1.0.3
which-boxed-primitive: 1.0.2
@@ -4559,6 +4963,17 @@ packages:
has-tostringtag: 1.0.0
dev: true
+ /which-typed-array@1.1.15:
+ resolution: {integrity: sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==}
+ engines: {node: '>= 0.4'}
+ dependencies:
+ available-typed-arrays: 1.0.7
+ call-bind: 1.0.7
+ for-each: 0.3.3
+ gopd: 1.0.1
+ has-tostringtag: 1.0.2
+ dev: true
+
/which@2.0.2:
resolution: {integrity: sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==}
engines: {node: '>= 8'}
From 268d8efa0ebbfae1253ec3bdf5bbbcc22ed51046 Mon Sep 17 00:00:00 2001
From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com>
Date: Mon, 1 Apr 2024 14:18:39 -0700
Subject: [PATCH 061/136] Chore(deps-dev): Bump tailwindcss from 3.4.1 to 3.4.3
(#3214)
Bumps [tailwindcss](https://github.com/tailwindlabs/tailwindcss) from 3.4.1 to 3.4.3.
- [Release notes](https://github.com/tailwindlabs/tailwindcss/releases)
- [Changelog](https://github.com/tailwindlabs/tailwindcss/blob/v3.4.3/CHANGELOG.md)
- [Commits](https://github.com/tailwindlabs/tailwindcss/compare/v3.4.1...v3.4.3)
---
updated-dependencies:
- dependency-name: tailwindcss
dependency-type: direct:development
update-type: version-update:semver-patch
...
Signed-off-by: dependabot[bot]
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
---
package-lock.json | 10 +++++-----
package.json | 2 +-
pnpm-lock.yaml | 20 ++++++++++----------
3 files changed, 16 insertions(+), 16 deletions(-)
diff --git a/package-lock.json b/package-lock.json
index 2a8a6a37..46db054c 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -55,7 +55,7 @@
"postcss": "^8.4.38",
"prettier": "^3.2.5",
"tailwind-scrollbar": "^3.0.5",
- "tailwindcss": "^3.4.1",
+ "tailwindcss": "^3.4.3",
"typescript": "^4.9.5"
},
"optionalDependencies": {
@@ -6700,9 +6700,9 @@
}
},
"node_modules/tailwindcss": {
- "version": "3.4.1",
- "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.1.tgz",
- "integrity": "sha512-qAYmXRfk3ENzuPBakNK0SRrUDipP8NQnEY6772uDhflcQz5EhRdD7JNZxyrFHVQNCwULPBn6FNPp9brpO7ctcA==",
+ "version": "3.4.3",
+ "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.3.tgz",
+ "integrity": "sha512-U7sxQk/n397Bmx4JHbJx/iSOOv5G+II3f1kpLpY2QeUv5DcPdcTsYLlusZfq1NthHS1c1cZoyFmmkex1rzke0A==",
"dev": true,
"dependencies": {
"@alloc/quick-lru": "^5.2.0",
@@ -6713,7 +6713,7 @@
"fast-glob": "^3.3.0",
"glob-parent": "^6.0.2",
"is-glob": "^4.0.3",
- "jiti": "^1.19.1",
+ "jiti": "^1.21.0",
"lilconfig": "^2.1.0",
"micromatch": "^4.0.5",
"normalize-path": "^3.0.0",
diff --git a/package.json b/package.json
index 466a4cff..53d0e3bb 100644
--- a/package.json
+++ b/package.json
@@ -57,7 +57,7 @@
"postcss": "^8.4.38",
"prettier": "^3.2.5",
"tailwind-scrollbar": "^3.0.5",
- "tailwindcss": "^3.4.1",
+ "tailwindcss": "^3.4.3",
"typescript": "^4.9.5"
},
"optionalDependencies": {
diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml
index d87dbdf4..52ffe17f 100644
--- a/pnpm-lock.yaml
+++ b/pnpm-lock.yaml
@@ -107,7 +107,7 @@ optionalDependencies:
devDependencies:
'@tailwindcss/forms':
specifier: ^0.5.7
- version: 0.5.7(tailwindcss@3.4.1)
+ version: 0.5.7(tailwindcss@3.4.3)
autoprefixer:
specifier: ^10.4.17
version: 10.4.17(postcss@8.4.38)
@@ -146,10 +146,10 @@ devDependencies:
version: 3.2.5
tailwind-scrollbar:
specifier: ^3.0.5
- version: 3.0.5(tailwindcss@3.4.1)
+ version: 3.0.5(tailwindcss@3.4.3)
tailwindcss:
- specifier: ^3.4.1
- version: 3.4.1
+ specifier: ^3.4.3
+ version: 3.4.3
typescript:
specifier: ^4.9.5
version: 4.9.5
@@ -502,13 +502,13 @@ packages:
defer-to-connect: 2.0.1
dev: false
- /@tailwindcss/forms@0.5.7(tailwindcss@3.4.1):
+ /@tailwindcss/forms@0.5.7(tailwindcss@3.4.3):
resolution: {integrity: sha512-QE7X69iQI+ZXwldE+rzasvbJiyV/ju1FGHH0Qn2W3FKbuYtqp8LKcy6iSw79fVUT5/Vvf+0XgLCeYVG+UV6hOw==}
peerDependencies:
tailwindcss: '>=3.0.0 || >= 3.0.0-alpha.1'
dependencies:
mini-svg-data-uri: 1.4.4
- tailwindcss: 3.4.1
+ tailwindcss: 3.4.3
dev: true
/@tanstack/react-virtual@3.0.2(react-dom@18.2.0)(react@18.2.0):
@@ -4506,17 +4506,17 @@ packages:
hasBin: true
dev: false
- /tailwind-scrollbar@3.0.5(tailwindcss@3.4.1):
+ /tailwind-scrollbar@3.0.5(tailwindcss@3.4.3):
resolution: {integrity: sha512-0ZwxTivevqq9BY9fRP9zDjHl7Tu+J5giBGbln+0O1R/7nHtBUKnjQcA1aTIhK7Oyjp6Uc/Dj6/dn8Dq58k5Uww==}
engines: {node: '>=12.13.0'}
peerDependencies:
tailwindcss: 3.x
dependencies:
- tailwindcss: 3.4.1
+ tailwindcss: 3.4.3
dev: true
- /tailwindcss@3.4.1:
- resolution: {integrity: sha512-qAYmXRfk3ENzuPBakNK0SRrUDipP8NQnEY6772uDhflcQz5EhRdD7JNZxyrFHVQNCwULPBn6FNPp9brpO7ctcA==}
+ /tailwindcss@3.4.3:
+ resolution: {integrity: sha512-U7sxQk/n397Bmx4JHbJx/iSOOv5G+II3f1kpLpY2QeUv5DcPdcTsYLlusZfq1NthHS1c1cZoyFmmkex1rzke0A==}
engines: {node: '>=14.0.0'}
hasBin: true
dependencies:
From 4e69ea6088839c19a7242a4d05d97ab207927ced Mon Sep 17 00:00:00 2001
From: rgon10 <3789272+rgon10@users.noreply.github.com>
Date: Mon, 1 Apr 2024 17:32:39 -0400
Subject: [PATCH 062/136] Fix: TrueNAS Core support for pool stats (#3206)
---------
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
---
docs/widgets/services/truenas.md | 3 +++
src/utils/config/service-helpers.js | 2 ++
src/widgets/truenas/component.jsx | 10 +++++++++-
src/widgets/truenas/pool.jsx | 14 ++++++++++++--
src/widgets/truenas/widget.js | 1 +
5 files changed, 27 insertions(+), 3 deletions(-)
diff --git a/docs/widgets/services/truenas.md b/docs/widgets/services/truenas.md
index 24350490..97bba3be 100644
--- a/docs/widgets/services/truenas.md
+++ b/docs/widgets/services/truenas.md
@@ -11,6 +11,8 @@ To create an API Key, follow [the official TrueNAS documentation](https://www.tr
A detailed pool listing is disabled by default, but can be enabled with the `enablePools` option.
+To use the `enablePools` option with TrueNAS Core, the `nasType` parameter is required.
+
```yaml
widget:
type: truenas
@@ -19,4 +21,5 @@ widget:
password: pass # not required if using api key
key: yourtruenasapikey # not required if using username / password
enablePools: true # optional, defaults to false
+ nasType: scale # defaults to scale, must be set to 'core' if using enablePools with TrueNAS Core
```
diff --git a/src/utils/config/service-helpers.js b/src/utils/config/service-helpers.js
index bea28278..d6552253 100644
--- a/src/utils/config/service-helpers.js
+++ b/src/utils/config/service-helpers.js
@@ -450,6 +450,7 @@ export function cleanServiceGroups(groups) {
// truenas
enablePools,
+ nasType,
// unifi
site,
@@ -522,6 +523,7 @@ export function cleanServiceGroups(groups) {
}
if (type === "truenas") {
if (enablePools !== undefined) cleanedService.widget.enablePools = JSON.parse(enablePools);
+ if (nasType !== undefined) cleanedService.widget.nasType = nasType;
}
if (["diskstation", "qnap"].includes(type)) {
if (volume) cleanedService.widget.volume = volume;
diff --git a/src/widgets/truenas/component.jsx b/src/widgets/truenas/component.jsx
index 872d8c64..10d45bf6 100644
--- a/src/widgets/truenas/component.jsx
+++ b/src/widgets/truenas/component.jsx
@@ -40,7 +40,15 @@ export default function Component({ service }) {
{enablePools &&
poolsData.map((pool) => (
-
+
))}
>
);
diff --git a/src/widgets/truenas/pool.jsx b/src/widgets/truenas/pool.jsx
index 8e9d0465..b92ecb68 100644
--- a/src/widgets/truenas/pool.jsx
+++ b/src/widgets/truenas/pool.jsx
@@ -1,8 +1,18 @@
import classNames from "classnames";
import prettyBytes from "pretty-bytes";
-export default function Pool({ name, free, allocated, healthy }) {
- const total = free + allocated;
+export default function Pool({ name, free, allocated, healthy, data, nasType }) {
+ let total = 0;
+ if (nasType === "scale") {
+ total = free + allocated;
+ } else {
+ allocated = 0; // eslint-disable-line no-param-reassign
+ for (let i = 0; i < data.length; i += 1) {
+ total += data[i].stats.size;
+ allocated += data[i].stats.allocated; // eslint-disable-line no-param-reassign
+ }
+ }
+
const usedPercent = Math.round((allocated / total) * 100);
const statusColor = healthy ? "bg-green-500" : "bg-yellow-500";
diff --git a/src/widgets/truenas/widget.js b/src/widgets/truenas/widget.js
index 7435b6e1..5f8a38df 100644
--- a/src/widgets/truenas/widget.js
+++ b/src/widgets/truenas/widget.js
@@ -25,6 +25,7 @@ const widget = {
healthy: entry.healthy,
allocated: entry.allocated,
free: entry.free,
+ data: entry.topology.data,
})),
},
},
From 60db01cc57b99c6d5d35b478e9a70fd4d883d0d9 Mon Sep 17 00:00:00 2001
From: XavierDupuis
Date: Tue, 2 Apr 2024 18:42:34 -0400
Subject: [PATCH 063/136] Documentation: fix allowed fields uniformity (#3224)
---
docs/widgets/services/azuredevops.md | 4 ++--
docs/widgets/services/crowdsec.md | 2 +-
docs/widgets/services/gitea.md | 2 +-
docs/widgets/services/peanut.md | 2 +-
docs/widgets/services/prometheus.md | 2 +-
docs/widgets/services/pterodactyl.md | 2 +-
6 files changed, 7 insertions(+), 7 deletions(-)
diff --git a/docs/widgets/services/azuredevops.md b/docs/widgets/services/azuredevops.md
index 218007fe..78846115 100644
--- a/docs/widgets/services/azuredevops.md
+++ b/docs/widgets/services/azuredevops.md
@@ -7,10 +7,10 @@ Learn more about [Azure DevOps](https://azure.microsoft.com/en-us/products/devop
This widget has 2 functions:
-1. Pipelines: checks if the relevant pipeline is running or not, and if not, reports the last status.\
+1. Pipelines: checks if the relevant pipeline is running or not, and if not, reports the last status.
Allowed fields: `["result", "status"]`.
-2. Pull Requests: returns the amount of open PRs, the amount of the PRs you have open, and how many PRs that you open are marked as 'Approved' by at least 1 person and not yet completed.\
+2. Pull Requests: returns the amount of open PRs, the amount of the PRs you have open, and how many PRs that you open are marked as 'Approved' by at least 1 person and not yet completed.
Allowed fields: `["totalPrs", "myPrs", "approved"]`.
You will need to generate a personal access token for an existing user, see the [azure documentation](https://learn.microsoft.com/en-us/azure/devops/organizations/accounts/use-personal-access-tokens-to-authenticate?view=azure-devops&tabs=Windows#create-a-pat)
diff --git a/docs/widgets/services/crowdsec.md b/docs/widgets/services/crowdsec.md
index 608367df..76b8efaa 100644
--- a/docs/widgets/services/crowdsec.md
+++ b/docs/widgets/services/crowdsec.md
@@ -8,7 +8,7 @@ Learn more about [Crowdsec](https://crowdsec.net).
See the [crowdsec docs](https://docs.crowdsec.net/docs/local_api/intro/#machines) for information about registering a machine,
in most instances you can use the default credentials (`/etc/crowdsec/local_api_credentials.yaml`).
-Allowed fields: ["alerts", "bans"]
+Allowed fields: `["alerts", "bans"]`.
```yaml
widget:
diff --git a/docs/widgets/services/gitea.md b/docs/widgets/services/gitea.md
index da695a9a..140c4ee7 100644
--- a/docs/widgets/services/gitea.md
+++ b/docs/widgets/services/gitea.md
@@ -7,7 +7,7 @@ Learn more about [Gitea](https://gitea.com).
API token requires `notifications`, `repository` and `issue` permissions. See the [gitea documentation](https://docs.gitea.com/development/api-usage#generating-and-listing-api-tokens) for details on generating tokens.
-Allowed fields: ["notifications", "issues", "pulls"]
+Allowed fields: `["notifications", "issues", "pulls"]`.
```yaml
widget:
diff --git a/docs/widgets/services/peanut.md b/docs/widgets/services/peanut.md
index 63d75bbf..eca349b9 100644
--- a/docs/widgets/services/peanut.md
+++ b/docs/widgets/services/peanut.md
@@ -9,7 +9,7 @@ This widget adds support for [Network UPS Tools](https://networkupstools.org/) v
The default ups name is `ups`. To configure more than one ups, you must create multiple peanut services.
-Allowed fields: `["battery_charge", "ups_load", "ups_status"]`
+Allowed fields: `["battery_charge", "ups_load", "ups_status"]`.
!!! note
diff --git a/docs/widgets/services/prometheus.md b/docs/widgets/services/prometheus.md
index 02560c91..beb04b5e 100644
--- a/docs/widgets/services/prometheus.md
+++ b/docs/widgets/services/prometheus.md
@@ -5,7 +5,7 @@ description: Prometheus Widget Configuration
Learn more about [Prometheus](https://github.com/prometheus/prometheus).
-Allowed fields: `["targets_up", "targets_down", "targets_total"]`
+Allowed fields: `["targets_up", "targets_down", "targets_total"]`.
```yaml
widget:
diff --git a/docs/widgets/services/pterodactyl.md b/docs/widgets/services/pterodactyl.md
index 76e0f6ce..abf5899b 100644
--- a/docs/widgets/services/pterodactyl.md
+++ b/docs/widgets/services/pterodactyl.md
@@ -5,7 +5,7 @@ description: Pterodactyl Widget Configuration
Learn more about [Pterodactyl](https://github.com/pterodactyl).
-Allowed fields: `["nodes", "servers"]`
+Allowed fields: `["nodes", "servers"]`.
```yaml
widget:
From 9904c2db2fd8fbc42be89d171564d02f6101f646 Mon Sep 17 00:00:00 2001
From: mrmorganmurphy <22598031+mrmorganmurphy@users.noreply.github.com>
Date: Wed, 3 Apr 2024 10:03:12 -0700
Subject: [PATCH 064/136] Documentation: update diskstation instructions
(#3230)
---
docs/widgets/services/diskstation.md | 13 +++++++++----
1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/docs/widgets/services/diskstation.md b/docs/widgets/services/diskstation.md
index 36010bfa..55e28355 100644
--- a/docs/widgets/services/diskstation.md
+++ b/docs/widgets/services/diskstation.md
@@ -11,22 +11,27 @@ An optional 'volume' parameter can be supplied to specify which volume's free sp
Allowed fields: `["uptime", "volumeAvailable", "resources.cpu", "resources.mem"]`.
-To access these system metrics you need to connect to the DiskStation with an account that is a member of the default `Administrators` group. That is because these metrics are requested from the API's `SYNO.Core.System` part that is only available to admin users. In order to keep the security impact as small as possible we can set the account in DSM up to limit the user's permissions inside the Synology system. In DSM 7.x, for instance, follow these steps:
+To access these system metrics you need to connect to the DiskStation (`DSM`) with an account that is a member of the default `Administrators` group. That is because these metrics are requested from the API's `SYNO.Core.System` part that is only available to admin users. In order to keep the security impact as small as possible we can set the account in DSM up to limit the user's permissions inside the Synology system. In DSM 7.x, for instance, follow these steps:
1. Create a new user, i.e. `remote_stats`.
2. Set up a strong password for the new user
3. Under the `User Groups` tab of the user config dialogue check the box for `Administrators`.
4. On the `Permissions` tab check the top box for `No Access`, effectively prohibiting the user from accessing anything in the shared folders.
5. Under `Applications` check the box next to `Deny` in the header to explicitly prohibit login to all applications.
-6. Now _only_ allow login to the `Download Station` application, either by
+6. Now _only_ allow login to the `DSM` application, either by
- unchecking `Deny` in the respective row, or (if inheriting permission doesn't work because of other group settings)
- checking `Allow` for this app, or
- checking `By IP` for this app to limit the source of login attempts to one or more IP addresses/subnets.
-7. When the `Preview` column shows `Allow` in the `Download Station` row, click `Save`.
+7. When the `Preview` column shows `Allow` in the `DSM` row, click `Save`.
Now configure the widget with the correct login information and test it.
-If you encounter issues during testing, make sure to uncheck the option for automatic blocking due to invalid logins under `Control Panel > Security > Protection`. If desired, this setting can be reactivated once the login is established working.
+If you encounter issues during testing:
+
+1. Make sure to uncheck the option for automatic blocking due to invalid logins under `Control Panel > Security > Protection`.
+ - If desired, this setting can be reactivated once the login is established working.
+2. Login to your Synology DSM with the newly created account and accept terms and conditions.
+3. Reattempt
```yaml
widget:
From d49a06efd983c36b37af941ec1574048d0fee10f Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Sat, 6 Apr 2024 17:35:12 -0700
Subject: [PATCH 065/136] Fix: rename pialert to netalertx (#3253)
---
docs/widgets/services/netalertx.md | 16 +++++++++
docs/widgets/services/pialert.md | 16 ---------
public/locales/en/common.json | 2 +-
src/widgets/components.js | 3 +-
src/widgets/netalertx/component.jsx | 37 ++++++++++++++++++++
src/widgets/{pialert => netalertx}/widget.js | 0
src/widgets/pialert/component.jsx | 37 --------------------
src/widgets/widgets.js | 5 +--
8 files changed, 59 insertions(+), 57 deletions(-)
create mode 100644 docs/widgets/services/netalertx.md
delete mode 100644 docs/widgets/services/pialert.md
create mode 100644 src/widgets/netalertx/component.jsx
rename src/widgets/{pialert => netalertx}/widget.js (100%)
delete mode 100644 src/widgets/pialert/component.jsx
diff --git a/docs/widgets/services/netalertx.md b/docs/widgets/services/netalertx.md
new file mode 100644
index 00000000..4579d74c
--- /dev/null
+++ b/docs/widgets/services/netalertx.md
@@ -0,0 +1,16 @@
+---
+title: NetAlertX
+description: NetAlertX (formerly PiAlert) Widget Configuration
+---
+
+Learn more about [NetAlertX](https://github.com/jokob-sk/NetAlertX).
+
+_Note that the project was renamed from PiAlert to NetAlertX._
+
+Allowed fields: `["total", "connected", "new_devices", "down_alerts"]`.
+
+```yaml
+widget:
+ type: netalertx
+ url: http://ip:port
+```
diff --git a/docs/widgets/services/pialert.md b/docs/widgets/services/pialert.md
deleted file mode 100644
index ab8fb1e9..00000000
--- a/docs/widgets/services/pialert.md
+++ /dev/null
@@ -1,16 +0,0 @@
----
-title: PiAlert
-description: PiAlert Widget Configuration
----
-
-Learn more about [PiAlert](https://github.com/jokob-sk/Pi.Alert).
-
-Note that [pucherot/PiAlert](https://github.com/pucherot/Pi.Alert) has been abandoned and might not work properly.
-
-Allowed fields: `["total", "connected", "new_devices", "down_alerts"]`.
-
-```yaml
-widget:
- type: pialert
- url: http://ip:port
-```
diff --git a/public/locales/en/common.json b/public/locales/en/common.json
index 98daae9e..3ac3ed0d 100644
--- a/public/locales/en/common.json
+++ b/public/locales/en/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
diff --git a/src/widgets/components.js b/src/widgets/components.js
index 8c85bd77..500fe0ce 100644
--- a/src/widgets/components.js
+++ b/src/widgets/components.js
@@ -63,6 +63,7 @@ const components = {
moonraker: dynamic(() => import("./moonraker/component")),
mylar: dynamic(() => import("./mylar/component")),
navidrome: dynamic(() => import("./navidrome/component")),
+ netalertx: dynamic(() => import("./netalertx/component")),
netdata: dynamic(() => import("./netdata/component")),
nextcloud: dynamic(() => import("./nextcloud/component")),
nextdns: dynamic(() => import("./nextdns/component")),
@@ -80,7 +81,7 @@ const components = {
pfsense: dynamic(() => import("./pfsense/component")),
photoprism: dynamic(() => import("./photoprism/component")),
proxmoxbackupserver: dynamic(() => import("./proxmoxbackupserver/component")),
- pialert: dynamic(() => import("./pialert/component")),
+ pialert: dynamic(() => import("./netalertx/component")),
pihole: dynamic(() => import("./pihole/component")),
plantit: dynamic(() => import("./plantit/component")),
plex: dynamic(() => import("./plex/component")),
diff --git a/src/widgets/netalertx/component.jsx b/src/widgets/netalertx/component.jsx
new file mode 100644
index 00000000..5172121e
--- /dev/null
+++ b/src/widgets/netalertx/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: netalertxData, error: netalertxError } = useWidgetAPI(widget, "data");
+
+ if (netalertxError) {
+ return ;
+ }
+
+ if (!netalertxData) {
+ return (
+
+
+
+
+
+
+ );
+ }
+
+ return (
+
+
+
+
+
+
+ );
+}
diff --git a/src/widgets/pialert/widget.js b/src/widgets/netalertx/widget.js
similarity index 100%
rename from src/widgets/pialert/widget.js
rename to src/widgets/netalertx/widget.js
diff --git a/src/widgets/pialert/component.jsx b/src/widgets/pialert/component.jsx
deleted file mode 100644
index 49bef897..00000000
--- a/src/widgets/pialert/component.jsx
+++ /dev/null
@@ -1,37 +0,0 @@
-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: pialertData, error: pialertError } = useWidgetAPI(widget, "data");
-
- if (pialertError) {
- return ;
- }
-
- if (!pialertData) {
- return (
-
-
-
-
-
-
- );
- }
-
- return (
-
-
-
-
-
-
- );
-}
diff --git a/src/widgets/widgets.js b/src/widgets/widgets.js
index 6e02d932..7ed98bfb 100644
--- a/src/widgets/widgets.js
+++ b/src/widgets/widgets.js
@@ -55,6 +55,7 @@ import mjpeg from "./mjpeg/widget";
import moonraker from "./moonraker/widget";
import mylar from "./mylar/widget";
import navidrome from "./navidrome/widget";
+import netalertx from "./netalertx/widget";
import netdata from "./netdata/widget";
import nextcloud from "./nextcloud/widget";
import nextdns from "./nextdns/widget";
@@ -73,7 +74,6 @@ import peanut from "./peanut/widget";
import pfsense from "./pfsense/widget";
import photoprism from "./photoprism/widget";
import proxmoxbackupserver from "./proxmoxbackupserver/widget";
-import pialert from "./pialert/widget";
import pihole from "./pihole/widget";
import plantit from "./plantit/widget";
import plex from "./plex/widget";
@@ -171,6 +171,7 @@ const widgets = {
moonraker,
mylar,
navidrome,
+ netalertx,
netdata,
nextcloud,
nextdns,
@@ -189,7 +190,7 @@ const widgets = {
pfsense,
photoprism,
proxmoxbackupserver,
- pialert,
+ pialert: netalertx,
pihole,
plantit,
plex,
From f82a122e26ce843075269ae380dd71b9af516423 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Sat, 6 Apr 2024 20:00:16 -0700
Subject: [PATCH 066/136] Fix site monitor with error
---
src/components/services/site-monitor.jsx | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/components/services/site-monitor.jsx b/src/components/services/site-monitor.jsx
index 4e70c80a..3d5ef79e 100644
--- a/src/components/services/site-monitor.jsx
+++ b/src/components/services/site-monitor.jsx
@@ -12,7 +12,7 @@ export default function SiteMonitor({ group, service, style }) {
let statusTitle = t("siteMonitor.http_status");
let statusText = "";
- if (error) {
+ if (error || (data && data.error)) {
colorClass = "text-rose-500";
statusText = t("siteMonitor.error");
statusTitle += ` ${t("siteMonitor.error")}`;
From 4239e8fe97ef064ed5ea2fd89cd65106032f73f7 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Mon, 8 Apr 2024 07:58:41 -0700
Subject: [PATCH 067/136] Update contributing / development guidelines
---
CONTRIBUTING.md | 6 +++++-
docs/more/development.md | 5 +++++
2 files changed, 10 insertions(+), 1 deletion(-)
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 48f2818d..d3b07697 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -48,11 +48,15 @@ Please see information in the docs regarding [code formatting with pre-commit ho
By contributing, you agree that your contributions will be licensed under its GNU General Public License.
+## Use of AI for pull requests
+
+In general, homepage does not accept "AI-generated" PRs. If you choose to use something like that to aid the development process to generate a significant proportion of the pull request, please make sure this is explicitly stated in the PR itself.
+
## References
This document was adapted from the open-source contribution guidelines for [Facebook's Draft](https://github.com/facebook/draft-js/blob/main/CONTRIBUTING.md)
-# Automatic Respository Maintenance
+## Automatic Respository Maintenance
The homepage team appreciates all effort and interest from the community in filing bug reports, creating feature requests, sharing ideas and helping other community members. That said, in an effort to keep the repository organized and managebale the project uses automatic handling of certain areas:
diff --git a/docs/more/development.md b/docs/more/development.md
index 8e3fac13..ec580cff 100644
--- a/docs/more/development.md
+++ b/docs/more/development.md
@@ -39,6 +39,11 @@ Once installed, hooks will run when you commit. If the formatting isn't quite ri
See the [pre-commit documentation](https://pre-commit.com/#install) to get started.
+## Preferring self-hosted open-source software
+
+In general, homepage is meant to be a dashboard for 'self-hosted' services and we believe it is a small way we can help showcase this kind of software. While exceptions are made, mostly when there is no viable
+self-hosted / open-source alternative, we ask that any widgets, etc. are developed primarily for a self-hosted tool.
+
## New Feature Guidelines
- New features should be linked to an existing feature request with at least 10 'up-votes'. The purpose of this requirement is to avoid the addition (and maintenance) of features that might only benefit a small number of users.
From ffad2b890ee3bccf9ac40c4b9dc2e941d733d806 Mon Sep 17 00:00:00 2001
From: "github-actions[bot]"
<41898282+github-actions[bot]@users.noreply.github.com>
Date: Mon, 8 Apr 2024 10:20:52 -0700
Subject: [PATCH 068/136] New Crowdin translations by GitHub Action (#3199)
Co-authored-by: Crowdin Bot
---
public/locales/af/common.json | 6 +-
public/locales/ar/common.json | 14 +-
public/locales/bg/common.json | 12 +-
public/locales/ca/common.json | 6 +-
public/locales/cs/common.json | 12 +-
public/locales/da/common.json | 14 +-
public/locales/de/common.json | 6 +-
public/locales/el/common.json | 6 +-
public/locales/eo/common.json | 6 +-
public/locales/es/common.json | 48 +-
public/locales/eu/common.json | 6 +-
public/locales/fi/common.json | 6 +-
public/locales/fr/common.json | 14 +-
public/locales/he/common.json | 6 +-
public/locales/hi/common.json | 6 +-
public/locales/hr/common.json | 14 +-
public/locales/hu/common.json | 14 +-
public/locales/id/common.json | 14 +-
public/locales/it/common.json | 14 +-
public/locales/ja/common.json | 14 +-
public/locales/ko/common.json | 6 +-
public/locales/lv/common.json | 6 +-
public/locales/ms/common.json | 6 +-
public/locales/nl/common.json | 14 +-
public/locales/no/common.json | 848 +++++++++++++++--------------
public/locales/pl/common.json | 178 +++---
public/locales/pt/common.json | 14 +-
public/locales/pt_BR/common.json | 84 +--
public/locales/ro/common.json | 6 +-
public/locales/ru/common.json | 14 +-
public/locales/sk/common.json | 14 +-
public/locales/sl/common.json | 14 +-
public/locales/sr/common.json | 6 +-
public/locales/sv/common.json | 6 +-
public/locales/te/common.json | 6 +-
public/locales/th/common.json | 6 +-
public/locales/tr/common.json | 14 +-
public/locales/uk/common.json | 14 +-
public/locales/vi/common.json | 6 +-
public/locales/yue/common.json | 18 +-
public/locales/zh-Hans/common.json | 36 +-
public/locales/zh-Hant/common.json | 18 +-
42 files changed, 870 insertions(+), 702 deletions(-)
diff --git a/public/locales/af/common.json b/public/locales/af/common.json
index 654130bb..1aab2d89 100644
--- a/public/locales/af/common.json
+++ b/public/locales/af/common.json
@@ -277,7 +277,7 @@
"approved": "Goedgekeur",
"available": "Beskikbaar"
},
- "pialert": {
+ "netalertx": {
"total": "Totaal",
"connected": "Gekoppel",
"new_devices": "Nuwe Toestelle",
@@ -872,5 +872,9 @@
"labels": "Etikette",
"users": "Gebruikers",
"totalValue": "Totale Waarde"
+ },
+ "crowdsec": {
+ "alerts": "Waarskuwings",
+ "bans": "Verbanne"
}
}
diff --git a/public/locales/ar/common.json b/public/locales/ar/common.json
index 28497fd4..b66a97a8 100644
--- a/public/locales/ar/common.json
+++ b/public/locales/ar/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "في انتظار قطع الاتصال",
"connectionStatusDisconnecting": "جار قطع الاتصال",
"connectionStatusDisconnected": "غير متصل",
- "connectionStatusConnected": "متصل",
+ "connectionStatusConnected": "Connected",
"uptime": "مدة التشغيل",
"maxDown": "أقصى حد للتنزيل",
"maxUp": "أقصى حد للتحميل",
@@ -277,11 +277,11 @@
"approved": "مصدق",
"available": "متاح"
},
- "pialert": {
+ "netalertx": {
"total": "المجموع",
- "connected": "متصل",
- "new_devices": "أجهزة جديدة",
- "down_alerts": "تنبيهات تعطل الخوادم"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "الاستعلامات",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "المستخدمون",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "تنبيهات",
+ "bans": "Bans"
}
}
diff --git a/public/locales/bg/common.json b/public/locales/bg/common.json
index 3fc1676b..0d232fc1 100644
--- a/public/locales/bg/common.json
+++ b/public/locales/bg/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Pending Disconnect",
"connectionStatusDisconnecting": "Disconnecting",
"connectionStatusDisconnected": "Disconnected",
- "connectionStatusConnected": "Свързано",
+ "connectionStatusConnected": "Connected",
"uptime": "Uptime",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -277,10 +277,10 @@
"approved": "Одобрен",
"available": "Наличен"
},
- "pialert": {
+ "netalertx": {
"total": "Общо",
- "connected": "Свързано",
- "new_devices": "Нови устройства",
+ "connected": "Connected",
+ "new_devices": "New Devices",
"down_alerts": "Down Alerts"
},
"pihole": {
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Потребители",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Предупреждения",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ca/common.json b/public/locales/ca/common.json
index 4c7796ff..382f5237 100644
--- a/public/locales/ca/common.json
+++ b/public/locales/ca/common.json
@@ -277,7 +277,7 @@
"approved": "Aprovat",
"available": "Disponible"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Usuaris",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/cs/common.json b/public/locales/cs/common.json
index 81043207..f1540dd7 100644
--- a/public/locales/cs/common.json
+++ b/public/locales/cs/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Čeká na odpojení",
"connectionStatusDisconnecting": "Odpojování",
"connectionStatusDisconnected": "Odpojeno",
- "connectionStatusConnected": "Připojeno",
+ "connectionStatusConnected": "Connected",
"uptime": "Doba spuštění",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -277,10 +277,10 @@
"approved": "Schváleno",
"available": "Dostupné"
},
- "pialert": {
+ "netalertx": {
"total": "Celkem",
- "connected": "Připojeno",
- "new_devices": "Nová zařízení",
+ "connected": "Connected",
+ "new_devices": "New Devices",
"down_alerts": "Down Alerts"
},
"pihole": {
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Uživatelé",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Upozornění",
+ "bans": "Bans"
}
}
diff --git a/public/locales/da/common.json b/public/locales/da/common.json
index 390cb1f6..661032bc 100644
--- a/public/locales/da/common.json
+++ b/public/locales/da/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Pending Disconnect",
"connectionStatusDisconnecting": "Disconnecting",
"connectionStatusDisconnected": "Disconnected",
- "connectionStatusConnected": "Forbundet",
+ "connectionStatusConnected": "Connected",
"uptime": "Oppetid",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -277,11 +277,11 @@
"approved": "Godkendt",
"available": "Tilgængelig"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
- "connected": "Forbundet",
- "new_devices": "Nye Enheder",
- "down_alerts": "Nedadvarsler"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Forespørgsler",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Brugere",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Advarsler",
+ "bans": "Bans"
}
}
diff --git a/public/locales/de/common.json b/public/locales/de/common.json
index 529c5ea5..82212c69 100644
--- a/public/locales/de/common.json
+++ b/public/locales/de/common.json
@@ -277,7 +277,7 @@
"approved": "Genehmigt",
"available": "Verfügbar"
},
- "pialert": {
+ "netalertx": {
"total": "Gesamt",
"connected": "Verbunden",
"new_devices": "Neue Geräte",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Benutzer",
"totalValue": "Gesamtwert"
+ },
+ "crowdsec": {
+ "alerts": "Warnungen",
+ "bans": "Bans"
}
}
diff --git a/public/locales/el/common.json b/public/locales/el/common.json
index d006f1cc..d4f55f98 100644
--- a/public/locales/el/common.json
+++ b/public/locales/el/common.json
@@ -277,7 +277,7 @@
"approved": "Εγκρίθηκε",
"available": "Διαθέσιμο"
},
- "pialert": {
+ "netalertx": {
"total": "Σύνολο",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Χρήστες",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Ειδοποιήσεις",
+ "bans": "Bans"
}
}
diff --git a/public/locales/eo/common.json b/public/locales/eo/common.json
index 3b1fa0f5..4fa17c47 100644
--- a/public/locales/eo/common.json
+++ b/public/locales/eo/common.json
@@ -277,7 +277,7 @@
"approved": "Aprobita",
"available": "Havebla"
},
- "pialert": {
+ "netalertx": {
"total": "Totalo",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Uzantoj",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/es/common.json b/public/locales/es/common.json
index c65cff84..10aa7c6c 100644
--- a/public/locales/es/common.json
+++ b/public/locales/es/common.json
@@ -12,7 +12,7 @@
"number": "{{value, number}}",
"ms": "{{value, number}}",
"date": "{{value, date}}",
- "relativeDate": "{{value, relativeDate}}",
+ "relativeDate": "{{valor, relativaFecha}}",
"uptime": "{{value, uptime}}",
"months": "me",
"days": "d",
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Desconexión pendiente",
"connectionStatusDisconnecting": "Desconectando",
"connectionStatusDisconnected": "Desconectado",
- "connectionStatusConnected": "Conectado",
+ "connectionStatusConnected": "Connected",
"uptime": "Tiempo activo",
"maxDown": "Descarga máxima",
"maxUp": "Subida máxima",
@@ -277,11 +277,11 @@
"approved": "Aprobado",
"available": "Disponible"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
- "connected": "Conectado",
- "new_devices": "Nuevos dispositivos",
- "down_alerts": "Alertas de caídas"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Consultas",
@@ -427,7 +427,7 @@
"custom": "Personalizado",
"visit": "Visitar",
"url": "Enlace",
- "searchsuggestion": "Suggestion"
+ "searchsuggestion": "Sugerencia"
},
"wmo": {
"0-day": "Soleado",
@@ -546,12 +546,12 @@
"hd": "Alta definición",
"tunerCount": "Tuners",
"channelNumber": "Canal",
- "channelNetwork": "Network",
- "signalStrength": "Strength",
- "signalQuality": "Quality",
- "symbolQuality": "Quality",
+ "channelNetwork": "Red",
+ "signalStrength": "Intensidad",
+ "signalQuality": "Calidad",
+ "symbolQuality": "Calidad",
"networkRate": "Tasa de bits",
- "clientIP": "Client"
+ "clientIP": "Cliente"
},
"scrutiny": {
"passed": "Aprobado",
@@ -798,10 +798,10 @@
},
"openwrt": {
"uptime": "Tiempo activo",
- "cpuLoad": "CPU Load Avg (5m)",
+ "cpuLoad": "Carga promedio del CPU (5m)",
"up": "Activo",
"down": "Inactivo",
- "bytesTx": "Transmitted",
+ "bytesTx": "Transmitido",
"bytesRx": "Recibido"
},
"uptimerobot": {
@@ -826,21 +826,21 @@
"noEventsFound": "No se encontraron eventos"
},
"romm": {
- "platforms": "Platforms",
+ "platforms": "Plataformas",
"totalRoms": "Total ROMs"
},
"netdata": {
- "warnings": "Warnings",
- "criticals": "Criticals"
+ "warnings": "Advertencias",
+ "criticals": "Críticos"
},
"plantit": {
- "events": "Events",
+ "events": "Eventos",
"plants": "Plants",
"photos": "Fotos",
"species": "Species"
},
"gitea": {
- "notifications": "Notifications",
+ "notifications": "Notificaciones",
"issues": "Números",
"pulls": "Pull Requests"
},
@@ -852,7 +852,7 @@
"sceneSize": "Scenes Size",
"sceneDuration": "Scenes Duration",
"images": "Imágenes",
- "imageSize": "Images Size",
+ "imageSize": "Tamaño de imagen",
"galleries": "Galerías",
"performers": "Performers",
"studios": "Studios",
@@ -869,8 +869,12 @@
"items": "Items",
"totalWithWarranty": "Con Garantía",
"locations": "Ubicaciones",
- "labels": "Labels",
+ "labels": "Etiquetas",
"users": "Usuarios",
- "totalValue": "Total Value"
+ "totalValue": "Valor total"
+ },
+ "crowdsec": {
+ "alerts": "Alertas",
+ "bans": "Bans"
}
}
diff --git a/public/locales/eu/common.json b/public/locales/eu/common.json
index 0748eab0..6625148c 100644
--- a/public/locales/eu/common.json
+++ b/public/locales/eu/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Guztira",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/fi/common.json b/public/locales/fi/common.json
index ec4c11b7..b775e970 100644
--- a/public/locales/fi/common.json
+++ b/public/locales/fi/common.json
@@ -277,7 +277,7 @@
"approved": "Hyväksytty",
"available": "Saatavilla"
},
- "pialert": {
+ "netalertx": {
"total": "Yhteensä",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/fr/common.json b/public/locales/fr/common.json
index d2cd1a5c..17975096 100644
--- a/public/locales/fr/common.json
+++ b/public/locales/fr/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Déconnexion en attente",
"connectionStatusDisconnecting": "Déconnexion en cours",
"connectionStatusDisconnected": "Déconnecté",
- "connectionStatusConnected": "Connecté",
+ "connectionStatusConnected": "Connected",
"uptime": "Démarré depuis",
"maxDown": "Max. Bas",
"maxUp": "Max. Haut",
@@ -277,11 +277,11 @@
"approved": "Validé",
"available": "Disponible"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
- "connected": "Connecté",
- "new_devices": "Nouvel Appareil",
- "down_alerts": "Alertes"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Requêtes",
@@ -872,5 +872,9 @@
"labels": "Étiquettes",
"users": "Utilisateurs",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alertes",
+ "bans": "Bans"
}
}
diff --git a/public/locales/he/common.json b/public/locales/he/common.json
index d18f9856..a420823e 100644
--- a/public/locales/he/common.json
+++ b/public/locales/he/common.json
@@ -277,7 +277,7 @@
"approved": "מאושר",
"available": "זמין"
},
- "pialert": {
+ "netalertx": {
"total": "סה\"כ",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/hi/common.json b/public/locales/hi/common.json
index f05d60e0..866a1280 100644
--- a/public/locales/hi/common.json
+++ b/public/locales/hi/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/hr/common.json b/public/locales/hr/common.json
index 03cc8919..4b323b40 100644
--- a/public/locales/hr/common.json
+++ b/public/locales/hr/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Odspajanje u tijeku",
"connectionStatusDisconnecting": "Odspajanje",
"connectionStatusDisconnected": "Odspojeno",
- "connectionStatusConnected": "Povezano",
+ "connectionStatusConnected": "Connected",
"uptime": "Vrijeme rada",
"maxDown": "Maksimum preuzimanja",
"maxUp": "Maksimum prijenosa",
@@ -277,11 +277,11 @@
"approved": "Odobreno",
"available": "Dostupno"
},
- "pialert": {
+ "netalertx": {
"total": "Ukupno",
- "connected": "Povezano",
- "new_devices": "Novi uređaji",
- "down_alerts": "Obavijesti o nedostupnosti"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Upiti",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Korisnici",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Upozorenja",
+ "bans": "Bans"
}
}
diff --git a/public/locales/hu/common.json b/public/locales/hu/common.json
index d1ac7035..735de467 100644
--- a/public/locales/hu/common.json
+++ b/public/locales/hu/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Szétkapcsolás függőben",
"connectionStatusDisconnecting": "Kapcsolat bontása",
"connectionStatusDisconnected": "Kapcsolat bontva",
- "connectionStatusConnected": "Csatlakoztatott",
+ "connectionStatusConnected": "Connected",
"uptime": "Üzemidő",
"maxDown": "Max let.",
"maxUp": "Max felt.",
@@ -277,11 +277,11 @@
"approved": "Engedélyezett",
"available": "Elérhető"
},
- "pialert": {
+ "netalertx": {
"total": "Összes",
- "connected": "Csatlakoztatott",
- "new_devices": "Új Eszközök",
- "down_alerts": "Leállási Figyelmeztetések"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Lekérdezések",
@@ -872,5 +872,9 @@
"labels": "Címkék",
"users": "Felhasználók",
"totalValue": "Teljes érték"
+ },
+ "crowdsec": {
+ "alerts": "Riasztások",
+ "bans": "Bans"
}
}
diff --git a/public/locales/id/common.json b/public/locales/id/common.json
index 38d44f4b..c1ca4450 100644
--- a/public/locales/id/common.json
+++ b/public/locales/id/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Menunggu Terputus",
"connectionStatusDisconnecting": "Sedan Memutus",
"connectionStatusDisconnected": "Terputus",
- "connectionStatusConnected": "Tersambung",
+ "connectionStatusConnected": "Connected",
"uptime": "Waktu Aktif",
"maxDown": "Maks Unduh",
"maxUp": "Maks Unggah",
@@ -277,11 +277,11 @@
"approved": "Tersetujui",
"available": "Tersedia"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
- "connected": "Tersambung",
- "new_devices": "Perangkat Baru",
- "down_alerts": "Alert Mati"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Kueri",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Pengguna",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Peringatan",
+ "bans": "Bans"
}
}
diff --git a/public/locales/it/common.json b/public/locales/it/common.json
index 421807f2..a795bc57 100644
--- a/public/locales/it/common.json
+++ b/public/locales/it/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "In attesa di disconnessione",
"connectionStatusDisconnecting": "Disconnessione in corso",
"connectionStatusDisconnected": "Disconnesso",
- "connectionStatusConnected": "Connesso",
+ "connectionStatusConnected": "Connected",
"uptime": "Tempo di attività",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -277,11 +277,11 @@
"approved": "Approvati",
"available": "Disponibili"
},
- "pialert": {
+ "netalertx": {
"total": "Totale",
- "connected": "Connesso",
- "new_devices": "Nuovi Dispositivi",
- "down_alerts": "Avvisi di Disservizio"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Richieste",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Utenti",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Allarmi",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ja/common.json b/public/locales/ja/common.json
index a4507bf4..e2f6a57b 100644
--- a/public/locales/ja/common.json
+++ b/public/locales/ja/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "接続を切断する",
"connectionStatusDisconnecting": "接続を切断中",
"connectionStatusDisconnected": "切断されました",
- "connectionStatusConnected": "接続済み",
+ "connectionStatusConnected": "Connected",
"uptime": "稼働時間",
"maxDown": "最大ダウン",
"maxUp": "最大アップ",
@@ -277,11 +277,11 @@
"approved": "承認済",
"available": "利用可"
},
- "pialert": {
+ "netalertx": {
"total": "合計",
- "connected": "接続済み",
- "new_devices": "新しいデバイス",
- "down_alerts": "ダウンアラート"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "クエリ",
@@ -872,5 +872,9 @@
"labels": "ラベル",
"users": "ユーザ",
"totalValue": "合計値"
+ },
+ "crowdsec": {
+ "alerts": "アラート",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ko/common.json b/public/locales/ko/common.json
index da8aa492..5e7a90e1 100644
--- a/public/locales/ko/common.json
+++ b/public/locales/ko/common.json
@@ -277,7 +277,7 @@
"approved": "승인됨",
"available": "이용 가능"
},
- "pialert": {
+ "netalertx": {
"total": "총합",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "사용자",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "경고",
+ "bans": "Bans"
}
}
diff --git a/public/locales/lv/common.json b/public/locales/lv/common.json
index 8211b753..1a46c862 100644
--- a/public/locales/lv/common.json
+++ b/public/locales/lv/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Kopā",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Lietotāji",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Paziņojumi",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ms/common.json b/public/locales/ms/common.json
index 46f08be8..f9583148 100644
--- a/public/locales/ms/common.json
+++ b/public/locales/ms/common.json
@@ -277,7 +277,7 @@
"approved": "Lulus",
"available": "Sudah Ada"
},
- "pialert": {
+ "netalertx": {
"total": "Jumlah",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Pengguna",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/nl/common.json b/public/locales/nl/common.json
index f1cd7aac..8aff253e 100644
--- a/public/locales/nl/common.json
+++ b/public/locales/nl/common.json
@@ -277,7 +277,7 @@
"approved": "Goedgekeurd",
"available": "Beschikbaar"
},
- "pialert": {
+ "netalertx": {
"total": "Totaal",
"connected": "Verbonden",
"new_devices": "Nieuwe Apparaten",
@@ -826,8 +826,8 @@
"noEventsFound": "Geen gebeurtenissen gevonden"
},
"romm": {
- "platforms": "Platforms",
- "totalRoms": "Total ROMs"
+ "platforms": "Platformen",
+ "totalRoms": "Totale ROM's"
},
"netdata": {
"warnings": "Waarschuwingen",
@@ -840,7 +840,7 @@
"species": "Soorten"
},
"gitea": {
- "notifications": "Notifications",
+ "notifications": "Notificaties",
"issues": "Problemen",
"pulls": "Pull Requests"
},
@@ -863,7 +863,7 @@
"tandoor": {
"users": "Gebruikers",
"recipes": "Recepten",
- "keywords": "Keywords"
+ "keywords": "Trefwoorden"
},
"homebox": {
"items": "Items",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Gebruikers",
"totalValue": "Totale waarde"
+ },
+ "crowdsec": {
+ "alerts": "Meldingen",
+ "bans": "Bans"
}
}
diff --git a/public/locales/no/common.json b/public/locales/no/common.json
index 86d6b20b..bfc335c9 100644
--- a/public/locales/no/common.json
+++ b/public/locales/no/common.json
@@ -14,76 +14,76 @@
"date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
- "months": "mo",
+ "months": "mnd",
"days": "d",
- "hours": "h",
+ "hours": "t",
"minutes": "m",
"seconds": "s"
},
"widget": {
- "missing_type": "Missing Widget Type: {{type}}",
- "api_error": "API Error",
- "information": "Information",
+ "missing_type": "Manglende Widget Type: {{type}}",
+ "api_error": "API-feil",
+ "information": "Informasjon",
"status": "Status",
- "url": "URL",
- "raw_error": "Raw Error",
- "response_data": "Response Data"
+ "url": "Nettadresse",
+ "raw_error": "Rå feil",
+ "response_data": "Responsdata"
},
"weather": {
- "current": "Current Location",
- "allow": "Click to allow",
- "updating": "Updating",
- "wait": "Please wait"
+ "current": "Gjeldende posisjon",
+ "allow": "Trykk for å tillate",
+ "updating": "Oppdaterer",
+ "wait": "Vennligst vent"
},
"search": {
- "placeholder": "Search…"
+ "placeholder": "Søk…"
},
"resources": {
"cpu": "CPU",
"mem": "MEM",
- "total": "Total",
- "free": "Free",
- "used": "Used",
- "load": "Load",
+ "total": "Totalt",
+ "free": "Ledig",
+ "used": "Brukt",
+ "load": "Last",
"temp": "TEMP",
- "max": "Max",
- "uptime": "UP"
+ "max": "Maks",
+ "uptime": "OPP"
},
"unifi": {
- "users": "Users",
- "uptime": "Uptime",
- "days": "Days",
+ "users": "Brukere",
+ "uptime": "Oppetid",
+ "days": "Dager",
"wan": "WAN",
"lan": "LAN",
"wlan": "WLAN",
- "devices": "Devices",
- "lan_devices": "LAN Devices",
- "wlan_devices": "WLAN Devices",
- "lan_users": "LAN Users",
- "wlan_users": "WLAN Users",
- "up": "UP",
- "down": "DOWN",
- "wait": "Please wait",
- "empty_data": "Subsystem status unknown"
+ "devices": "Enheter",
+ "lan_devices": "LAN-enheter",
+ "wlan_devices": "WLAN-enheter",
+ "lan_users": "LAN Brukere",
+ "wlan_users": "WLAN Brukere",
+ "up": "OPP",
+ "down": "NEDE",
+ "wait": "Vennligst vent",
+ "empty_data": "Ukjent undersystemstatus"
},
"docker": {
"rx": "RX",
"tx": "TX",
"mem": "MEM",
"cpu": "CPU",
- "running": "Running",
- "offline": "Offline",
- "error": "Error",
- "unknown": "Unknown",
- "healthy": "Healthy",
- "starting": "Starting",
- "unhealthy": "Unhealthy",
+ "running": "Kjører",
+ "offline": "Frakoblet",
+ "error": "Feil",
+ "unknown": "Ukjent",
+ "healthy": "Friskt",
+ "starting": "Starter",
+ "unhealthy": "Usunn",
"not_found": "Not Found",
"exited": "Exited",
"partial": "Partial"
},
"ping": {
- "error": "Error",
+ "error": "Feil",
"ping": "Ping",
"down": "Down",
"up": "Up",
@@ -91,226 +91,226 @@
},
"siteMonitor": {
"http_status": "HTTP status",
- "error": "Error",
- "response": "Response",
+ "error": "Feil",
+ "response": "Svar",
"down": "Down",
"up": "Up",
"not_available": "Not Available"
},
"emby": {
- "playing": "Playing",
- "transcoding": "Transcoding",
+ "playing": "Spiller",
+ "transcoding": "Transkoding",
"bitrate": "Bitrate",
- "no_active": "No Active Streams",
- "movies": "Movies",
- "series": "Series",
- "episodes": "Episodes",
- "songs": "Songs"
+ "no_active": "Ingen aktive strømminger",
+ "movies": "Film",
+ "series": "Serie",
+ "episodes": "Episoder",
+ "songs": "Sanger"
},
"esphome": {
- "offline": "Offline",
- "offline_alt": "Offline",
+ "offline": "Frakoblet",
+ "offline_alt": "Frakoblet",
"online": "Online",
- "total": "Total",
- "unknown": "Unknown"
+ "total": "Totalt",
+ "unknown": "Ukjent"
},
"evcc": {
- "pv_power": "Production",
- "battery_soc": "Battery",
- "grid_power": "Grid",
- "home_power": "Consumption",
- "charge_power": "Charger",
- "watt_hour": "Wh"
+ "pv_power": "Produksjon",
+ "battery_soc": "Batteri",
+ "grid_power": "Nett",
+ "home_power": "Forbruk",
+ "charge_power": "Lader",
+ "watt_hour": "W/t"
},
"flood": {
- "download": "Download",
- "upload": "Upload",
+ "download": "Last ned",
+ "upload": "Opplastning",
"leech": "Leech",
"seed": "Seed"
},
"freshrss": {
- "subscriptions": "Subscriptions",
- "unread": "Unread"
+ "subscriptions": "Abonnementer",
+ "unread": "Ulest"
},
"fritzbox": {
"connectionStatus": "Status",
- "connectionStatusUnconfigured": "Unconfigured",
- "connectionStatusConnecting": "Connecting",
- "connectionStatusAuthenticating": "Authenticating",
- "connectionStatusPendingDisconnect": "Pending Disconnect",
- "connectionStatusDisconnecting": "Disconnecting",
- "connectionStatusDisconnected": "Disconnected",
+ "connectionStatusUnconfigured": "Ikke konfigurert",
+ "connectionStatusConnecting": "Kobler til",
+ "connectionStatusAuthenticating": "Autentisering",
+ "connectionStatusPendingDisconnect": "Venter på frakobling",
+ "connectionStatusDisconnecting": "Kobler fra",
+ "connectionStatusDisconnected": "Frakoblet",
"connectionStatusConnected": "Connected",
- "uptime": "Uptime",
- "maxDown": "Max. Down",
- "maxUp": "Max. Up",
+ "uptime": "Oppetid",
+ "maxDown": "Maks. Ned",
+ "maxUp": "Max. Opp",
"down": "Down",
"up": "Up",
- "received": "Received",
- "sent": "Sent",
- "externalIPAddress": "Ext. IP"
+ "received": "Mottatt",
+ "sent": "Sendt",
+ "externalIPAddress": "Ekstern IP"
},
"caddy": {
- "upstreams": "Upstreams",
- "requests": "Current requests",
- "requests_failed": "Failed requests"
+ "upstreams": "Oppstrøms",
+ "requests": "Aktuelle forespørsler",
+ "requests_failed": "Mislykkede forespørsler"
},
"changedetectionio": {
- "totalObserved": "Total Observed",
- "diffsDetected": "Diffs Detected"
+ "totalObserved": "Totalt sett",
+ "diffsDetected": "Diffs oppdaget"
},
"channelsdvrserver": {
"shows": "Shows",
- "recordings": "Recordings",
- "scheduled": "Scheduled",
- "passes": "Passes"
+ "recordings": "Opptak",
+ "scheduled": "Tidsplan",
+ "passes": "Pasninger"
},
"tautulli": {
- "playing": "Playing",
- "transcoding": "Transcoding",
+ "playing": "Spiller",
+ "transcoding": "Transkoding",
"bitrate": "Bitrate",
- "no_active": "No Active Streams",
- "plex_connection_error": "Check Plex Connection"
+ "no_active": "Ingen aktive strømminger",
+ "plex_connection_error": "Kontroller Plex tilkoblingen"
},
"omada": {
- "connectedAp": "Connected APs",
- "activeUser": "Active devices",
- "alerts": "Alerts",
- "connectedGateway": "Connected gateways",
- "connectedSwitches": "Connected switches"
+ "connectedAp": "Tilkoblede AP'er",
+ "activeUser": "Aktive enheter",
+ "alerts": "Varsler",
+ "connectedGateway": "Tilkoblede gateways",
+ "connectedSwitches": "Tilkoblede switcher"
},
"nzbget": {
- "rate": "Rate",
- "remaining": "Remaining",
- "downloaded": "Downloaded"
+ "rate": "Ranger",
+ "remaining": "Gjenstående",
+ "downloaded": "Nedlastede"
},
"plex": {
- "streams": "Active Streams",
- "albums": "Albums",
- "movies": "Movies",
- "tv": "TV Shows"
+ "streams": "Aktive strømmninger",
+ "albums": "Album",
+ "movies": "Film",
+ "tv": "TV serier"
},
"sabnzbd": {
- "rate": "Rate",
- "queue": "Queue",
- "timeleft": "Time Left"
+ "rate": "Ranger",
+ "queue": "Kø",
+ "timeleft": "Gjenstående tid"
},
"rutorrent": {
- "active": "Active",
- "upload": "Upload",
- "download": "Download"
+ "active": "Aktiv",
+ "upload": "Opplastning",
+ "download": "Last ned"
},
"transmission": {
- "download": "Download",
- "upload": "Upload",
+ "download": "Last ned",
+ "upload": "Opplastning",
"leech": "Leech",
"seed": "Seed"
},
"qbittorrent": {
- "download": "Download",
- "upload": "Upload",
+ "download": "Last ned",
+ "upload": "Opplastning",
"leech": "Leech",
"seed": "Seed"
},
"qnap": {
- "cpuUsage": "CPU Usage",
- "memUsage": "MEM Usage",
- "systemTempC": "System Temp",
- "poolUsage": "Pool Usage",
- "volumeUsage": "Volume Usage",
- "invalid": "Invalid"
+ "cpuUsage": "CPU Bruk",
+ "memUsage": "Minnebruk",
+ "systemTempC": "System temp",
+ "poolUsage": "Pool Bruk",
+ "volumeUsage": "Volumbruk",
+ "invalid": "Ugyldig"
},
"deluge": {
- "download": "Download",
- "upload": "Upload",
+ "download": "Last ned",
+ "upload": "Opplastning",
"leech": "Leech",
"seed": "Seed"
},
"downloadstation": {
- "download": "Download",
- "upload": "Upload",
+ "download": "Last ned",
+ "upload": "Opplastning",
"leech": "Leech",
"seed": "Seed"
},
"sonarr": {
- "wanted": "Wanted",
- "queued": "Queued",
- "series": "Series",
- "queue": "Queue",
- "unknown": "Unknown"
+ "wanted": "Ønsket",
+ "queued": "Ventende",
+ "series": "Serie",
+ "queue": "Kø",
+ "unknown": "Ukjent"
},
"radarr": {
- "wanted": "Wanted",
- "missing": "Missing",
- "queued": "Queued",
- "movies": "Movies",
- "queue": "Queue",
- "unknown": "Unknown"
+ "wanted": "Ønsket",
+ "missing": "Mangler",
+ "queued": "Ventende",
+ "movies": "Film",
+ "queue": "Kø",
+ "unknown": "Ukjent"
},
"lidarr": {
- "wanted": "Wanted",
- "queued": "Queued",
- "artists": "Artists"
+ "wanted": "Ønsket",
+ "queued": "Ventende",
+ "artists": "Artister"
},
"readarr": {
- "wanted": "Wanted",
- "queued": "Queued",
- "books": "Books"
+ "wanted": "Ønsket",
+ "queued": "Ventende",
+ "books": "Bøker"
},
"bazarr": {
- "missingEpisodes": "Missing Episodes",
- "missingMovies": "Missing Movies"
+ "missingEpisodes": "Manglende episoder",
+ "missingMovies": "Manglende filmer"
},
"ombi": {
- "pending": "Pending",
- "approved": "Approved",
- "available": "Available"
+ "pending": "Ventende",
+ "approved": "Godkjent",
+ "available": "Tilgjengelig"
},
"jellyseerr": {
- "pending": "Pending",
- "approved": "Approved",
- "available": "Available"
+ "pending": "Ventende",
+ "approved": "Godkjent",
+ "available": "Tilgjengelig"
},
"overseerr": {
- "pending": "Pending",
- "processing": "Processing",
- "approved": "Approved",
- "available": "Available"
+ "pending": "Ventende",
+ "processing": "Behandler",
+ "approved": "Godkjent",
+ "available": "Tilgjengelig"
},
- "pialert": {
- "total": "Total",
+ "netalertx": {
+ "total": "Totalt",
"connected": "Connected",
"new_devices": "New Devices",
"down_alerts": "Down Alerts"
},
"pihole": {
- "queries": "Queries",
- "blocked": "Blocked",
- "blocked_percent": "Blocked %",
- "gravity": "Gravity"
+ "queries": "Spørringer",
+ "blocked": "Blokkert",
+ "blocked_percent": "Blokkert %",
+ "gravity": "Gravitasjon"
},
"adguard": {
- "queries": "Queries",
- "blocked": "Blocked",
- "filtered": "Filtered",
- "latency": "Latency"
+ "queries": "Spørringer",
+ "blocked": "Blokkert",
+ "filtered": "Filtrert",
+ "latency": "Responstid"
},
"speedtest": {
- "upload": "Upload",
- "download": "Download",
+ "upload": "Opplastning",
+ "download": "Last ned",
"ping": "Ping"
},
"portainer": {
- "running": "Running",
- "stopped": "Stopped",
- "total": "Total"
+ "running": "Kjører",
+ "stopped": "Stoppet",
+ "total": "Totalt"
},
"tailscale": {
- "address": "Address",
- "expires": "Expires",
- "never": "Never",
- "last_seen": "Last Seen",
- "now": "Now",
+ "address": "Adresse",
+ "expires": "Utgår",
+ "never": "Aldri",
+ "last_seen": "Sist sett",
+ "now": "Nå",
"years": "{{number}}y",
"weeks": "{{number}}w",
"days": "{{number}}d",
@@ -320,7 +320,7 @@
"ago": "{{value}} Ago"
},
"tdarr": {
- "queue": "Queue",
+ "queue": "Kø",
"processed": "Processed",
"errored": "Errored",
"saved": "Saved"
@@ -331,13 +331,13 @@
"middleware": "Middleware"
},
"navidrome": {
- "nothing_streaming": "No Active Streams",
+ "nothing_streaming": "Ingen aktive strømminger",
"please_wait": "Please Wait"
},
"npm": {
"enabled": "Enabled",
"disabled": "Disabled",
- "total": "Total"
+ "total": "Totalt"
},
"coinmarketcap": {
"configure": "Configure one or more crypto currencies to track",
@@ -354,7 +354,7 @@
"prowlarr": {
"enableIndexers": "Indexers",
"numberOfGrabs": "Grabs",
- "numberOfQueries": "Queries",
+ "numberOfQueries": "Spørringer",
"numberOfFailGrabs": "Fail Grabs",
"numberOfFailQueries": "Fail Queries"
},
@@ -366,33 +366,33 @@
"numActiveSessions": "Sessions",
"numConnections": "Connections",
"dataRelayed": "Relayed",
- "transferRate": "Rate"
+ "transferRate": "Ranger"
},
"mastodon": {
- "user_count": "Users",
+ "user_count": "Brukere",
"status_count": "Posts",
"domain_count": "Domains"
},
"medusa": {
- "wanted": "Wanted",
- "queued": "Queued",
- "series": "Series"
+ "wanted": "Ønsket",
+ "queued": "Ventende",
+ "series": "Serie"
},
"minecraft": {
"players": "Players",
- "version": "Version",
+ "version": "Versjon",
"status": "Status",
"up": "Online",
- "down": "Offline"
+ "down": "Frakoblet"
},
"miniflux": {
"read": "Read",
- "unread": "Unread"
+ "unread": "Ulest"
},
"authentik": {
- "users": "Users",
+ "users": "Brukere",
"loginsLast24H": "Logins (24h)",
- "failedLoginsLast24H": "Failed Logins (24h)"
+ "failedLoginsLast24H": "Mislykket innlogginger (24t)"
},
"proxmox": {
"mem": "MEM",
@@ -402,211 +402,211 @@
},
"glances": {
"cpu": "CPU",
- "load": "Load",
- "wait": "Please wait",
+ "load": "Last",
+ "wait": "Vennligst vent",
"temp": "TEMP",
"_temp": "Temp",
- "warn": "Warn",
- "uptime": "UP",
- "total": "Total",
- "free": "Free",
- "used": "Used",
+ "warn": "Advarsel",
+ "uptime": "OPP",
+ "total": "Totalt",
+ "free": "Ledig",
+ "used": "Brukt",
"days": "d",
- "hours": "h",
+ "hours": "t",
"crit": "Crit",
"read": "Read",
- "write": "Write",
+ "write": "Skriv",
"gpu": "GPU",
"mem": "Mem",
"swap": "Swap"
},
"quicklaunch": {
- "bookmark": "Bookmark",
- "service": "Service",
- "search": "Search",
- "custom": "Custom",
- "visit": "Visit",
- "url": "URL",
- "searchsuggestion": "Suggestion"
+ "bookmark": "Bokmerke",
+ "service": "Tjeneste",
+ "search": "Søk",
+ "custom": "Egendefinert",
+ "visit": "Besøk",
+ "url": "Nettadresse",
+ "searchsuggestion": "Forslag"
},
"wmo": {
- "0-day": "Sunny",
- "0-night": "Clear",
- "1-day": "Mainly Sunny",
- "1-night": "Mainly Clear",
- "2-day": "Partly Cloudy",
- "2-night": "Partly Cloudy",
- "3-day": "Cloudy",
- "3-night": "Cloudy",
- "45-day": "Foggy",
- "45-night": "Foggy",
- "48-day": "Foggy",
- "48-night": "Foggy",
- "51-day": "Light Drizzle",
- "51-night": "Light Drizzle",
- "53-day": "Drizzle",
- "53-night": "Drizzle",
- "55-day": "Heavy Drizzle",
- "55-night": "Heavy Drizzle",
- "56-day": "Light Freezing Drizzle",
- "56-night": "Light Freezing Drizzle",
- "57-day": "Freezing Drizzle",
- "57-night": "Freezing Drizzle",
- "61-day": "Light Rain",
- "61-night": "Light Rain",
- "63-day": "Rain",
- "63-night": "Rain",
- "65-day": "Heavy Rain",
- "65-night": "Heavy Rain",
- "66-day": "Freezing Rain",
- "66-night": "Freezing Rain",
- "67-day": "Freezing Rain",
- "67-night": "Freezing Rain",
- "71-day": "Light Snow",
- "71-night": "Light Snow",
- "73-day": "Snow",
- "73-night": "Snow",
- "75-day": "Heavy Snow",
- "75-night": "Heavy Snow",
- "77-day": "Snow Grains",
- "77-night": "Snow Grains",
- "80-day": "Light Showers",
- "80-night": "Light Showers",
- "81-day": "Showers",
- "81-night": "Showers",
- "82-day": "Heavy Showers",
- "82-night": "Heavy Showers",
- "85-day": "Snow Showers",
- "85-night": "Snow Showers",
- "86-day": "Snow Showers",
- "86-night": "Snow Showers",
- "95-day": "Thunderstorm",
- "95-night": "Thunderstorm",
- "96-day": "Thunderstorm With Hail",
- "96-night": "Thunderstorm With Hail",
- "99-day": "Thunderstorm With Hail",
- "99-night": "Thunderstorm With Hail"
+ "0-day": "Solfylt",
+ "0-night": "Klart",
+ "1-day": "Lettskyet",
+ "1-night": "Lettskyet",
+ "2-day": "Delvis skyet",
+ "2-night": "Delvis skyet",
+ "3-day": "Skyet",
+ "3-night": "Skyet",
+ "45-day": "Tåke",
+ "45-night": "Tåke",
+ "48-day": "Tåke",
+ "48-night": "Tåke",
+ "51-day": "Lett yr",
+ "51-night": "Lett yr",
+ "53-day": "Yr",
+ "53-night": "Yr",
+ "55-day": "Tungt Regn",
+ "55-night": "Tungt Regn",
+ "56-day": "Lett underkjølt regn",
+ "56-night": "Lett underkjølt regn",
+ "57-day": "Underkjølt Regn",
+ "57-night": "Underkjølt Regn",
+ "61-day": "Lett regn",
+ "61-night": "Lett regn",
+ "63-day": "Regn",
+ "63-night": "Regn",
+ "65-day": "Kraftig regn",
+ "65-night": "Kraftig regn",
+ "66-day": "Underkjølt regn",
+ "66-night": "Underkjølt regn",
+ "67-day": "Underkjølt regn",
+ "67-night": "Underkjølt regn",
+ "71-day": "Lett snøvær",
+ "71-night": "Lett snøvær",
+ "73-day": "Snø",
+ "73-night": "Snø",
+ "75-day": "Tett snø",
+ "75-night": "Tett snø",
+ "77-day": "Snøkorn",
+ "77-night": "Snøkorn",
+ "80-day": "Lette Regnbyger",
+ "80-night": "Lette Regnbyger",
+ "81-day": "Regnbyger",
+ "81-night": "Regnbyger",
+ "82-day": "Tunge regnbyger",
+ "82-night": "Tunge regnbyger",
+ "85-day": "Snøbyger",
+ "85-night": "Snøbyger",
+ "86-day": "Snøbyger",
+ "86-night": "Snøbyger",
+ "95-day": "Tordenbyger",
+ "95-night": "Tordenbyger",
+ "96-day": "Tordenvær med hagl",
+ "96-night": "Tordenvær med hagl",
+ "99-day": "Tordenvær med hagl",
+ "99-night": "Tordenvær med hagl"
},
"homebridge": {
"available_update": "System",
- "updates": "Updates",
- "update_available": "Update Available",
- "up_to_date": "Up to Date",
+ "updates": "Oppdateringer",
+ "update_available": "Oppdatering tilgjengelig",
+ "up_to_date": "Oppdatert",
"child_bridges": "Child Bridges",
"child_bridges_status": "{{ok}}/{{total}}",
"up": "Up",
- "pending": "Pending",
+ "pending": "Ventende",
"down": "Down"
},
"healthchecks": {
- "new": "New",
+ "new": "Ny",
"up": "Up",
- "grace": "In Grace Period",
+ "grace": "I rammeperiode",
"down": "Down",
- "paused": "Paused",
+ "paused": "Pauset",
"status": "Status",
- "last_ping": "Last Ping",
- "never": "No pings yet"
+ "last_ping": "Siste Ping",
+ "never": "Ingen ping ennå"
},
"watchtower": {
- "containers_scanned": "Scanned",
- "containers_updated": "Updated",
- "containers_failed": "Failed"
+ "containers_scanned": "Skannet",
+ "containers_updated": "Oppdatert",
+ "containers_failed": "Mislyktes"
},
"autobrr": {
- "approvedPushes": "Approved",
- "rejectedPushes": "Rejected",
- "filters": "Filters",
+ "approvedPushes": "Godkjent",
+ "rejectedPushes": "Avvist",
+ "filters": "Filtre",
"indexers": "Indexers"
},
"tubearchivist": {
- "downloads": "Queue",
- "videos": "Videos",
- "channels": "Channels",
- "playlists": "Playlists"
+ "downloads": "Kø",
+ "videos": "Videoer",
+ "channels": "Kanal",
+ "playlists": "Spillelister"
},
"truenas": {
- "load": "System Load",
- "uptime": "Uptime",
- "alerts": "Alerts"
+ "load": "Last på systemet",
+ "uptime": "Oppetid",
+ "alerts": "Varsler"
},
"pyload": {
- "speed": "Speed",
- "active": "Active",
- "queue": "Queue",
- "total": "Total"
+ "speed": "Hastighet",
+ "active": "Aktiv",
+ "queue": "Kø",
+ "total": "Totalt"
},
"gluetun": {
- "public_ip": "Public IP",
+ "public_ip": "Offentlig IP",
"region": "Region",
- "country": "Country"
+ "country": "Land"
},
"hdhomerun": {
- "channels": "Channels",
+ "channels": "Kanal",
"hd": "HD",
- "tunerCount": "Tuners",
- "channelNumber": "Channel",
- "channelNetwork": "Network",
- "signalStrength": "Strength",
- "signalQuality": "Quality",
- "symbolQuality": "Quality",
+ "tunerCount": "Tunere",
+ "channelNumber": "Kanal",
+ "channelNetwork": "Nettverk",
+ "signalStrength": "Styrke",
+ "signalQuality": "Kvalitet",
+ "symbolQuality": "Kvalitet",
"networkRate": "Bitrate",
- "clientIP": "Client"
+ "clientIP": "Klient"
},
"scrutiny": {
- "passed": "Passed",
- "failed": "Failed",
- "unknown": "Unknown"
+ "passed": "Bestått",
+ "failed": "Mislyktes",
+ "unknown": "Ukjent"
},
"paperlessngx": {
- "inbox": "Inbox",
- "total": "Total"
+ "inbox": "Innboks",
+ "total": "Totalt"
},
"peanut": {
- "battery_charge": "Battery Charge",
- "ups_load": "UPS Load",
- "ups_status": "UPS Status",
+ "battery_charge": "Batteriladning",
+ "ups_load": "UPS last",
+ "ups_status": "UPS status",
"online": "Online",
- "on_battery": "On Battery",
- "low_battery": "Low Battery"
+ "on_battery": "På batteri",
+ "low_battery": "Lavt batterinivå"
},
"nextdns": {
"wait": "Please Wait",
- "no_devices": "No Device Data Received"
+ "no_devices": "Ingen enhetsdata mottatt"
},
"mikrotik": {
- "cpuLoad": "CPU Load",
- "memoryUsed": "Memory Used",
- "uptime": "Uptime",
+ "cpuLoad": "Prosessorbelastning",
+ "memoryUsed": "Minne brukt",
+ "uptime": "Oppetid",
"numberOfLeases": "Leases"
},
"xteve": {
- "streams_all": "All Streams",
- "streams_active": "Active Streams",
- "streams_xepg": "XEPG Channels"
+ "streams_all": "Alle strømminger",
+ "streams_active": "Aktive strømmninger",
+ "streams_xepg": "XEPG Kanaler"
},
"opendtu": {
- "yieldDay": "Today",
- "absolutePower": "Power",
- "relativePower": "Power %",
- "limit": "Limit"
+ "yieldDay": "Idag",
+ "absolutePower": "Effekt",
+ "relativePower": "Effekt %",
+ "limit": "Grense"
},
"opnsense": {
- "cpu": "CPU Load",
- "memory": "Active Memory",
- "wanUpload": "WAN Upload",
- "wanDownload": "WAN Download"
+ "cpu": "Prosessorbelastning",
+ "memory": "Aktiv minne",
+ "wanUpload": "WAN Opplasting",
+ "wanDownload": "WAN Nedlasting"
},
"moonraker": {
- "printer_state": "Printer State",
+ "printer_state": "Skriver tilstand",
"print_status": "Print Status",
- "print_progress": "Progress",
- "layers": "Layers"
+ "print_progress": "Progresjon",
+ "layers": "Lag"
},
"octoprint": {
"printer_state": "Status",
- "temp_tool": "Tool temp",
- "temp_bed": "Bed temp",
+ "temp_tool": "Verktøy temperatur",
+ "temp_bed": "Seng temperatur",
"job_completion": "Completion"
},
"cloudflared": {
@@ -630,48 +630,48 @@
"memory_usage": "Memory"
},
"immich": {
- "users": "Users",
+ "users": "Brukere",
"photos": "Photos",
- "videos": "Videos",
- "storage": "Storage"
+ "videos": "Videoer",
+ "storage": "Lagring"
},
"uptimekuma": {
- "up": "Sites Up",
+ "up": "Nettsteder opp",
"down": "Sites Down",
- "uptime": "Uptime",
+ "uptime": "Oppetid",
"incident": "Incident",
"m": "m"
},
"atsumeru": {
- "series": "Series",
+ "series": "Serie",
"archives": "Archives",
"chapters": "Chapters",
"categories": "Categories"
},
"komga": {
"libraries": "Libraries",
- "series": "Series",
- "books": "Books"
+ "series": "Serie",
+ "books": "Bøker"
},
"diskstation": {
- "days": "Days",
- "uptime": "Uptime",
- "volumeAvailable": "Available"
+ "days": "Dager",
+ "uptime": "Oppetid",
+ "volumeAvailable": "Tilgjengelig"
},
"mylar": {
- "series": "Series",
+ "series": "Serie",
"issues": "Issues",
- "wanted": "Wanted"
+ "wanted": "Ønsket"
},
"photoprism": {
- "albums": "Albums",
+ "albums": "Album",
"photos": "Photos",
- "videos": "Videos",
+ "videos": "Videoer",
"people": "People"
},
"fileflows": {
- "queue": "Queue",
- "processing": "Processing",
+ "queue": "Kø",
+ "processing": "Behandler",
"processed": "Processed",
"time": "Time"
},
@@ -694,7 +694,7 @@
"size": "Size",
"lastrun": "Last Run",
"nextrun": "Next Run",
- "failed": "Failed"
+ "failed": "Mislyktes"
},
"unmanic": {
"active_workers": "Active Workers",
@@ -711,18 +711,18 @@
"targets_total": "Total Targets"
},
"gatus": {
- "up": "Sites Up",
+ "up": "Nettsteder opp",
"down": "Sites Down",
- "uptime": "Uptime"
+ "uptime": "Oppetid"
},
"ghostfolio": {
- "gross_percent_today": "Today",
+ "gross_percent_today": "Idag",
"gross_percent_1y": "One year",
"gross_percent_max": "All time"
},
"audiobookshelf": {
"podcasts": "Podcasts",
- "books": "Books",
+ "books": "Bøker",
"podcastsDuration": "Duration",
"booksDuration": "Duration"
},
@@ -733,144 +733,148 @@
},
"whatsupdocker": {
"monitoring": "Monitoring",
- "updates": "Updates"
+ "updates": "Oppdateringer"
},
"calibreweb": {
- "books": "Books",
+ "books": "Bøker",
"authors": "Authors",
"categories": "Categories",
- "series": "Series"
+ "series": "Serie"
},
"jdownloader": {
- "downloadCount": "Queue",
- "downloadBytesRemaining": "Remaining",
+ "downloadCount": "Kø",
+ "downloadBytesRemaining": "Gjenstående",
"downloadTotalBytes": "Size",
- "downloadSpeed": "Speed"
+ "downloadSpeed": "Hastighet"
},
"kavita": {
- "seriesCount": "Series",
+ "seriesCount": "Serie",
"totalFiles": "Files"
},
"azuredevops": {
- "result": "Result",
+ "result": "Resultat",
"status": "Status",
- "buildId": "Build ID",
- "succeeded": "Succeeded",
- "notStarted": "Not Started",
- "failed": "Failed",
- "canceled": "Canceled",
- "inProgress": "In Progress",
- "totalPrs": "Total PRs",
- "myPrs": "My PRs",
- "approved": "Approved"
+ "buildId": "Produksjons ID",
+ "succeeded": "Vellykket",
+ "notStarted": "Ikke startet",
+ "failed": "Mislyktes",
+ "canceled": "Avbrutt",
+ "inProgress": "Pågående",
+ "totalPrs": "Totalt PR-er",
+ "myPrs": "Mine PR'er",
+ "approved": "Godkjent"
},
"gamedig": {
"status": "Status",
"online": "Online",
- "offline": "Offline",
- "name": "Name",
- "map": "Map",
- "currentPlayers": "Current players",
+ "offline": "Frakoblet",
+ "name": "Navn",
+ "map": "Kart",
+ "currentPlayers": "Aktuelle spillere",
"players": "Players",
- "maxPlayers": "Max players",
+ "maxPlayers": "Maks spillere",
"bots": "Bots",
"ping": "Ping"
},
"urbackup": {
"ok": "Ok",
- "errored": "Errors",
- "noRecent": "Out of Date",
- "totalUsed": "Used Storage"
+ "errored": "Feil",
+ "noRecent": "Utdatert",
+ "totalUsed": "Brukt lagringsplass"
},
"mealie": {
- "recipes": "Recipes",
- "users": "Users",
+ "recipes": "Oppskrifter",
+ "users": "Brukere",
"categories": "Categories",
- "tags": "Tags"
+ "tags": "Stikkord"
},
"openmediavault": {
- "downloading": "Downloading",
- "total": "Total",
- "running": "Running",
- "stopped": "Stopped",
- "passed": "Passed",
- "failed": "Failed"
+ "downloading": "Nedlaster",
+ "total": "Totalt",
+ "running": "Kjører",
+ "stopped": "Stoppet",
+ "passed": "Bestått",
+ "failed": "Mislyktes"
},
"openwrt": {
- "uptime": "Uptime",
- "cpuLoad": "CPU Load Avg (5m)",
+ "uptime": "Oppetid",
+ "cpuLoad": "CPU-belastning snitt (5m)",
"up": "Up",
"down": "Down",
- "bytesTx": "Transmitted",
- "bytesRx": "Received"
+ "bytesTx": "Sendt",
+ "bytesRx": "Mottatt"
},
"uptimerobot": {
"status": "Status",
- "uptime": "Uptime",
- "lastDown": "Last Downtime",
- "downDuration": "Downtime Duration",
- "sitesUp": "Sites Up",
+ "uptime": "Oppetid",
+ "lastDown": "Siste nedetid",
+ "downDuration": "Varighet på nedetid",
+ "sitesUp": "Nettsteder opp",
"sitesDown": "Sites Down",
- "paused": "Paused",
- "notyetchecked": "Not Yet Checked",
+ "paused": "Pauset",
+ "notyetchecked": "Ikke sjekket enda",
"up": "Up",
- "seemsdown": "Seems Down",
+ "seemsdown": "Virker nede",
"down": "Down",
- "unknown": "Unknown"
+ "unknown": "Ukjent"
},
"calendar": {
- "inCinemas": "In cinemas",
- "physicalRelease": "Physical release",
- "digitalRelease": "Digital release",
- "noEventsToday": "No events for today!",
- "noEventsFound": "No events found"
+ "inCinemas": "På Kino",
+ "physicalRelease": "Fysisk utslipp",
+ "digitalRelease": "Digital utgivelse",
+ "noEventsToday": "Ingen hendelser for i dag!",
+ "noEventsFound": "Ingen hendelser funnet"
},
"romm": {
- "platforms": "Platforms",
- "totalRoms": "Total ROMs"
+ "platforms": "Plattformer",
+ "totalRoms": "Totale ROM-er"
},
"netdata": {
- "warnings": "Warnings",
- "criticals": "Criticals"
+ "warnings": "Advarsler",
+ "criticals": "Kritiske"
},
"plantit": {
- "events": "Events",
- "plants": "Plants",
+ "events": "Begivenheter",
+ "plants": "Planter",
"photos": "Photos",
- "species": "Species"
+ "species": "Arter"
},
"gitea": {
- "notifications": "Notifications",
+ "notifications": "Varslinger",
"issues": "Issues",
"pulls": "Pull Requests"
},
"stash": {
- "scenes": "Scenes",
- "scenesPlayed": "Scenes Played",
- "playCount": "Total Plays",
- "playDuration": "Time Watched",
- "sceneSize": "Scenes Size",
- "sceneDuration": "Scenes Duration",
- "images": "Images",
- "imageSize": "Images Size",
- "galleries": "Galleries",
- "performers": "Performers",
+ "scenes": "Scener",
+ "scenesPlayed": "Scener avspilt",
+ "playCount": "Totalt Spillt",
+ "playDuration": "Tid Sett",
+ "sceneSize": "Scenesstørrelse",
+ "sceneDuration": "Scener Varighet",
+ "images": "Bilder",
+ "imageSize": "Bildestørrelse",
+ "galleries": "Gallerier",
+ "performers": "Utøvere",
"studios": "Studios",
- "movies": "Movies",
- "tags": "Tags",
- "oCount": "O Count"
+ "movies": "Film",
+ "tags": "Stikkord",
+ "oCount": "O antall"
},
"tandoor": {
- "users": "Users",
- "recipes": "Recipes",
- "keywords": "Keywords"
+ "users": "Brukere",
+ "recipes": "Oppskrifter",
+ "keywords": "Nøkkelord"
},
"homebox": {
- "items": "Items",
- "totalWithWarranty": "With Warranty",
- "locations": "Locations",
- "labels": "Labels",
- "users": "Users",
- "totalValue": "Total Value"
+ "items": "Enheter",
+ "totalWithWarranty": "Med garanti",
+ "locations": "Posisjon",
+ "labels": "Etiketter",
+ "users": "Brukere",
+ "totalValue": "Totalverdi"
+ },
+ "crowdsec": {
+ "alerts": "Varsler",
+ "bans": "Utestengelse"
}
}
diff --git a/public/locales/pl/common.json b/public/locales/pl/common.json
index 80b2d9ce..5c64296e 100644
--- a/public/locales/pl/common.json
+++ b/public/locales/pl/common.json
@@ -40,7 +40,7 @@
},
"resources": {
"cpu": "Procesor",
- "mem": "PAM",
+ "mem": "RAM",
"total": "Całkowite",
"free": "Wolne",
"used": "Użyte",
@@ -53,9 +53,9 @@
"users": "Użytkownicy",
"uptime": "Czas działania",
"days": "Dni",
- "wan": "Sieć WAN",
- "lan": "Sieć LAN",
- "wlan": "Sieć WLAN",
+ "wan": "WAN",
+ "lan": "LAN",
+ "wlan": "WLAN",
"devices": "Urządzenia",
"lan_devices": "Urządzenia LAN",
"wlan_devices": "Urządzenia WLAN",
@@ -64,23 +64,23 @@
"up": "CZAS",
"down": "Pobieranie",
"wait": "Proszę czekać",
- "empty_data": "Nieznany stan"
+ "empty_data": "Status podsystemu nieznany"
},
"docker": {
"rx": "Rx",
"tx": "Tx",
- "mem": "PAM",
+ "mem": "RAM",
"cpu": "Procesor",
"running": "Działa",
"offline": "Nieosiągalny",
"error": "Błąd",
"unknown": "Nieznany",
"healthy": "Zdrowy",
- "starting": "Rozpoczynanie",
- "unhealthy": "Niezdrowe",
+ "starting": "Uruchamianie",
+ "unhealthy": "Niezdrowy",
"not_found": "Nie znaleziono",
- "exited": "Zakończone",
- "partial": "Częściowe"
+ "exited": "Zakończony",
+ "partial": "Częściowy"
},
"ping": {
"error": "Błąd",
@@ -137,18 +137,18 @@
"connectionStatusUnconfigured": "Nieskonfigurowane",
"connectionStatusConnecting": "Łączenie",
"connectionStatusAuthenticating": "Uwierzytelnianie",
- "connectionStatusPendingDisconnect": "Pending Disconnect",
+ "connectionStatusPendingDisconnect": "Oczekujące rozłączenie",
"connectionStatusDisconnecting": "Rozłączanie",
"connectionStatusDisconnected": "Rozłączono",
- "connectionStatusConnected": "Połączony",
+ "connectionStatusConnected": "Connected",
"uptime": "Czas działania",
- "maxDown": "Max. Down",
- "maxUp": "Max. Up",
+ "maxDown": "Maks. Pobieranie",
+ "maxUp": "Maks. Wysyłanie",
"down": "Niedostępny",
"up": "Dostępny",
"received": "Odebrane",
"sent": "Wysłane",
- "externalIPAddress": "Ext. IP"
+ "externalIPAddress": "Pub. IP"
},
"caddy": {
"upstreams": "Upstreams",
@@ -156,12 +156,12 @@
"requests_failed": "Nieudane zapytania"
},
"changedetectionio": {
- "totalObserved": "Obserwowanych ogółem",
- "diffsDetected": "Wykryto różnic"
+ "totalObserved": "Łącznie obserwowanych",
+ "diffsDetected": "Wykrytych różnic"
},
"channelsdvrserver": {
"shows": "Seriale",
- "recordings": "Nagrywanie",
+ "recordings": "Nagrania",
"scheduled": "W kolejce",
"passes": "Przebiegi"
},
@@ -277,11 +277,11 @@
"approved": "Zaakceptowane",
"available": "Dostępne"
},
- "pialert": {
+ "netalertx": {
"total": "Całkowite",
- "connected": "Połączony",
- "new_devices": "Nowe urządzenia",
- "down_alerts": "Powiadomienia o niedostępności"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Zapytania",
@@ -395,7 +395,7 @@
"failedLoginsLast24H": "Nieudane logowania (24h)"
},
"proxmox": {
- "mem": "PAM",
+ "mem": "RAM",
"cpu": "Procesor",
"lxc": "Kontenery LXC",
"vms": "Maszyn wirtualnych"
@@ -413,7 +413,7 @@
"used": "Użyte",
"days": "d",
"hours": "g",
- "crit": "Crit",
+ "crit": "Krytyczyny",
"read": "Przeczytane",
"write": "Zapis",
"gpu": "Karta graficzna",
@@ -492,7 +492,7 @@
"updates": "Aktualizacje",
"update_available": "Dostępna aktualizacja",
"up_to_date": "Aktualny",
- "child_bridges": "Child Bridges",
+ "child_bridges": "Mostki podrzędne",
"child_bridges_status": "{{ok}}/{{total}}",
"up": "Dostępny",
"pending": "Oczekiwane",
@@ -501,12 +501,12 @@
"healthchecks": {
"new": "Nowy",
"up": "Dostępny",
- "grace": "In Grace Period",
+ "grace": "W okresie karencji",
"down": "Niedostępny",
"paused": "Zatrzymane",
"status": "Stan",
"last_ping": "Ostatni ping",
- "never": "No pings yet"
+ "never": "Brak pingów"
},
"watchtower": {
"containers_scanned": "Zeskanowane",
@@ -544,7 +544,7 @@
"hdhomerun": {
"channels": "Kanały",
"hd": "HD",
- "tunerCount": "Tuners",
+ "tunerCount": "Tunery",
"channelNumber": "Kanał",
"channelNetwork": "Sieć",
"signalStrength": "Siła",
@@ -563,7 +563,7 @@
"total": "Całkowite"
},
"peanut": {
- "battery_charge": "Battery Charge",
+ "battery_charge": "Stan baterii",
"ups_load": "Obciążenie UPS",
"ups_status": "Status UPS",
"online": "Dostępny",
@@ -576,7 +576,7 @@
},
"mikrotik": {
"cpuLoad": "Obciążenie procesora",
- "memoryUsed": "Zuyżyta pamięć",
+ "memoryUsed": "Zużyta pamięć",
"uptime": "Czas działania",
"numberOfLeases": "Dzierżawy"
},
@@ -587,8 +587,8 @@
},
"opendtu": {
"yieldDay": "Dzisiaj",
- "absolutePower": "Power",
- "relativePower": "Power %",
+ "absolutePower": "Zasilanie",
+ "relativePower": "Moc %",
"limit": "Limit"
},
"opnsense": {
@@ -605,16 +605,16 @@
},
"octoprint": {
"printer_state": "Stan",
- "temp_tool": "Tool temp",
- "temp_bed": "Bed temp",
+ "temp_tool": "Temperatura narzędzia",
+ "temp_bed": "Temp. łóżka",
"job_completion": "Ukończono"
},
"cloudflared": {
- "origin_ip": "Origin IP",
+ "origin_ip": "IP Źródła",
"status": "Stan"
},
"pfsense": {
- "load": "Load Avg",
+ "load": "Śr. Obciążenie",
"memory": "Użycie pamięci",
"wanStatus": "Status WAN",
"up": "Dostępny",
@@ -624,8 +624,8 @@
"wanIP": "WAN IP"
},
"proxmoxbackupserver": {
- "datastore_usage": "Datastore",
- "failed_tasks_24h": "Failed Tasks 24h",
+ "datastore_usage": "Magazyn danych",
+ "failed_tasks_24h": "Nieudane zadania 24h",
"cpu_usage": "Procesor",
"memory_usage": "Pamięć"
},
@@ -679,7 +679,7 @@
"dashboards": "Panel główny",
"datasources": "Źródła danych",
"totalalerts": "Wszystkie alerty",
- "alertstriggered": "Alerts Triggered"
+ "alertstriggered": "Wywołane alerty"
},
"nextcloud": {
"cpuload": "Obciążenie CPU",
@@ -687,7 +687,7 @@
"freespace": "Wolna przestrzeń",
"activeusers": "Aktywni użytkownicy",
"numfiles": "Pliki",
- "numshares": "Shared Items"
+ "numshares": "Udostępnione elementy"
},
"kopia": {
"status": "Stan",
@@ -698,7 +698,7 @@
},
"unmanic": {
"active_workers": "Aktywni pracownicy",
- "total_workers": "Total Workers",
+ "total_workers": "Wszyscy pracownicy",
"records_total": "Długość kolejki"
},
"pterodactyl": {
@@ -706,9 +706,9 @@
"nodes": "Węzły"
},
"prometheus": {
- "targets_up": "Targets Up",
- "targets_down": "Targets Down",
- "targets_total": "Total Targets"
+ "targets_up": "Cele włączone",
+ "targets_down": "Cele wyłączone",
+ "targets_total": "Wszystkich Celi"
},
"gatus": {
"up": "Działające",
@@ -727,9 +727,9 @@
"booksDuration": "Czas trwania"
},
"homeassistant": {
- "people_home": "People Home",
- "lights_on": "Lights On",
- "switches_on": "Switches On"
+ "people_home": "Dom ludzi",
+ "lights_on": "Światła włączone",
+ "switches_on": "Przełączniki włączone"
},
"whatsupdocker": {
"monitoring": "Monitoring",
@@ -756,12 +756,12 @@
"status": "Stan",
"buildId": "ID kompilacji",
"succeeded": "Ukończono",
- "notStarted": "Not Started",
+ "notStarted": "Nierozpoczęte",
"failed": "Niepowodzenie",
"canceled": "Anulowano",
"inProgress": "W trakcie",
- "totalPrs": "Total PRs",
- "myPrs": "My PRs",
+ "totalPrs": "Łącznie PRs",
+ "myPrs": "Moje PRs",
"approved": "Zaakceptowane"
},
"gamedig": {
@@ -770,7 +770,7 @@
"offline": "Nieosiągalny",
"name": "Nazwa",
"map": "Mapa",
- "currentPlayers": "Current players",
+ "currentPlayers": "Gracze online",
"players": "Gracze",
"maxPlayers": "Maksymalna ilość graczy",
"bots": "Boty",
@@ -783,7 +783,7 @@
"totalUsed": "Użyta pamięć"
},
"mealie": {
- "recipes": "Recipes",
+ "recipes": "Przepisy",
"users": "Użytkownicy",
"categories": "Kategorie",
"tags": "Tagi"
@@ -798,79 +798,83 @@
},
"openwrt": {
"uptime": "Czas działania",
- "cpuLoad": "CPU Load Avg (5m)",
+ "cpuLoad": "Śr. obciążenie CPU (5m)",
"up": "Dostępny",
"down": "Niedostępny",
- "bytesTx": "Transmitted",
+ "bytesTx": "Przesłane",
"bytesRx": "Odebrane"
},
"uptimerobot": {
"status": "Stan",
"uptime": "Czas działania",
- "lastDown": "Last Downtime",
- "downDuration": "Downtime Duration",
+ "lastDown": "Ostatni downtime",
+ "downDuration": "Długość downtime'u",
"sitesUp": "Działające",
"sitesDown": "Niedziałające",
"paused": "Zatrzymane",
- "notyetchecked": "Not Yet Checked",
+ "notyetchecked": "Nie sprawdzono",
"up": "Dostępny",
- "seemsdown": "Seems Down",
+ "seemsdown": "Możliwe, że wyłączony",
"down": "Niedostępny",
"unknown": "Nieznany"
},
"calendar": {
"inCinemas": "W kinach",
"physicalRelease": "Wydanie fizyczne",
- "digitalRelease": "Digital release",
- "noEventsToday": "No events for today!",
- "noEventsFound": "No events found"
+ "digitalRelease": "Wydanie cyfrowe",
+ "noEventsToday": "Brak wydarzeń na dziś!",
+ "noEventsFound": "Nie znaleziono wydarzeń"
},
"romm": {
"platforms": "Platformy",
- "totalRoms": "Total ROMs"
+ "totalRoms": "Łącznie ROM"
},
"netdata": {
"warnings": "Ostrzeżenia",
- "criticals": "Criticals"
+ "criticals": "Krytyczny"
},
"plantit": {
- "events": "Events",
- "plants": "Plants",
+ "events": "Wydarzenia",
+ "plants": "Rośliny",
"photos": "Zdjęcia",
- "species": "Species"
+ "species": "Gatunki"
},
"gitea": {
- "notifications": "Notifications",
+ "notifications": "Powiadomienia",
"issues": "Zgłoszenia",
- "pulls": "Pull Requests"
+ "pulls": "Żądania Pull"
},
"stash": {
- "scenes": "Scenes",
- "scenesPlayed": "Scenes Played",
- "playCount": "Total Plays",
- "playDuration": "Time Watched",
- "sceneSize": "Scenes Size",
- "sceneDuration": "Scenes Duration",
- "images": "Images",
- "imageSize": "Images Size",
- "galleries": "Galleries",
- "performers": "Performers",
- "studios": "Studios",
+ "scenes": "Sceny",
+ "scenesPlayed": "Odgrane sceny",
+ "playCount": "Łącznie odtworzone",
+ "playDuration": "Łączny czas oglądania",
+ "sceneSize": "Rozmiar scen",
+ "sceneDuration": "Czas trwania scen",
+ "images": "Obrazy",
+ "imageSize": "Rozmiar obrazów",
+ "galleries": "Galerie",
+ "performers": "Artyści",
+ "studios": "Studia",
"movies": "Filmy",
"tags": "Tagi",
- "oCount": "O Count"
+ "oCount": "O Licznik"
},
"tandoor": {
"users": "Użytkownicy",
- "recipes": "Recipes",
- "keywords": "Keywords"
+ "recipes": "Przepisy",
+ "keywords": "Słowa kluczowe"
},
"homebox": {
- "items": "Items",
- "totalWithWarranty": "With Warranty",
- "locations": "Locations",
- "labels": "Labels",
+ "items": "Elementy",
+ "totalWithWarranty": "Z gwarancją",
+ "locations": "Lokalizacje",
+ "labels": "Etykiety",
"users": "Użytkownicy",
- "totalValue": "Total Value"
+ "totalValue": "Wartość całkowita"
+ },
+ "crowdsec": {
+ "alerts": "Alarmy",
+ "bans": "Bany"
}
}
diff --git a/public/locales/pt/common.json b/public/locales/pt/common.json
index aafdd8e0..74b67f82 100644
--- a/public/locales/pt/common.json
+++ b/public/locales/pt/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Desconexão pendente",
"connectionStatusDisconnecting": "Desconectando",
"connectionStatusDisconnected": "Desconectado",
- "connectionStatusConnected": "Conectado",
+ "connectionStatusConnected": "Connected",
"uptime": "Ligado",
"maxDown": "Máx. de Descarga",
"maxUp": "Max. de Envio",
@@ -277,11 +277,11 @@
"approved": "Aprovada",
"available": "Disponível"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
- "connected": "Conectado",
- "new_devices": "Novos dispositivos",
- "down_alerts": "Alertas de Baixo"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Consultas",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Utilizadores",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alertas",
+ "bans": "Bans"
}
}
diff --git a/public/locales/pt_BR/common.json b/public/locales/pt_BR/common.json
index 9cef642f..0de066b7 100644
--- a/public/locales/pt_BR/common.json
+++ b/public/locales/pt_BR/common.json
@@ -14,7 +14,7 @@
"date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}",
"uptime": "{{value, uptime}}",
- "months": "mo",
+ "months": "M",
"days": "d",
"hours": "h",
"minutes": "m",
@@ -85,17 +85,17 @@
"ping": {
"error": "Erro",
"ping": "Tempo de resposta",
- "down": "Down",
- "up": "Up",
- "not_available": "Not Available"
+ "down": "Inativo",
+ "up": "Ativo",
+ "not_available": "Não Disponível"
},
"siteMonitor": {
- "http_status": "HTTP status",
+ "http_status": "Estado HTTP",
"error": "Erro",
- "response": "Response",
- "down": "Down",
- "up": "Up",
- "not_available": "Not Available"
+ "response": "Resposta",
+ "down": "Inativo",
+ "up": "Ativo",
+ "not_available": "Não Disponível"
},
"emby": {
"playing": "A reproduzir",
@@ -134,21 +134,21 @@
},
"fritzbox": {
"connectionStatus": "Estado",
- "connectionStatusUnconfigured": "Unconfigured",
- "connectionStatusConnecting": "Connecting",
- "connectionStatusAuthenticating": "Authenticating",
- "connectionStatusPendingDisconnect": "Pending Disconnect",
- "connectionStatusDisconnecting": "Disconnecting",
- "connectionStatusDisconnected": "Disconnected",
+ "connectionStatusUnconfigured": "Não configurado",
+ "connectionStatusConnecting": "Conectando",
+ "connectionStatusAuthenticating": "Autenticando",
+ "connectionStatusPendingDisconnect": "Desconexão Pendente",
+ "connectionStatusDisconnecting": "Desconectando",
+ "connectionStatusDisconnected": "Desconectado",
"connectionStatusConnected": "Connected",
"uptime": "Ligado",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
- "down": "Down",
- "up": "Up",
- "received": "Received",
- "sent": "Sent",
- "externalIPAddress": "Ext. IP"
+ "down": "Inativo",
+ "up": "Ativo",
+ "received": "Recebido",
+ "sent": "Enviado",
+ "externalIPAddress": "IP Externo"
},
"caddy": {
"upstreams": "Upstreams",
@@ -160,9 +160,9 @@
"diffsDetected": "Diferenças Detetadas"
},
"channelsdvrserver": {
- "shows": "Shows",
+ "shows": "Programas",
"recordings": "Gravações",
- "scheduled": "Scheduled",
+ "scheduled": "Agendado",
"passes": "Passes"
},
"tautulli": {
@@ -170,7 +170,7 @@
"transcoding": "Transcodificação",
"bitrate": "Taxa de bits",
"no_active": "Sem streams ativas",
- "plex_connection_error": "Check Plex Connection"
+ "plex_connection_error": "Verifique a conexão do Plex"
},
"omada": {
"connectedAp": "APs Ligados",
@@ -186,7 +186,7 @@
},
"plex": {
"streams": "Streams Ativas",
- "albums": "Albums",
+ "albums": "Álbuns",
"movies": "Filmes",
"tv": "Series de TV"
},
@@ -213,9 +213,9 @@
"seed": "Semente"
},
"qnap": {
- "cpuUsage": "CPU Usage",
- "memUsage": "MEM Usage",
- "systemTempC": "System Temp",
+ "cpuUsage": "Uso de CPU",
+ "memUsage": "Uso de Memória",
+ "systemTempC": "Temp. do Sistema",
"poolUsage": "Pool Usage",
"volumeUsage": "Volume Usage",
"invalid": "Invalid"
@@ -277,7 +277,7 @@
"approved": "Aprovada",
"available": "Disponível"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -494,15 +494,15 @@
"up_to_date": "Atualizado",
"child_bridges": "Pontes Filhas",
"child_bridges_status": "{{ok}}/{{total}}",
- "up": "Up",
+ "up": "Ativo",
"pending": "Pendente",
- "down": "Down"
+ "down": "Inativo"
},
"healthchecks": {
"new": "Novo",
- "up": "Up",
+ "up": "Ativo",
"grace": "Em Período Gratuito",
- "down": "Down",
+ "down": "Inativo",
"paused": "Pausado",
"status": "Estado",
"last_ping": "Ultimo Ping",
@@ -617,8 +617,8 @@
"load": "Load Avg",
"memory": "Mem Usage",
"wanStatus": "WAN Status",
- "up": "Up",
- "down": "Down",
+ "up": "Ativo",
+ "down": "Inativo",
"temp": "Temp",
"disk": "Disk Usage",
"wanIP": "WAN IP"
@@ -664,7 +664,7 @@
"wanted": "Desejada"
},
"photoprism": {
- "albums": "Albums",
+ "albums": "Álbuns",
"photos": "Fotos",
"videos": "Vídeos",
"people": "Pessoa"
@@ -799,10 +799,10 @@
"openwrt": {
"uptime": "Ligado",
"cpuLoad": "CPU Load Avg (5m)",
- "up": "Up",
- "down": "Down",
+ "up": "Ativo",
+ "down": "Inativo",
"bytesTx": "Transmitted",
- "bytesRx": "Received"
+ "bytesRx": "Recebido"
},
"uptimerobot": {
"status": "Estado",
@@ -813,9 +813,9 @@
"sitesDown": "Sites Fora do Ar",
"paused": "Pausado",
"notyetchecked": "Not Yet Checked",
- "up": "Up",
+ "up": "Ativo",
"seemsdown": "Seems Down",
- "down": "Down",
+ "down": "Inativo",
"unknown": "Desconhecido"
},
"calendar": {
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Utilizadores",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alertas",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ro/common.json b/public/locales/ro/common.json
index 987b1197..512904ff 100644
--- a/public/locales/ro/common.json
+++ b/public/locales/ro/common.json
@@ -277,7 +277,7 @@
"approved": "Aprobate",
"available": "Disponibile"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Utilizatori",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/ru/common.json b/public/locales/ru/common.json
index 81472ced..973c131f 100644
--- a/public/locales/ru/common.json
+++ b/public/locales/ru/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Ожидает отключения",
"connectionStatusDisconnecting": "Отключение",
"connectionStatusDisconnected": "Отключено",
- "connectionStatusConnected": "Подключено",
+ "connectionStatusConnected": "Connected",
"uptime": "Время работы",
"maxDown": "Макс. Загрузка",
"maxUp": "Макс. Отдача",
@@ -277,11 +277,11 @@
"approved": "Одобрено",
"available": "Доступно"
},
- "pialert": {
+ "netalertx": {
"total": "Всего",
- "connected": "Подключено",
- "new_devices": "Новые устройства",
- "down_alerts": "Оповещение о недоступности"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Запросы",
@@ -872,5 +872,9 @@
"labels": "Ярлыки",
"users": "Пользователи",
"totalValue": "Общая стоимость"
+ },
+ "crowdsec": {
+ "alerts": "Предупреждения",
+ "bans": "Bans"
}
}
diff --git a/public/locales/sk/common.json b/public/locales/sk/common.json
index 794bf9c6..b792a425 100644
--- a/public/locales/sk/common.json
+++ b/public/locales/sk/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Čakám na odpojenie",
"connectionStatusDisconnecting": "Odpájanie",
"connectionStatusDisconnected": "Odpojené",
- "connectionStatusConnected": "Pripojené",
+ "connectionStatusConnected": "Connected",
"uptime": "Prevádzka",
"maxDown": "Max. sťahovanie",
"maxUp": "Max. nahrávanie",
@@ -277,11 +277,11 @@
"approved": "Schválené",
"available": "Dostupné"
},
- "pialert": {
+ "netalertx": {
"total": "Celkovo",
- "connected": "Pripojené",
- "new_devices": "Nové zariadenia",
- "down_alerts": "Upozornenia o výpadkoch"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Dopyty",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Používatelia",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Upozornenia",
+ "bans": "Bans"
}
}
diff --git a/public/locales/sl/common.json b/public/locales/sl/common.json
index d48cd753..f732fbe1 100644
--- a/public/locales/sl/common.json
+++ b/public/locales/sl/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Čakanje na prekinitev",
"connectionStatusDisconnecting": "Prekinitev",
"connectionStatusDisconnected": "Prekinjeno",
- "connectionStatusConnected": "Povezanih",
+ "connectionStatusConnected": "Connected",
"uptime": "Čas delovanja",
"maxDown": "Maks. dol",
"maxUp": "Maks. gor",
@@ -277,11 +277,11 @@
"approved": "Odobreno",
"available": "Na voljo"
},
- "pialert": {
+ "netalertx": {
"total": "Skupaj",
- "connected": "Povezanih",
- "new_devices": "Nove naprave",
- "down_alerts": "Izključeno"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Poizvedbe",
@@ -872,5 +872,9 @@
"labels": "Oznake",
"users": "Uporabniki",
"totalValue": "Skupna vrednost"
+ },
+ "crowdsec": {
+ "alerts": "Opozorila",
+ "bans": "Prepovedi"
}
}
diff --git a/public/locales/sr/common.json b/public/locales/sr/common.json
index 86d6b20b..71ca98db 100644
--- a/public/locales/sr/common.json
+++ b/public/locales/sr/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/sv/common.json b/public/locales/sv/common.json
index 9311ed8d..9918ab64 100644
--- a/public/locales/sv/common.json
+++ b/public/locales/sv/common.json
@@ -277,7 +277,7 @@
"approved": "Godkända",
"available": "Tillgänglig"
},
- "pialert": {
+ "netalertx": {
"total": "Total",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Användare",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/te/common.json b/public/locales/te/common.json
index 90ff4f22..40bd9f7a 100644
--- a/public/locales/te/common.json
+++ b/public/locales/te/common.json
@@ -277,7 +277,7 @@
"approved": "ఆమోదించబడింది",
"available": "అందుబాటులో వున్నవి"
},
- "pialert": {
+ "netalertx": {
"total": "మొత్తం",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "వినియోగదారులు",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/th/common.json b/public/locales/th/common.json
index 29b5b8c1..9bb8ee9b 100644
--- a/public/locales/th/common.json
+++ b/public/locales/th/common.json
@@ -277,7 +277,7 @@
"approved": "Approved",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "ทั้งหมด",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "ผู้ใช้",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/tr/common.json b/public/locales/tr/common.json
index 98960ac1..9d284786 100644
--- a/public/locales/tr/common.json
+++ b/public/locales/tr/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Bağlantının Kesilmesi Bekleniyor",
"connectionStatusDisconnecting": "Bağlantı kesiliyor...",
"connectionStatusDisconnected": "Bağlantı kesildi",
- "connectionStatusConnected": "Bağlandı",
+ "connectionStatusConnected": "Connected",
"uptime": "Çalışma Süresi",
"maxDown": "Max. Indirme",
"maxUp": "Max. Gönderme",
@@ -277,11 +277,11 @@
"approved": "Onaylı",
"available": "Kullanılabilir"
},
- "pialert": {
+ "netalertx": {
"total": "Toplam",
- "connected": "Bağlandı",
- "new_devices": "Yeni Cihazlar",
- "down_alerts": "Düşme Uyarıları"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Sorgular",
@@ -872,5 +872,9 @@
"labels": "Etiketler",
"users": "Kullanıcılar",
"totalValue": "Toplam Değer"
+ },
+ "crowdsec": {
+ "alerts": "Alarmlar",
+ "bans": "Bans"
}
}
diff --git a/public/locales/uk/common.json b/public/locales/uk/common.json
index 1a69825c..55e8c07e 100644
--- a/public/locales/uk/common.json
+++ b/public/locales/uk/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "Pending Disconnect",
"connectionStatusDisconnecting": "Disconnecting",
"connectionStatusDisconnected": "Disconnected",
- "connectionStatusConnected": "Підключено",
+ "connectionStatusConnected": "Connected",
"uptime": "Час роботи",
"maxDown": "Max. Down",
"maxUp": "Max. Up",
@@ -277,11 +277,11 @@
"approved": "Затверджено",
"available": "Доступно"
},
- "pialert": {
+ "netalertx": {
"total": "Усього",
- "connected": "Підключено",
- "new_devices": "Нові пристрої",
- "down_alerts": "Сповіщення про збій"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "Запити",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Користувачі",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Оповіщення",
+ "bans": "Bans"
}
}
diff --git a/public/locales/vi/common.json b/public/locales/vi/common.json
index 23827ddc..5299c54d 100644
--- a/public/locales/vi/common.json
+++ b/public/locales/vi/common.json
@@ -277,7 +277,7 @@
"approved": "Đã duyệt",
"available": "Available"
},
- "pialert": {
+ "netalertx": {
"total": "Tổng",
"connected": "Connected",
"new_devices": "New Devices",
@@ -872,5 +872,9 @@
"labels": "Labels",
"users": "Users",
"totalValue": "Total Value"
+ },
+ "crowdsec": {
+ "alerts": "Alerts",
+ "bans": "Bans"
}
}
diff --git a/public/locales/yue/common.json b/public/locales/yue/common.json
index 3b32c081..d7a9242c 100644
--- a/public/locales/yue/common.json
+++ b/public/locales/yue/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "待辦的斷開",
"connectionStatusDisconnecting": "正在中斷連線",
"connectionStatusDisconnected": "連接已中斷",
- "connectionStatusConnected": "已連線",
+ "connectionStatusConnected": "Connected",
"uptime": "運行時間",
"maxDown": "最大下載速率",
"maxUp": "最大上傳速率",
@@ -277,11 +277,11 @@
"approved": "批准",
"available": "可用"
},
- "pialert": {
+ "netalertx": {
"total": "全部",
- "connected": "已連線",
- "new_devices": "新裝置",
- "down_alerts": "離線警告"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "查詢",
@@ -858,7 +858,7 @@
"studios": "工作室",
"movies": "電影",
"tags": "標籤",
- "oCount": "O Count"
+ "oCount": "0 個"
},
"tandoor": {
"users": "使用者",
@@ -867,10 +867,14 @@
},
"homebox": {
"items": "項目",
- "totalWithWarranty": "With Warranty",
+ "totalWithWarranty": "有保証",
"locations": "位置",
"labels": "標籤",
"users": "使用者",
"totalValue": "總共"
+ },
+ "crowdsec": {
+ "alerts": "警示",
+ "bans": "禁止"
}
}
diff --git a/public/locales/zh-Hans/common.json b/public/locales/zh-Hans/common.json
index 3957ccc8..5ae9de40 100644
--- a/public/locales/zh-Hans/common.json
+++ b/public/locales/zh-Hans/common.json
@@ -54,13 +54,13 @@
"uptime": "运行时间",
"days": "天",
"wan": "WAN",
- "lan": "LAN",
- "wlan": "WLAN",
+ "lan": "局域网",
+ "wlan": "无线局域网",
"devices": "设备",
- "lan_devices": "LAN设备",
+ "lan_devices": "有线设备",
"wlan_devices": "WLAN 设备",
- "lan_users": "LAN 用户",
- "wlan_users": "WLAN 用户",
+ "lan_users": "有线用户",
+ "wlan_users": "无线用户",
"up": "运行时间",
"down": "离线",
"wait": "请稍候",
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "等待断开连接",
"connectionStatusDisconnecting": "正在断开连接",
"connectionStatusDisconnected": "未连接",
- "connectionStatusConnected": "已连接",
+ "connectionStatusConnected": "Connected",
"uptime": "运行时间",
"maxDown": "最大下载速度",
"maxUp": "",
@@ -277,11 +277,11 @@
"approved": "已批准",
"available": "可用"
},
- "pialert": {
+ "netalertx": {
"total": "总计",
- "connected": "已连接",
- "new_devices": "新设备",
- "down_alerts": "离线警报"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "查询",
@@ -858,7 +858,7 @@
"studios": "工作室",
"movies": "电影",
"tags": "标签",
- "oCount": "O Count"
+ "oCount": "O 个"
},
"tandoor": {
"users": "用户数",
@@ -866,11 +866,15 @@
"keywords": "关键词"
},
"homebox": {
- "items": "Items",
- "totalWithWarranty": "With Warranty",
- "locations": "Locations",
- "labels": "Labels",
+ "items": "条目",
+ "totalWithWarranty": "有保证",
+ "locations": "位置",
+ "labels": "标签",
"users": "用户数",
- "totalValue": "Total Value"
+ "totalValue": "总计"
+ },
+ "crowdsec": {
+ "alerts": "警告",
+ "bans": "禁用"
}
}
diff --git a/public/locales/zh-Hant/common.json b/public/locales/zh-Hant/common.json
index 2ee4e831..38b7ea42 100644
--- a/public/locales/zh-Hant/common.json
+++ b/public/locales/zh-Hant/common.json
@@ -140,7 +140,7 @@
"connectionStatusPendingDisconnect": "待辦的斷開",
"connectionStatusDisconnecting": "正在中斷連線",
"connectionStatusDisconnected": "連接已中斷",
- "connectionStatusConnected": "已連線",
+ "connectionStatusConnected": "Connected",
"uptime": "運行時間",
"maxDown": "最大下載速率",
"maxUp": "最大上傳速率",
@@ -277,11 +277,11 @@
"approved": "已核准",
"available": "可觀看"
},
- "pialert": {
+ "netalertx": {
"total": "全部",
- "connected": "已連線",
- "new_devices": "新裝置",
- "down_alerts": "離線警告"
+ "connected": "Connected",
+ "new_devices": "New Devices",
+ "down_alerts": "Down Alerts"
},
"pihole": {
"queries": "查詢",
@@ -858,7 +858,7 @@
"studios": "工作室",
"movies": "電影",
"tags": "標籤",
- "oCount": "O Count"
+ "oCount": "0 個"
},
"tandoor": {
"users": "用戶",
@@ -867,10 +867,14 @@
},
"homebox": {
"items": "項目",
- "totalWithWarranty": "With Warranty",
+ "totalWithWarranty": "有保証",
"locations": "位置",
"labels": "標籤",
"users": "用戶",
"totalValue": "總共"
+ },
+ "crowdsec": {
+ "alerts": "警示",
+ "bans": "禁止"
}
}
From c18fd02c8ec2af0a5224da310a0e5ea6a54830f8 Mon Sep 17 00:00:00 2001
From: shamoon <4887959+shamoon@users.noreply.github.com>
Date: Mon, 8 Apr 2024 15:19:35 -0700
Subject: [PATCH 069/136] Fix typo in crowdsec docs
---
docs/widgets/services/crowdsec.md | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/docs/widgets/services/crowdsec.md b/docs/widgets/services/crowdsec.md
index 76b8efaa..da15a478 100644
--- a/docs/widgets/services/crowdsec.md
+++ b/docs/widgets/services/crowdsec.md
@@ -15,5 +15,5 @@ widget:
type: crowdsec
url: http://crowdsechostorip:port
username: localhost # machine_id in crowdsec
- passowrd: password
+ password: password
```
From bfd392026dbf8b4296aa6193d2e99e718e456ece Mon Sep 17 00:00:00 2001
From: brikim
Date: Fri, 12 Apr 2024 22:33:40 -0500
Subject: [PATCH 070/136] Enhancement: option to show user for Tautulli and
Emby/Jellyfin widgets (#3287)
---------
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
---
docs/widgets/services/emby.md | 1 +
docs/widgets/services/plex-tautulli.md | 1 +
src/utils/config/service-helpers.js | 11 +++++++++++
src/widgets/emby/component.jsx | 11 +++++++++--
src/widgets/tautulli/component.jsx | 25 +++++++++++++++++--------
5 files changed, 39 insertions(+), 10 deletions(-)
diff --git a/docs/widgets/services/emby.md b/docs/widgets/services/emby.md
index f262bfc6..1d70fdf3 100644
--- a/docs/widgets/services/emby.md
+++ b/docs/widgets/services/emby.md
@@ -16,4 +16,5 @@ widget:
key: apikeyapikeyapikeyapikeyapikey
enableBlocks: true # optional, defaults to false
enableNowPlaying: true # optional, defaults to true
+ enableUser: true # optional, defaults to false
```
diff --git a/docs/widgets/services/plex-tautulli.md b/docs/widgets/services/plex-tautulli.md
index b88f6eeb..cce45fc3 100644
--- a/docs/widgets/services/plex-tautulli.md
+++ b/docs/widgets/services/plex-tautulli.md
@@ -14,4 +14,5 @@ widget:
type: tautulli
url: http://tautulli.host.or.ip
key: apikeyapikeyapikeyapikeyapikey
+ enableUser: true # optional, defaults to false
```
diff --git a/src/utils/config/service-helpers.js b/src/utils/config/service-helpers.js
index d6552253..7fb81088 100644
--- a/src/utils/config/service-helpers.js
+++ b/src/utils/config/service-helpers.js
@@ -393,6 +393,9 @@ export function cleanServiceGroups(groups) {
enableBlocks,
enableNowPlaying,
+ // emby, jellyfin, tautulli
+ enableUser,
+
// glances, pihole
version,
@@ -517,6 +520,14 @@ export function cleanServiceGroups(groups) {
if (["emby", "jellyfin"].includes(type)) {
if (enableBlocks !== undefined) cleanedService.widget.enableBlocks = JSON.parse(enableBlocks);
if (enableNowPlaying !== undefined) cleanedService.widget.enableNowPlaying = JSON.parse(enableNowPlaying);
+ if (enableUser !== undefined) {
+ cleanedService.widget.enableUser = !!JSON.parse(enableUser);
+ }
+ }
+ if (["tautulli"].includes(type)) {
+ if (enableUser !== undefined) {
+ cleanedService.widget.enableUser = !!JSON.parse(enableUser);
+ }
}
if (["sonarr", "radarr"].includes(type)) {
if (enableQueue !== undefined) cleanedService.widget.enableQueue = JSON.parse(enableQueue);
diff --git a/src/widgets/emby/component.jsx b/src/widgets/emby/component.jsx
index 89fd44c3..f11a689d 100644
--- a/src/widgets/emby/component.jsx
+++ b/src/widgets/emby/component.jsx
@@ -27,10 +27,11 @@ function ticksToString(ticks) {
return parts.map((part) => part.toString().padStart(2, "0")).join(":");
}
-function SingleSessionEntry({ playCommand, session }) {
+function SingleSessionEntry({ playCommand, session, enableUser }) {
const {
NowPlayingItem: { Name, SeriesName },
PlayState: { PositionTicks, IsPaused, IsMuted },
+ UserName,
} = session;
const RunTimeTicks =
@@ -49,6 +50,7 @@ function SingleSessionEntry({ playCommand, session }) {
{Name}
{SeriesName && ` - ${SeriesName}`}
+ {enableUser && ` (${UserName})`}