mirror of
https://github.com/gethomepage/homepage.git
synced 2025-12-05 21:47:48 +01:00
Compare commits
33 Commits
v1.4.1
...
44405b4aae
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
44405b4aae | ||
|
|
842cec2fee | ||
|
|
c6ad937619 | ||
|
|
a6ab095ff9 | ||
|
|
9a085bcb17 | ||
|
|
6d7be1c7f2 | ||
|
|
25cd51cee9 | ||
|
|
495de204d1 | ||
|
|
8e5f4d55c9 | ||
|
|
184fd65c76 | ||
|
|
15817f9b27 | ||
|
|
79671ac30e | ||
|
|
1d5db612fd | ||
|
|
d30016304b | ||
|
|
f0fd125e37 | ||
|
|
9ed4b85d5a | ||
|
|
f607d806d0 | ||
|
|
c0ddb5f816 | ||
|
|
fc563532e1 | ||
|
|
98248903c6 | ||
|
|
5870111d11 | ||
|
|
bb23c25690 | ||
|
|
4084c8dafc | ||
|
|
cb1dde1b79 | ||
|
|
1691711a52 | ||
|
|
b5d8f6c01c | ||
|
|
db86b5408a | ||
|
|
4be2c2868b | ||
|
|
c6197a9f92 | ||
|
|
dd861d7d1c | ||
|
|
e65f8c46f9 | ||
|
|
082e1316c1 | ||
|
|
a4b5e72d82 |
2
.github/workflows/crowdin.yml
vendored
2
.github/workflows/crowdin.yml
vendored
@@ -17,7 +17,7 @@ jobs:
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
uses: actions/checkout@v5
|
||||
- name: crowdin action
|
||||
uses: crowdin/github-action@v2
|
||||
with:
|
||||
|
||||
4
.github/workflows/docker-publish.yml
vendored
4
.github/workflows/docker-publish.yml
vendored
@@ -22,7 +22,7 @@ jobs:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
uses: actions/checkout@v5
|
||||
|
||||
- name: Install python
|
||||
uses: actions/setup-python@v5
|
||||
@@ -61,7 +61,7 @@ jobs:
|
||||
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
uses: actions/checkout@v5
|
||||
|
||||
- name: Extract Docker metadata
|
||||
id: meta
|
||||
|
||||
6
.github/workflows/docs-publish.yml
vendored
6
.github/workflows/docs-publish.yml
vendored
@@ -17,7 +17,7 @@ jobs:
|
||||
runs-on: ubuntu-22.04
|
||||
steps:
|
||||
- name: Checkout repository
|
||||
uses: actions/checkout@v4
|
||||
uses: actions/checkout@v5
|
||||
- name: Install python
|
||||
uses: actions/setup-python@v5
|
||||
with:
|
||||
@@ -32,7 +32,7 @@ jobs:
|
||||
needs:
|
||||
- pre-commit
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@v5
|
||||
- uses: actions/setup-python@v5
|
||||
with:
|
||||
python-version: 3.x
|
||||
@@ -54,7 +54,7 @@ jobs:
|
||||
needs:
|
||||
- pre-commit
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
- uses: actions/checkout@v5
|
||||
- name: Configure Git Credentials
|
||||
run: |
|
||||
git config user.name github-actions[bot]
|
||||
|
||||
4
.github/workflows/repo-maintenance.yml
vendored
4
.github/workflows/repo-maintenance.yml
vendored
@@ -212,9 +212,9 @@ jobs:
|
||||
}
|
||||
|
||||
const CUTOFF_1_DAYS = 180;
|
||||
const CUTOFF_1_COUNT = 10;
|
||||
const CUTOFF_1_COUNT = 20;
|
||||
const CUTOFF_2_DAYS = 365;
|
||||
const CUTOFF_2_COUNT = 20;
|
||||
const CUTOFF_2_COUNT = 40;
|
||||
|
||||
const cutoff1Date = new Date();
|
||||
cutoff1Date.setDate(cutoff1Date.getDate() - CUTOFF_1_DAYS);
|
||||
|
||||
@@ -63,7 +63,7 @@ The homepage team appreciates all effort and interest from the community in fili
|
||||
- Issues, pull requests and discussions that are closed will be locked after 30 days of inactivity.
|
||||
- Discussions with a marked answer will be automatically closed.
|
||||
- Discussions in the 'General' or 'Support' categories will be closed after 180 days of inactivity.
|
||||
- Feature requests that do not meet the following thresholds will be closed: 10 "up-votes" after 180 days of inactivity or 20 "up-votes" after 365 days.
|
||||
- Feature requests that do not meet the following thresholds will be closed: 20 "up-votes" after 180 days of inactivity or 40 "up-votes" after 365 days.
|
||||
|
||||
In all cases, threads can be re-opened by project maintainers and, of course, users can always create a new discussion for related concerns.
|
||||
Finally, remember that all information remains searchable and 'closed' feature requests can still serve as inspiration for new features.
|
||||
|
||||
@@ -264,7 +264,7 @@ fullWidth: true
|
||||
|
||||
### Maximum Group Columns
|
||||
|
||||
You can set the maximum number of columns of groups on larger screen sizes (note this is only for groups with the default `style: columns`, not groups with `stle: row`) by adding:
|
||||
You can set the maximum number of columns of groups on larger screen sizes (note this is only for groups with the default `style: columns`, not groups with `style: row`) by adding:
|
||||
|
||||
```yaml
|
||||
maxGroupColumns: 8 # default is 4 for services, 6 for bookmarks, max 8
|
||||
|
||||
@@ -17,9 +17,15 @@ The account you made the API token for also needs the following **Assigned globa
|
||||
|
||||
Allowed fields: `["users", "loginsLast24H", "failedLoginsLast24H"]`.
|
||||
|
||||
| Authentik Version | Homepage Widget Version |
|
||||
| ----------------- | ----------------------- |
|
||||
| < 2025.8.0 | 1 (default) |
|
||||
| >= 2025.8.0 | 2 |
|
||||
|
||||
```yaml
|
||||
widget:
|
||||
type: authentik
|
||||
url: http://authentik.host.or.ip:port
|
||||
key: api_token
|
||||
version: 2 # optional, default is 1
|
||||
```
|
||||
|
||||
@@ -139,10 +139,12 @@ You can also find a list of all available service widgets in the sidebar navigat
|
||||
- [TubeArchivist](tubearchivist.md)
|
||||
- [UniFi Controller](unifi-controller.md)
|
||||
- [Unmanic](unmanic.md)
|
||||
- [Unraid](unraid.md)
|
||||
- [Uptime Kuma](uptime-kuma.md)
|
||||
- [UptimeRobot](uptimerobot.md)
|
||||
- [UrBackup](urbackup.md)
|
||||
- [Vikunja](vikunja.md)
|
||||
- [Wallos](wallos.md)
|
||||
- [Watchtower](watchtower.md)
|
||||
- [WGEasy](wgeasy.md)
|
||||
- [WhatsUpDocker](whatsupdocker.md)
|
||||
|
||||
@@ -9,6 +9,8 @@ This widget is compatible with [TriliumNext](https://github.com/TriliumNext/Note
|
||||
|
||||
Find (or create) your ETAPI key under `Options > ETAPI > Create new ETAPI token`.
|
||||
|
||||
Allowed fields: `["version", "notesCount", "dbSize"]`
|
||||
|
||||
```yaml
|
||||
widget:
|
||||
type: trilium
|
||||
|
||||
28
docs/widgets/services/unraid.md
Normal file
28
docs/widgets/services/unraid.md
Normal file
@@ -0,0 +1,28 @@
|
||||
---
|
||||
title: Unraid
|
||||
description: Unraid Widget Configuration
|
||||
---
|
||||
|
||||
Learn more about [Unraid](https://unraid.net/).
|
||||
|
||||
The Unraid widget allows you to monitor the resources of an Unraid server.
|
||||
|
||||
**Minimum Requirements:**
|
||||
|
||||
- Unraid 7.2 -or- Unraid Connect plugin 2025.08.19.1850
|
||||
- API key with the **GUEST** (read only) role: [Managing API Keys](https://docs.unraid.net/go/managing-api-keys)
|
||||
|
||||
The widget can display metrics for selected Unraid pools. If using one of the "pool" fields, you must also add the pool name to the settings.
|
||||
|
||||
**Allowed fields:** `["cpu","memoryPercent","memoryAvailable","memoryUsed","notifications","arrayFreeSpace","arrayUsedSpace","arrayUsedPercent","status","pool1UsedSpace","pool1FreeSpace","pool1UsedPercent","pool2UsedSpace","pool2FreeSpace","pool2UsedPercent","pool3UsedSpace","pool3FreeSpace","pool3UsedPercent","pool4UsedSpace","pool4FreeSpace","pool4UsedPercent"]`
|
||||
|
||||
```yaml
|
||||
widget:
|
||||
type: unraid
|
||||
url: https://unraid.host.or.ip
|
||||
key: api-key
|
||||
pool1: pool1name # required only if using pool1 fields
|
||||
pool2: pool2name # required only if using pool2 fields
|
||||
pool3: pool3name # required only if using pool3 fields
|
||||
pool4: pool4name # required only if using pool4 fields
|
||||
```
|
||||
@@ -165,10 +165,12 @@ nav:
|
||||
- widgets/services/tubearchivist.md
|
||||
- widgets/services/unifi-controller.md
|
||||
- widgets/services/unmanic.md
|
||||
- widgets/services/unraid.md
|
||||
- widgets/services/uptime-kuma.md
|
||||
- widgets/services/uptimerobot.md
|
||||
- widgets/services/urbackup.md
|
||||
- widgets/services/vikunja.md
|
||||
- widgets/services/wallos.md
|
||||
- widgets/services/watchtower.md
|
||||
- widgets/services/wgeasy.md
|
||||
- widgets/services/whatsupdocker.md
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "homepage",
|
||||
"version": "1.4.1",
|
||||
"version": "1.4.6",
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"preinstall": "npx only-allow pnpm",
|
||||
@@ -72,6 +72,7 @@
|
||||
},
|
||||
"pnpm": {
|
||||
"onlyBuiltDependencies": [
|
||||
"osx-temperature-sensor",
|
||||
"sharp"
|
||||
]
|
||||
}
|
||||
|
||||
@@ -1083,5 +1083,27 @@
|
||||
"nextMonthlyCost": "Next Month",
|
||||
"previousMonthlyCost": "Prev. Month",
|
||||
"nextRenewingSubscription": "Next Payment"
|
||||
},
|
||||
"unraid": {
|
||||
"STARTED": "Started",
|
||||
"STOPPED": "Stopped",
|
||||
"NEW_ARRAY": "New Array",
|
||||
"RECON_DISK": "Reconstructing Disk",
|
||||
"DISABLE_DISK": "Disk Disabled",
|
||||
"SWAP_DSBL": "Swap Disable",
|
||||
"INVALID_EXPANSION": "Invalid Expansion",
|
||||
"PARITY_NOT_BIGGEST": "Parity Not Biggest",
|
||||
"TOO_MANY_MISSING_DISKS": "Too Many Missing Disks",
|
||||
"NEW_DISK_TOO_SMALL": "New Disk Too Small",
|
||||
"NO_DATA_DISKS": "No Data Disks",
|
||||
"notifications": "Notifications",
|
||||
"status": "Status",
|
||||
"cpu": "CPU",
|
||||
"memoryUsed": "Memory Used",
|
||||
"memoryAvailable": "Memory Available",
|
||||
"arrayUsed": "Array Used",
|
||||
"arrayFree": "Array Free",
|
||||
"poolUsed": "{{pool}} Used",
|
||||
"poolFree": "{{pool}} Free"
|
||||
}
|
||||
}
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -30,7 +30,7 @@
|
||||
"response_data": "Données de réponse"
|
||||
},
|
||||
"weather": {
|
||||
"current": "Localisation actuelle",
|
||||
"current": "Emplacement actuel",
|
||||
"allow": "Cliquez pour autoriser",
|
||||
"updating": "Mise à jour",
|
||||
"wait": "Veuillez patienter"
|
||||
@@ -47,7 +47,7 @@
|
||||
"load": "Charge",
|
||||
"temp": "Température",
|
||||
"max": "Max",
|
||||
"uptime": "Démarré depuis"
|
||||
"uptime": "Actif"
|
||||
},
|
||||
"unifi": {
|
||||
"users": "Utilisateurs",
|
||||
@@ -1073,15 +1073,15 @@
|
||||
"containers": "Conteneurs"
|
||||
},
|
||||
"filebrowser": {
|
||||
"available": "Available",
|
||||
"used": "Used",
|
||||
"available": "Disponible",
|
||||
"used": "Utilisé",
|
||||
"total": "Total"
|
||||
},
|
||||
"wallos": {
|
||||
"activeSubscriptions": "Subscriptions",
|
||||
"thisMonthlyCost": "This Month",
|
||||
"nextMonthlyCost": "Next Month",
|
||||
"previousMonthlyCost": "Prev. Month",
|
||||
"nextRenewingSubscription": "Next Payment"
|
||||
"activeSubscriptions": "Abonnements",
|
||||
"thisMonthlyCost": "Ce mois",
|
||||
"nextMonthlyCost": "Mois prochain",
|
||||
"previousMonthlyCost": "Mois précédent",
|
||||
"nextRenewingSubscription": "Prochain paiement"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -451,7 +451,7 @@
|
||||
"crit": "Krytyczyny",
|
||||
"read": "Read",
|
||||
"write": "Zapis",
|
||||
"gpu": "Karta graficzna",
|
||||
"gpu": "GPU",
|
||||
"mem": "Pamięć",
|
||||
"swap": "Swap"
|
||||
},
|
||||
|
||||
@@ -212,7 +212,7 @@
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"seed": "Semear"
|
||||
},
|
||||
"qnap": {
|
||||
"cpuUsage": "Utilização do CPU",
|
||||
@@ -223,39 +223,39 @@
|
||||
"invalid": "Inválido"
|
||||
},
|
||||
"deluge": {
|
||||
"download": "Download",
|
||||
"download": "Baixar",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"seed": "Semear"
|
||||
},
|
||||
"develancacheui": {
|
||||
"cachehitbytes": "‘Bytes’ de Acerto na Memória transitória",
|
||||
"cachemissbytes": "‘Bytes’ de Falha de Memória transitória"
|
||||
},
|
||||
"downloadstation": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"download": "Baixar",
|
||||
"upload": "Envio de Dados",
|
||||
"leech": "Sanguessuga",
|
||||
"seed": "Semear"
|
||||
},
|
||||
"sonarr": {
|
||||
"wanted": "Desejados",
|
||||
"queued": "Em fila de espera",
|
||||
"series": "Series",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"series": "Séries",
|
||||
"queue": "Fila",
|
||||
"unknown": "Desconhecido"
|
||||
},
|
||||
"radarr": {
|
||||
"wanted": "Wanted",
|
||||
"wanted": "Desejado",
|
||||
"missing": "Em falta",
|
||||
"queued": "Queued",
|
||||
"movies": "Movies",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"queued": "Na Fila",
|
||||
"movies": "Filmes",
|
||||
"queue": "Fila",
|
||||
"unknown": "Desconhecido"
|
||||
},
|
||||
"lidarr": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"wanted": "Desejado",
|
||||
"queued": "Na Fila",
|
||||
"artists": "Artistas"
|
||||
},
|
||||
"readarr": {
|
||||
|
||||
@@ -241,7 +241,7 @@
|
||||
"sonarr": {
|
||||
"wanted": "Розыск",
|
||||
"queued": "В очереди",
|
||||
"series": "Серии",
|
||||
"series": "Сериалы",
|
||||
"queue": "Очередь",
|
||||
"unknown": "Неизвестно"
|
||||
},
|
||||
|
||||
@@ -61,9 +61,9 @@
|
||||
"wlan_devices": "Zariadenia WLAN",
|
||||
"lan_users": "Použ. LAN",
|
||||
"wlan_users": "Použ. WLAN",
|
||||
"up": "UP",
|
||||
"up": "BEŽÍ",
|
||||
"down": "NEBEŽÍ",
|
||||
"wait": "Please wait",
|
||||
"wait": "Čakajte, prosím",
|
||||
"empty_data": "Stav podsystému neznámy"
|
||||
},
|
||||
"docker": {
|
||||
@@ -94,8 +94,8 @@
|
||||
"error": "Chyba",
|
||||
"response": "Odpoveď",
|
||||
"down": "Down",
|
||||
"up": "Up",
|
||||
"not_available": "Not Available"
|
||||
"up": "Beží",
|
||||
"not_available": "Nedostupné"
|
||||
},
|
||||
"emby": {
|
||||
"playing": "Prehrávané",
|
||||
@@ -112,7 +112,7 @@
|
||||
"offline_alt": "Offline",
|
||||
"online": "Online",
|
||||
"total": "Celkom",
|
||||
"unknown": "Unknown"
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"evcc": {
|
||||
"pv_power": "Produkcia",
|
||||
@@ -141,11 +141,11 @@
|
||||
"connectionStatusDisconnecting": "Odpájanie",
|
||||
"connectionStatusDisconnected": "Odpojené",
|
||||
"connectionStatusConnected": "Pripojené",
|
||||
"uptime": "Uptime",
|
||||
"uptime": "Dostupnosť",
|
||||
"maxDown": "Max. sťahovanie",
|
||||
"maxUp": "Max. nahrávanie",
|
||||
"down": "Down",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"received": "Prijaté",
|
||||
"sent": "Odoslané",
|
||||
"externalIPAddress": "Ext. IP",
|
||||
@@ -189,7 +189,7 @@
|
||||
"plex": {
|
||||
"streams": "Aktívne vysielanie",
|
||||
"albums": "Albumy",
|
||||
"movies": "Movies",
|
||||
"movies": "Filmov",
|
||||
"tv": "Seriály"
|
||||
},
|
||||
"sabnzbd": {
|
||||
@@ -199,18 +199,18 @@
|
||||
},
|
||||
"rutorrent": {
|
||||
"active": "Aktívne",
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"download": "Download"
|
||||
},
|
||||
"transmission": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
},
|
||||
"qbittorrent": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
},
|
||||
@@ -224,7 +224,7 @@
|
||||
},
|
||||
"deluge": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
},
|
||||
@@ -234,7 +234,7 @@
|
||||
},
|
||||
"downloadstation": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
},
|
||||
@@ -242,25 +242,25 @@
|
||||
"wanted": "Žiadané",
|
||||
"queued": "V poradí",
|
||||
"series": "Series",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"queue": "Poradie",
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"radarr": {
|
||||
"wanted": "Wanted",
|
||||
"missing": "Chýbajúce",
|
||||
"queued": "Queued",
|
||||
"movies": "Movies",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"queued": "V poradí",
|
||||
"movies": "Filmov",
|
||||
"queue": "Poradie",
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"lidarr": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"queued": "V poradí",
|
||||
"artists": "Interpreti"
|
||||
},
|
||||
"readarr": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"queued": "V poradí",
|
||||
"books": "Knihy"
|
||||
},
|
||||
"bazarr": {
|
||||
@@ -273,19 +273,19 @@
|
||||
"available": "Dostupné"
|
||||
},
|
||||
"jellyseerr": {
|
||||
"pending": "Pending",
|
||||
"approved": "Approved",
|
||||
"available": "Available"
|
||||
"pending": "Čakajúce",
|
||||
"approved": "Schválené",
|
||||
"available": "Dostupné"
|
||||
},
|
||||
"overseerr": {
|
||||
"pending": "Pending",
|
||||
"pending": "Čakajúce",
|
||||
"processing": "Spracovávané",
|
||||
"approved": "Approved",
|
||||
"available": "Available"
|
||||
"approved": "Schválené",
|
||||
"available": "Dostupné"
|
||||
},
|
||||
"netalertx": {
|
||||
"total": "Total",
|
||||
"connected": "Connected",
|
||||
"total": "Celkom",
|
||||
"connected": "Pripojené",
|
||||
"new_devices": "Nové zariadenia",
|
||||
"down_alerts": "Upozornenia o výpadkoch"
|
||||
},
|
||||
@@ -296,26 +296,26 @@
|
||||
"gravity": "Gravity"
|
||||
},
|
||||
"adguard": {
|
||||
"queries": "Queries",
|
||||
"blocked": "Blocked",
|
||||
"queries": "Požiadaviek",
|
||||
"blocked": "Blokované",
|
||||
"filtered": "Filtrované",
|
||||
"latency": "Odozva"
|
||||
},
|
||||
"speedtest": {
|
||||
"upload": "Upload",
|
||||
"upload": "Nahrávanie",
|
||||
"download": "Download",
|
||||
"ping": "Ping"
|
||||
"ping": "Odozva"
|
||||
},
|
||||
"portainer": {
|
||||
"running": "Running",
|
||||
"running": "Beží",
|
||||
"stopped": "Zastavené",
|
||||
"total": "Total"
|
||||
"total": "Celkom"
|
||||
},
|
||||
"suwayomi": {
|
||||
"download": "Downloaded",
|
||||
"nondownload": "Non-Downloaded",
|
||||
"read": "Read",
|
||||
"unread": "Unread",
|
||||
"unread": "Neprečítané",
|
||||
"downloadedread": "Downloaded & Read",
|
||||
"downloadedunread": "Downloaded & Unread",
|
||||
"nondownloadedread": "Non-Downloaded & Read",
|
||||
@@ -336,7 +336,7 @@
|
||||
"ago": "Pred {{value}}"
|
||||
},
|
||||
"technitium": {
|
||||
"totalQueries": "Queries",
|
||||
"totalQueries": "Požiadaviek",
|
||||
"totalNoError": "Success",
|
||||
"totalServerFailure": "Failures",
|
||||
"totalNxDomain": "NX Domains",
|
||||
@@ -344,12 +344,12 @@
|
||||
"totalAuthoritative": "Authoritative",
|
||||
"totalRecursive": "Recursive",
|
||||
"totalCached": "Cached",
|
||||
"totalBlocked": "Blocked",
|
||||
"totalBlocked": "Blokované",
|
||||
"totalDropped": "Dropped",
|
||||
"totalClients": "Klienti"
|
||||
},
|
||||
"tdarr": {
|
||||
"queue": "Queue",
|
||||
"queue": "Poradie",
|
||||
"processed": "Spracované",
|
||||
"errored": "Chybné",
|
||||
"saved": "Uložené"
|
||||
@@ -360,10 +360,10 @@
|
||||
"middleware": "Midlvér"
|
||||
},
|
||||
"trilium": {
|
||||
"version": "Version",
|
||||
"version": "Verzia",
|
||||
"notesCount": "Notes",
|
||||
"dbSize": "Database Size",
|
||||
"unknown": "Unknown"
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"navidrome": {
|
||||
"nothing_streaming": "No Active Streams",
|
||||
@@ -372,7 +372,7 @@
|
||||
"npm": {
|
||||
"enabled": "Povolené",
|
||||
"disabled": "Zakázané",
|
||||
"total": "Total"
|
||||
"total": "Celkom"
|
||||
},
|
||||
"coinmarketcap": {
|
||||
"configure": "Nastavte jednu alebo viac kryptomien na sledovanie",
|
||||
@@ -389,7 +389,7 @@
|
||||
"prowlarr": {
|
||||
"enableIndexers": "Indexery",
|
||||
"numberOfGrabs": "Zachytení",
|
||||
"numberOfQueries": "Queries",
|
||||
"numberOfQueries": "Požiadaviek",
|
||||
"numberOfFailGrabs": "Neúspešné zachytenia",
|
||||
"numberOfFailQueries": "Neúspešné dopyty"
|
||||
},
|
||||
@@ -404,48 +404,48 @@
|
||||
"transferRate": "Rate"
|
||||
},
|
||||
"mastodon": {
|
||||
"user_count": "Users",
|
||||
"user_count": "Používateľov",
|
||||
"status_count": "Príspevky",
|
||||
"domain_count": "Domény"
|
||||
},
|
||||
"medusa": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"queued": "V poradí",
|
||||
"series": "Series"
|
||||
},
|
||||
"minecraft": {
|
||||
"players": "Hráči",
|
||||
"version": "Verzia",
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"up": "Online",
|
||||
"down": "Offline"
|
||||
},
|
||||
"miniflux": {
|
||||
"read": "Prečítané",
|
||||
"unread": "Unread"
|
||||
"unread": "Neprečítané"
|
||||
},
|
||||
"authentik": {
|
||||
"users": "Users",
|
||||
"users": "Používateľov",
|
||||
"loginsLast24H": "Prihlás. (24 hod.)",
|
||||
"failedLoginsLast24H": "Neúspešné prihlás. (24 hod.)"
|
||||
},
|
||||
"proxmox": {
|
||||
"mem": "MEM",
|
||||
"mem": "RAM",
|
||||
"cpu": "CPU",
|
||||
"lxc": "LXC",
|
||||
"vms": "Virtuálne stroje"
|
||||
},
|
||||
"glances": {
|
||||
"cpu": "CPU",
|
||||
"load": "Load",
|
||||
"wait": "Please wait",
|
||||
"load": "Záťaž",
|
||||
"wait": "Čakajte, prosím",
|
||||
"temp": "TEMP",
|
||||
"_temp": "Teplota",
|
||||
"warn": "Upozornení",
|
||||
"uptime": "UP",
|
||||
"total": "Total",
|
||||
"free": "Free",
|
||||
"used": "Used",
|
||||
"uptime": "BEŽÍ",
|
||||
"total": "Celkom",
|
||||
"free": "Voľné",
|
||||
"used": "Využité",
|
||||
"days": "d",
|
||||
"hours": "h",
|
||||
"crit": "Kritické",
|
||||
@@ -461,7 +461,7 @@
|
||||
"search": "Hľadať",
|
||||
"custom": "Vlastné",
|
||||
"visit": "Navštíviť",
|
||||
"url": "URL",
|
||||
"url": "URL adresa",
|
||||
"searchsuggestion": "Návrh"
|
||||
},
|
||||
"wmo": {
|
||||
@@ -474,49 +474,49 @@
|
||||
"3-day": "Oblačno",
|
||||
"3-night": "Cloudy",
|
||||
"45-day": "Hmlisto",
|
||||
"45-night": "Foggy",
|
||||
"48-day": "Foggy",
|
||||
"48-night": "Foggy",
|
||||
"45-night": "Hmlisto",
|
||||
"48-day": "Hmlisto",
|
||||
"48-night": "Hmlisto",
|
||||
"51-day": "Mierne mrholenie",
|
||||
"51-night": "Light Drizzle",
|
||||
"53-day": "Mrholenie",
|
||||
"53-night": "Drizzle",
|
||||
"55-day": "Silné mrholenie",
|
||||
"55-night": "Heavy Drizzle",
|
||||
"55-night": "Silné mrholenie",
|
||||
"56-day": "Mierne mrazivé mrholenie",
|
||||
"56-night": "Light Freezing Drizzle",
|
||||
"57-day": "Mrazivé mrholenie",
|
||||
"57-night": "Freezing Drizzle",
|
||||
"61-day": "Slabý dážď",
|
||||
"61-night": "Light Rain",
|
||||
"61-night": "Slabý dážď",
|
||||
"63-day": "Dážď",
|
||||
"63-night": "Rain",
|
||||
"63-night": "Dážď",
|
||||
"65-day": "Silný dážď",
|
||||
"65-night": "Heavy Rain",
|
||||
"65-night": "Silný dážď",
|
||||
"66-day": "Mrazivý dážď",
|
||||
"66-night": "Mrznúci dážď",
|
||||
"67-day": "Mrznúci dážď",
|
||||
"67-night": "Mrznúci dážď",
|
||||
"71-day": "Mierne sneženie",
|
||||
"71-night": "Light Snow",
|
||||
"71-night": "Slabé sneženie",
|
||||
"73-day": "Sneženie",
|
||||
"73-night": "Snow",
|
||||
"73-night": "Sneženie",
|
||||
"75-day": "Silné sneženie",
|
||||
"75-night": "Heavy Snow",
|
||||
"75-night": "Husté sneženie",
|
||||
"77-day": "Snehové vločky",
|
||||
"77-night": "Snow Grains",
|
||||
"80-day": "Mierne prehánky",
|
||||
"80-night": "Light Showers",
|
||||
"80-night": "Mierne prehánky",
|
||||
"81-day": "Prehánky",
|
||||
"81-night": "Showers",
|
||||
"81-night": "Prehánky",
|
||||
"82-day": "Silné prehánky",
|
||||
"82-night": "Heavy Showers",
|
||||
"82-night": "Silné prehánky",
|
||||
"85-day": "Snehové prehánky",
|
||||
"85-night": "Snow Showers",
|
||||
"86-day": "Snow Showers",
|
||||
"86-night": "Snow Showers",
|
||||
"85-night": "Snehové prehánky",
|
||||
"86-day": "Snehové prehánky",
|
||||
"86-night": "Snehové prehánky",
|
||||
"95-day": "Búrka",
|
||||
"95-night": "Thunderstorm",
|
||||
"95-night": "Búrka",
|
||||
"96-day": "Búrka s krupobitím",
|
||||
"96-night": "Thunderstorm With Hail",
|
||||
"99-day": "Thunderstorm With Hail",
|
||||
@@ -529,17 +529,17 @@
|
||||
"up_to_date": "Aktuálny",
|
||||
"child_bridges": "Podradené premostenia",
|
||||
"child_bridges_status": "{{ok}}/{{total}}",
|
||||
"up": "Up",
|
||||
"pending": "Pending",
|
||||
"up": "Beží",
|
||||
"pending": "Čakajúce",
|
||||
"down": "Down"
|
||||
},
|
||||
"healthchecks": {
|
||||
"new": "Nový",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"grace": "V dodatočnej lehote",
|
||||
"down": "Down",
|
||||
"paused": "Pozastavené",
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"last_ping": "Poslendný ping",
|
||||
"never": "Zatiaľ žiadne ping-y"
|
||||
},
|
||||
@@ -549,27 +549,27 @@
|
||||
"containers_failed": "Zlyhané"
|
||||
},
|
||||
"autobrr": {
|
||||
"approvedPushes": "Approved",
|
||||
"approvedPushes": "Schválené",
|
||||
"rejectedPushes": "Odmietnuté",
|
||||
"filters": "Filtre",
|
||||
"indexers": "Indexers"
|
||||
},
|
||||
"tubearchivist": {
|
||||
"downloads": "Queue",
|
||||
"downloads": "Poradie",
|
||||
"videos": "Videá",
|
||||
"channels": "Kanály",
|
||||
"playlists": "Playlisty"
|
||||
},
|
||||
"truenas": {
|
||||
"load": "Záťaž systému",
|
||||
"uptime": "Uptime",
|
||||
"alerts": "Alerts"
|
||||
"uptime": "Dostupnosť",
|
||||
"alerts": "Upozornenia"
|
||||
},
|
||||
"pyload": {
|
||||
"speed": "Rýchlosť",
|
||||
"active": "Active",
|
||||
"queue": "Queue",
|
||||
"total": "Total"
|
||||
"queue": "Poradie",
|
||||
"total": "Celkom"
|
||||
},
|
||||
"gluetun": {
|
||||
"public_ip": "Verejná IP",
|
||||
@@ -585,18 +585,18 @@
|
||||
"channelNetwork": "Sieť",
|
||||
"signalStrength": "Sila",
|
||||
"signalQuality": "Kvalita",
|
||||
"symbolQuality": "Quality",
|
||||
"symbolQuality": "Kvalita",
|
||||
"networkRate": "Bitrate",
|
||||
"clientIP": "Klient"
|
||||
},
|
||||
"scrutiny": {
|
||||
"passed": "Úspešný",
|
||||
"failed": "Failed",
|
||||
"unknown": "Unknown"
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"paperlessngx": {
|
||||
"inbox": "Schránka správ",
|
||||
"total": "Total"
|
||||
"total": "Celkom"
|
||||
},
|
||||
"peanut": {
|
||||
"battery_charge": "Nabitie batérie",
|
||||
@@ -607,13 +607,13 @@
|
||||
"low_battery": "Slabá batéria"
|
||||
},
|
||||
"nextdns": {
|
||||
"wait": "Please Wait",
|
||||
"wait": "Čakajte, prosím",
|
||||
"no_devices": "Informácie o zariadení nezískané"
|
||||
},
|
||||
"mikrotik": {
|
||||
"cpuLoad": "Využitie CPU",
|
||||
"memoryUsed": "Využitie pamäte",
|
||||
"uptime": "Uptime",
|
||||
"uptime": "Dostupnosť",
|
||||
"numberOfLeases": "Pridelené adresy"
|
||||
},
|
||||
"xteve": {
|
||||
@@ -628,7 +628,7 @@
|
||||
"limit": "Limit"
|
||||
},
|
||||
"opnsense": {
|
||||
"cpu": "CPU Load",
|
||||
"cpu": "Zátaž procesora",
|
||||
"memory": "Aktívna pamäť",
|
||||
"wanUpload": "WAN nahrávanie",
|
||||
"wanDownload": "WAN sťahovanie"
|
||||
@@ -640,20 +640,20 @@
|
||||
"layers": "Vrstvy"
|
||||
},
|
||||
"octoprint": {
|
||||
"printer_state": "Status",
|
||||
"printer_state": "Stav",
|
||||
"temp_tool": "Teplota extrudéra",
|
||||
"temp_bed": "Teplota podložky",
|
||||
"job_completion": "Priebeh"
|
||||
},
|
||||
"cloudflared": {
|
||||
"origin_ip": "Zdrojová IP",
|
||||
"status": "Status"
|
||||
"status": "Stav"
|
||||
},
|
||||
"pfsense": {
|
||||
"load": "Priemerné zaťaženie",
|
||||
"memory": "Využitie pamäte",
|
||||
"wanStatus": "Stav WAN",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"down": "Down",
|
||||
"temp": "Temp",
|
||||
"disk": "Využitie disku",
|
||||
@@ -666,15 +666,15 @@
|
||||
"memory_usage": "Pamäť"
|
||||
},
|
||||
"immich": {
|
||||
"users": "Users",
|
||||
"photos": "Fotografie",
|
||||
"videos": "Videos",
|
||||
"users": "Používateľov",
|
||||
"photos": "Fotografií",
|
||||
"videos": "Videí",
|
||||
"storage": "Úložisko"
|
||||
},
|
||||
"uptimekuma": {
|
||||
"up": "Weby dostupné",
|
||||
"down": "Weby nedostupné",
|
||||
"uptime": "Uptime",
|
||||
"uptime": "Dostupnosť",
|
||||
"incident": "Udalosť",
|
||||
"m": "m"
|
||||
},
|
||||
@@ -691,8 +691,8 @@
|
||||
},
|
||||
"diskstation": {
|
||||
"days": "Days",
|
||||
"uptime": "Uptime",
|
||||
"volumeAvailable": "Available"
|
||||
"uptime": "Dostupnosť",
|
||||
"volumeAvailable": "Dostupné"
|
||||
},
|
||||
"mylar": {
|
||||
"series": "Series",
|
||||
@@ -700,15 +700,15 @@
|
||||
"wanted": "Wanted"
|
||||
},
|
||||
"photoprism": {
|
||||
"albums": "Albums",
|
||||
"photos": "Photos",
|
||||
"videos": "Videos",
|
||||
"albums": "Albumov",
|
||||
"photos": "Fotografií",
|
||||
"videos": "Videí",
|
||||
"people": "Ľudia"
|
||||
},
|
||||
"fileflows": {
|
||||
"queue": "Queue",
|
||||
"queue": "Poradie",
|
||||
"processing": "Processing",
|
||||
"processed": "Processed",
|
||||
"processed": "Spracované",
|
||||
"time": "Čas"
|
||||
},
|
||||
"firefly": {
|
||||
@@ -730,7 +730,7 @@
|
||||
"numshares": "Zdieľané položky"
|
||||
},
|
||||
"kopia": {
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"size": "Veľkosť",
|
||||
"lastrun": "Naposledy spustené",
|
||||
"nextrun": "Nasledujúce spustenie",
|
||||
@@ -753,10 +753,10 @@
|
||||
"gatus": {
|
||||
"up": "Sites Up",
|
||||
"down": "Sites Down",
|
||||
"uptime": "Uptime"
|
||||
"uptime": "Dostupnosť"
|
||||
},
|
||||
"ghostfolio": {
|
||||
"gross_percent_today": "Today",
|
||||
"gross_percent_today": "Dnes",
|
||||
"gross_percent_1y": "Jeden rok",
|
||||
"gross_percent_max": "Za celý čas"
|
||||
},
|
||||
@@ -778,22 +778,22 @@
|
||||
"calibreweb": {
|
||||
"books": "Books",
|
||||
"authors": "Autori",
|
||||
"categories": "Categories",
|
||||
"categories": "Kategórie",
|
||||
"series": "Series"
|
||||
},
|
||||
"jdownloader": {
|
||||
"downloadCount": "Queue",
|
||||
"downloadBytesRemaining": "Remaining",
|
||||
"downloadTotalBytes": "Size",
|
||||
"downloadCount": "Poradie",
|
||||
"downloadBytesRemaining": "Zostávajúce",
|
||||
"downloadTotalBytes": "Veľkosť",
|
||||
"downloadSpeed": "Speed"
|
||||
},
|
||||
"kavita": {
|
||||
"seriesCount": "Series",
|
||||
"totalFiles": "Files"
|
||||
"totalFiles": "Súborov"
|
||||
},
|
||||
"azuredevops": {
|
||||
"result": "Výsledok",
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"buildId": "ID zostavy",
|
||||
"succeeded": "Úspešný",
|
||||
"notStarted": "Nespustený",
|
||||
@@ -802,10 +802,10 @@
|
||||
"inProgress": "Prebieha",
|
||||
"totalPrs": "Počet PR-ok",
|
||||
"myPrs": "Moje PR-ka",
|
||||
"approved": "Approved"
|
||||
"approved": "Schválené"
|
||||
},
|
||||
"gamedig": {
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"online": "Online",
|
||||
"offline": "Offline",
|
||||
"name": "Meno",
|
||||
@@ -814,7 +814,7 @@
|
||||
"players": "Players",
|
||||
"maxPlayers": "Maximálny počet hráčov",
|
||||
"bots": "Boti",
|
||||
"ping": "Ping"
|
||||
"ping": "Odozva"
|
||||
},
|
||||
"urbackup": {
|
||||
"ok": "Ok",
|
||||
@@ -824,39 +824,39 @@
|
||||
},
|
||||
"mealie": {
|
||||
"recipes": "Recepty",
|
||||
"users": "Users",
|
||||
"categories": "Categories",
|
||||
"users": "Používateľov",
|
||||
"categories": "Kategórie",
|
||||
"tags": "Štítky"
|
||||
},
|
||||
"openmediavault": {
|
||||
"downloading": "Sťahovanie",
|
||||
"total": "Total",
|
||||
"running": "Running",
|
||||
"total": "Celkom",
|
||||
"running": "Beží",
|
||||
"stopped": "Stopped",
|
||||
"passed": "Passed",
|
||||
"failed": "Failed"
|
||||
},
|
||||
"openwrt": {
|
||||
"uptime": "Uptime",
|
||||
"uptime": "Dostupnosť",
|
||||
"cpuLoad": "Záťaž CPU priem. (5m)",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"down": "Down",
|
||||
"bytesTx": "Prenesených",
|
||||
"bytesRx": "Received"
|
||||
"bytesRx": "Prijaté"
|
||||
},
|
||||
"uptimerobot": {
|
||||
"status": "Status",
|
||||
"uptime": "Uptime",
|
||||
"status": "Stav",
|
||||
"uptime": "Dostupnosť",
|
||||
"lastDown": "Posledný čas nedostupnosti",
|
||||
"downDuration": "Trvanie nedostupnosti",
|
||||
"sitesUp": "Sites Up",
|
||||
"sitesDown": "Sites Down",
|
||||
"paused": "Paused",
|
||||
"paused": "Pozastavené",
|
||||
"notyetchecked": "Neskontrolované",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"seemsdown": "Javí sa nedostupný",
|
||||
"down": "Down",
|
||||
"unknown": "Unknown"
|
||||
"unknown": "Neznáme"
|
||||
},
|
||||
"calendar": {
|
||||
"inCinemas": "V kinách",
|
||||
@@ -872,13 +872,13 @@
|
||||
"saves": "Saves",
|
||||
"states": "States",
|
||||
"screenshots": "Screenshots",
|
||||
"totalfilesize": "Total Size"
|
||||
"totalfilesize": "Celková veľkosť"
|
||||
},
|
||||
"mailcow": {
|
||||
"domains": "Domains",
|
||||
"mailboxes": "Mailboxes",
|
||||
"mails": "Mails",
|
||||
"storage": "Storage"
|
||||
"storage": "Úložisko"
|
||||
},
|
||||
"netdata": {
|
||||
"warnings": "Upozornenia",
|
||||
@@ -887,7 +887,7 @@
|
||||
"plantit": {
|
||||
"events": "Udalosti",
|
||||
"plants": "Rastliny",
|
||||
"photos": "Photos",
|
||||
"photos": "Fotografií",
|
||||
"species": "Druhy"
|
||||
},
|
||||
"gitea": {
|
||||
@@ -908,13 +908,13 @@
|
||||
"galleries": "Galérie",
|
||||
"performers": "Herci",
|
||||
"studios": "Štúdiá",
|
||||
"movies": "Movies",
|
||||
"tags": "Tags",
|
||||
"movies": "Filmov",
|
||||
"tags": "Štítky",
|
||||
"oCount": "O Count"
|
||||
},
|
||||
"tandoor": {
|
||||
"users": "Users",
|
||||
"recipes": "Recipes",
|
||||
"users": "Používateľov",
|
||||
"recipes": "Recepty",
|
||||
"keywords": "Kľúčové slová"
|
||||
},
|
||||
"homebox": {
|
||||
@@ -922,18 +922,18 @@
|
||||
"totalWithWarranty": "So zárukou",
|
||||
"locations": "Umiestnenia",
|
||||
"labels": "Štítky",
|
||||
"users": "Users",
|
||||
"users": "Používateľov",
|
||||
"totalValue": "Celková hodnota"
|
||||
},
|
||||
"crowdsec": {
|
||||
"alerts": "Alerts",
|
||||
"alerts": "Upozornenia",
|
||||
"bans": "Bany"
|
||||
},
|
||||
"wgeasy": {
|
||||
"connected": "Connected",
|
||||
"connected": "Pripojené",
|
||||
"enabled": "Enabled",
|
||||
"disabled": "Disabled",
|
||||
"total": "Total"
|
||||
"total": "Celkom"
|
||||
},
|
||||
"swagdashboard": {
|
||||
"proxied": "Proxied",
|
||||
@@ -942,26 +942,26 @@
|
||||
"banned": "Zabanovaný"
|
||||
},
|
||||
"myspeed": {
|
||||
"ping": "Ping",
|
||||
"ping": "Odozva",
|
||||
"download": "Download",
|
||||
"upload": "Upload"
|
||||
"upload": "Nahrávanie"
|
||||
},
|
||||
"stocks": {
|
||||
"stocks": "Stocks",
|
||||
"loading": "Loading",
|
||||
"loading": "Načítava sa",
|
||||
"open": "Open - US Market",
|
||||
"closed": "Closed - US Market",
|
||||
"invalidConfiguration": "Invalid Configuration"
|
||||
},
|
||||
"frigate": {
|
||||
"cameras": "Cameras",
|
||||
"uptime": "Uptime",
|
||||
"version": "Version"
|
||||
"uptime": "Dostupnosť",
|
||||
"version": "Verzia"
|
||||
},
|
||||
"linkwarden": {
|
||||
"links": "Links",
|
||||
"links": "Odkazy",
|
||||
"collections": "Collections",
|
||||
"tags": "Tags"
|
||||
"tags": "Štítky"
|
||||
},
|
||||
"zabbix": {
|
||||
"unclassified": "Not classified",
|
||||
@@ -972,38 +972,38 @@
|
||||
"disaster": "Disaster"
|
||||
},
|
||||
"lubelogger": {
|
||||
"vehicle": "Vehicle",
|
||||
"vehicles": "Vehicles",
|
||||
"vehicle": "Vozidlo",
|
||||
"vehicles": "Vozidlá",
|
||||
"serviceRecords": "Service Records",
|
||||
"reminders": "Reminders",
|
||||
"nextReminder": "Next Reminder",
|
||||
"none": "None"
|
||||
"none": "Žiadne"
|
||||
},
|
||||
"vikunja": {
|
||||
"projects": "Active Projects",
|
||||
"projects": "Aktívne projekty",
|
||||
"tasks7d": "Tasks Due This Week",
|
||||
"tasksOverdue": "Overdue Tasks",
|
||||
"tasksInProgress": "Tasks In Progress"
|
||||
},
|
||||
"headscale": {
|
||||
"name": "Name",
|
||||
"address": "Address",
|
||||
"address": "Adresa",
|
||||
"last_seen": "Last Seen",
|
||||
"status": "Status",
|
||||
"status": "Stav",
|
||||
"online": "Online",
|
||||
"offline": "Offline"
|
||||
},
|
||||
"beszel": {
|
||||
"name": "Name",
|
||||
"systems": "Systems",
|
||||
"up": "Up",
|
||||
"up": "Beží",
|
||||
"down": "Down",
|
||||
"paused": "Paused",
|
||||
"pending": "Pending",
|
||||
"status": "Status",
|
||||
"paused": "Pozastavené",
|
||||
"pending": "Čakajúce",
|
||||
"status": "Stav",
|
||||
"updated": "Updated",
|
||||
"cpu": "CPU",
|
||||
"memory": "MEM",
|
||||
"memory": "RAM",
|
||||
"disk": "Disk",
|
||||
"network": "NET"
|
||||
},
|
||||
@@ -1011,14 +1011,14 @@
|
||||
"apps": "Apps",
|
||||
"synced": "Synced",
|
||||
"outOfSync": "Out Of Sync",
|
||||
"healthy": "Healthy",
|
||||
"healthy": "Zdravý",
|
||||
"degraded": "Degraded",
|
||||
"progressing": "Progressing",
|
||||
"missing": "Missing",
|
||||
"suspended": "Suspended"
|
||||
},
|
||||
"spoolman": {
|
||||
"loading": "Loading"
|
||||
"loading": "Načítava sa"
|
||||
},
|
||||
"gitlab": {
|
||||
"groups": "Groups",
|
||||
@@ -1027,8 +1027,8 @@
|
||||
"projects": "Projects"
|
||||
},
|
||||
"apcups": {
|
||||
"status": "Status",
|
||||
"load": "Load",
|
||||
"status": "Stav",
|
||||
"load": "Záťaž",
|
||||
"bcharge": "Battery Charge",
|
||||
"timeleft": "Time Left"
|
||||
},
|
||||
@@ -1037,45 +1037,45 @@
|
||||
"favorites": "Favorites",
|
||||
"archived": "Archived",
|
||||
"highlights": "Highlights",
|
||||
"lists": "Lists",
|
||||
"tags": "Tags"
|
||||
"lists": "Zoznamy",
|
||||
"tags": "Štítky"
|
||||
},
|
||||
"slskd": {
|
||||
"slskStatus": "Network",
|
||||
"connected": "Connected",
|
||||
"disconnected": "Disconnected",
|
||||
"connected": "Pripojené",
|
||||
"disconnected": "Odpojené",
|
||||
"updateStatus": "Update",
|
||||
"update_yes": "Available",
|
||||
"update_yes": "Dostupné",
|
||||
"update_no": "Up to Date",
|
||||
"downloads": "Downloads",
|
||||
"uploads": "Uploads",
|
||||
"sharedFiles": "Files"
|
||||
},
|
||||
"jellystat": {
|
||||
"songs": "Songs",
|
||||
"movies": "Movies",
|
||||
"episodes": "Episodes",
|
||||
"other": "Other"
|
||||
"songs": "Skladieb",
|
||||
"movies": "Filmov",
|
||||
"episodes": "Epizód",
|
||||
"other": "Ostatné"
|
||||
},
|
||||
"checkmk": {
|
||||
"serviceErrors": "Service issues",
|
||||
"hostErrors": "Host issues"
|
||||
},
|
||||
"komodo": {
|
||||
"total": "Total",
|
||||
"running": "Running",
|
||||
"total": "Celkom",
|
||||
"running": "Beží",
|
||||
"stopped": "Stopped",
|
||||
"down": "Down",
|
||||
"unhealthy": "Unhealthy",
|
||||
"unknown": "Unknown",
|
||||
"unhealthy": "Nezdravý",
|
||||
"unknown": "Neznáme",
|
||||
"servers": "Servers",
|
||||
"stacks": "Stacks",
|
||||
"containers": "Containers"
|
||||
},
|
||||
"filebrowser": {
|
||||
"available": "Available",
|
||||
"used": "Used",
|
||||
"total": "Total"
|
||||
"available": "Dostupné",
|
||||
"used": "Využité",
|
||||
"total": "Celkom"
|
||||
},
|
||||
"wallos": {
|
||||
"activeSubscriptions": "Subscriptions",
|
||||
|
||||
@@ -63,7 +63,7 @@
|
||||
"wlan_users": "WLAN Kullanıcıları",
|
||||
"up": "UP",
|
||||
"down": "Aşağı",
|
||||
"wait": "Please wait",
|
||||
"wait": "Lütfen bekleyin",
|
||||
"empty_data": "Alt sistem durumu bilinmiyor"
|
||||
},
|
||||
"docker": {
|
||||
@@ -83,7 +83,7 @@
|
||||
"partial": "Parçalı"
|
||||
},
|
||||
"ping": {
|
||||
"error": "Error",
|
||||
"error": "Hata",
|
||||
"ping": "Gecikme",
|
||||
"down": "İndirme",
|
||||
"up": "Yükleme",
|
||||
@@ -91,11 +91,11 @@
|
||||
},
|
||||
"siteMonitor": {
|
||||
"http_status": "HTTPS durumu",
|
||||
"error": "Error",
|
||||
"error": "Hata",
|
||||
"response": "Yanıt",
|
||||
"down": "Down",
|
||||
"up": "Up",
|
||||
"not_available": "Not Available"
|
||||
"not_available": "Mevcut Değil"
|
||||
},
|
||||
"emby": {
|
||||
"playing": "Oynatılıyor",
|
||||
@@ -108,11 +108,11 @@
|
||||
"songs": "Şarkılar"
|
||||
},
|
||||
"esphome": {
|
||||
"offline": "Offline",
|
||||
"offline_alt": "Offline",
|
||||
"offline": "Çevrimdışı",
|
||||
"offline_alt": "Çevrimdışı",
|
||||
"online": "Çevrimiçi",
|
||||
"total": "Total",
|
||||
"unknown": "Unknown"
|
||||
"total": "Toplam",
|
||||
"unknown": "Bilinmiyor"
|
||||
},
|
||||
"evcc": {
|
||||
"pv_power": "Üretim",
|
||||
@@ -133,7 +133,7 @@
|
||||
"unread": "Okunmamış"
|
||||
},
|
||||
"fritzbox": {
|
||||
"connectionStatus": "Status",
|
||||
"connectionStatus": "Durum",
|
||||
"connectionStatusUnconfigured": "Yapılandırılmamış",
|
||||
"connectionStatusConnecting": "Bağlanıyor",
|
||||
"connectionStatusAuthenticating": "Kimlik doğrulanıyor",
|
||||
@@ -141,7 +141,7 @@
|
||||
"connectionStatusDisconnecting": "Bağlantı kesiliyor...",
|
||||
"connectionStatusDisconnected": "Bağlantı kesildi",
|
||||
"connectionStatusConnected": "Bağlandı",
|
||||
"uptime": "Uptime",
|
||||
"uptime": "Çalışma Süresi",
|
||||
"maxDown": "Max. Indirme",
|
||||
"maxUp": "Max. Gönderme",
|
||||
"down": "Down",
|
||||
@@ -168,17 +168,17 @@
|
||||
"passes": "Geçilenler"
|
||||
},
|
||||
"tautulli": {
|
||||
"playing": "Playing",
|
||||
"transcoding": "Transcoding",
|
||||
"bitrate": "Bitrate",
|
||||
"no_active": "No Active Streams",
|
||||
"playing": "Oynatılıyor",
|
||||
"transcoding": "Dönüştürülüyor",
|
||||
"bitrate": "Bit Oranı",
|
||||
"no_active": "Aktif akış yok",
|
||||
"plex_connection_error": "Plex Bağlantısı Kontrol Ediliyor"
|
||||
},
|
||||
"omada": {
|
||||
"connectedAp": "Bağlı AP'ler",
|
||||
"activeUser": "Aktif cihazlar",
|
||||
"alerts": "Alarmlar",
|
||||
"connectedGateways": "Connected gateways",
|
||||
"connectedGateways": "Bağlı ağ geçitleri",
|
||||
"connectedSwitches": "Bağlı anahtarlar"
|
||||
},
|
||||
"nzbget": {
|
||||
@@ -189,30 +189,30 @@
|
||||
"plex": {
|
||||
"streams": "Aktif Akış",
|
||||
"albums": "Albümler",
|
||||
"movies": "Movies",
|
||||
"movies": "Filmler",
|
||||
"tv": "TV Showları"
|
||||
},
|
||||
"sabnzbd": {
|
||||
"rate": "Rate",
|
||||
"rate": "Oran",
|
||||
"queue": "Kuyruk",
|
||||
"timeleft": "Kalan Zaman"
|
||||
},
|
||||
"rutorrent": {
|
||||
"active": "Aktif",
|
||||
"upload": "Upload",
|
||||
"download": "Download"
|
||||
"upload": "Yükleme",
|
||||
"download": "İndirme"
|
||||
},
|
||||
"transmission": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"download": "İndirme",
|
||||
"upload": "Yükleme",
|
||||
"leech": "Tüketici",
|
||||
"seed": "Sağlayıcı"
|
||||
},
|
||||
"qbittorrent": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"download": "İndirme",
|
||||
"upload": "Yükleme",
|
||||
"leech": "Tüketici",
|
||||
"seed": "Sağlayıcı"
|
||||
},
|
||||
"qnap": {
|
||||
"cpuUsage": "İşlemci Kullanımı",
|
||||
@@ -223,7 +223,7 @@
|
||||
"invalid": "Geçersiz"
|
||||
},
|
||||
"deluge": {
|
||||
"download": "Download",
|
||||
"download": "İndirme",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
@@ -233,25 +233,25 @@
|
||||
"cachemissbytes": "Önbellek Kaçırılan Byte"
|
||||
},
|
||||
"downloadstation": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"download": "İndirme",
|
||||
"upload": "Yükleme",
|
||||
"leech": "Tüketici",
|
||||
"seed": "Sağlayıcı"
|
||||
},
|
||||
"sonarr": {
|
||||
"wanted": "İstendi",
|
||||
"queued": "Sırada",
|
||||
"series": "Series",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"series": "Seriler",
|
||||
"queue": "Kuyruk",
|
||||
"unknown": "Bilinmeyen"
|
||||
},
|
||||
"radarr": {
|
||||
"wanted": "Wanted",
|
||||
"wanted": "İstendi",
|
||||
"missing": "Eksik",
|
||||
"queued": "Queued",
|
||||
"movies": "Movies",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"queued": "Kuyrukta",
|
||||
"movies": "Filmler",
|
||||
"queue": "Kuyruk",
|
||||
"unknown": "Bilinmeyen"
|
||||
},
|
||||
"lidarr": {
|
||||
"wanted": "Wanted",
|
||||
@@ -273,9 +273,9 @@
|
||||
"available": "Kullanılabilir"
|
||||
},
|
||||
"jellyseerr": {
|
||||
"pending": "Pending",
|
||||
"approved": "Approved",
|
||||
"available": "Available"
|
||||
"pending": "Bekleyen",
|
||||
"approved": "Onaylı",
|
||||
"available": "Kullanılabilir"
|
||||
},
|
||||
"overseerr": {
|
||||
"pending": "Pending",
|
||||
@@ -284,7 +284,7 @@
|
||||
"available": "Available"
|
||||
},
|
||||
"netalertx": {
|
||||
"total": "Total",
|
||||
"total": "Toplam",
|
||||
"connected": "Connected",
|
||||
"new_devices": "Yeni Cihazlar",
|
||||
"down_alerts": "Hata Uyarıları"
|
||||
@@ -302,24 +302,24 @@
|
||||
"latency": "Gecikme"
|
||||
},
|
||||
"speedtest": {
|
||||
"upload": "Upload",
|
||||
"download": "Download",
|
||||
"ping": "Ping"
|
||||
"upload": "Yükleme",
|
||||
"download": "İndirme",
|
||||
"ping": "Gecikme"
|
||||
},
|
||||
"portainer": {
|
||||
"running": "Running",
|
||||
"running": "Çalışıyor",
|
||||
"stopped": "Durduruldu",
|
||||
"total": "Total"
|
||||
"total": "Toplam"
|
||||
},
|
||||
"suwayomi": {
|
||||
"download": "Downloaded",
|
||||
"nondownload": "Non-Downloaded",
|
||||
"read": "Read",
|
||||
"unread": "Unread",
|
||||
"downloadedread": "Downloaded & Read",
|
||||
"downloadedunread": "Downloaded & Unread",
|
||||
"nondownloadedread": "Non-Downloaded & Read",
|
||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
||||
"download": "İndirilen",
|
||||
"nondownload": "İndirilmemiş",
|
||||
"read": "Okunan",
|
||||
"unread": "Okunmamış",
|
||||
"downloadedread": "İndirildi & Okundu",
|
||||
"downloadedunread": "İndirildi & Okunmadı",
|
||||
"nondownloadedread": "İndirilmedi & Okundu",
|
||||
"nondownloadedunread": "İndirilmedi & Okunmadı"
|
||||
},
|
||||
"tailscale": {
|
||||
"address": "Adres",
|
||||
@@ -336,7 +336,7 @@
|
||||
"ago": "{{value}} Önce"
|
||||
},
|
||||
"technitium": {
|
||||
"totalQueries": "Queries",
|
||||
"totalQueries": "Sorgular",
|
||||
"totalNoError": "Başarılı",
|
||||
"totalServerFailure": "Başarısızlıklar",
|
||||
"totalNxDomain": "NX Alan Adları",
|
||||
@@ -344,12 +344,12 @@
|
||||
"totalAuthoritative": "Yetkili",
|
||||
"totalRecursive": "Tekrarlamalı",
|
||||
"totalCached": "Önbelleğe alındı",
|
||||
"totalBlocked": "Blocked",
|
||||
"totalBlocked": "Engellenen",
|
||||
"totalDropped": "Bırakıldı",
|
||||
"totalClients": "Alıcılar"
|
||||
},
|
||||
"tdarr": {
|
||||
"queue": "Queue",
|
||||
"queue": "Kuyruk",
|
||||
"processed": "İşlendi",
|
||||
"errored": "Hatalı",
|
||||
"saved": "Kaydedildi"
|
||||
@@ -360,19 +360,19 @@
|
||||
"middleware": "Ara Katman"
|
||||
},
|
||||
"trilium": {
|
||||
"version": "Version",
|
||||
"notesCount": "Notes",
|
||||
"dbSize": "Database Size",
|
||||
"unknown": "Unknown"
|
||||
"version": "Sürüm",
|
||||
"notesCount": "Notlar",
|
||||
"dbSize": "Veritabanı Boyutu",
|
||||
"unknown": "Bilinmeyen"
|
||||
},
|
||||
"navidrome": {
|
||||
"nothing_streaming": "No Active Streams",
|
||||
"nothing_streaming": "Aktif akış yok",
|
||||
"please_wait": "Lütfen Bekleyin"
|
||||
},
|
||||
"npm": {
|
||||
"enabled": "Etkin",
|
||||
"disabled": "Devre Dışı",
|
||||
"total": "Total"
|
||||
"total": "Toplam"
|
||||
},
|
||||
"coinmarketcap": {
|
||||
"configure": "İzleme için bir veya daha fazla kripto para birimi yapılandırın",
|
||||
@@ -383,46 +383,46 @@
|
||||
},
|
||||
"gotify": {
|
||||
"apps": "Uygulamalar",
|
||||
"clients": "Clients",
|
||||
"clients": "İstemciler",
|
||||
"messages": "İletiler"
|
||||
},
|
||||
"prowlarr": {
|
||||
"enableIndexers": "Dizin Oluşturucular",
|
||||
"enableIndexers": "İndeksleyici",
|
||||
"numberOfGrabs": "Yakalamalar",
|
||||
"numberOfQueries": "Queries",
|
||||
"numberOfQueries": "Sorgular",
|
||||
"numberOfFailGrabs": "Başarısız Yakalamalar",
|
||||
"numberOfFailQueries": "Başarısız Sorgular"
|
||||
},
|
||||
"jackett": {
|
||||
"configured": "Yapılandırılmış",
|
||||
"errored": "Errored"
|
||||
"errored": "Hatalı"
|
||||
},
|
||||
"strelaysrv": {
|
||||
"numActiveSessions": "Aktif Sezonlar",
|
||||
"numConnections": "Bağlantı Sayısı",
|
||||
"dataRelayed": "Aktarılan",
|
||||
"transferRate": "Rate"
|
||||
"transferRate": "Oran"
|
||||
},
|
||||
"mastodon": {
|
||||
"user_count": "Users",
|
||||
"user_count": "Kullanıcılar",
|
||||
"status_count": "Gönderiler",
|
||||
"domain_count": "Etki Alanları"
|
||||
},
|
||||
"medusa": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"wanted": "İstendi",
|
||||
"queued": "Sırada",
|
||||
"series": "Series"
|
||||
},
|
||||
"minecraft": {
|
||||
"players": "Oyuncular",
|
||||
"version": "Versiyon",
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"up": "Online",
|
||||
"down": "Offline"
|
||||
},
|
||||
"miniflux": {
|
||||
"read": "Okunan",
|
||||
"unread": "Unread"
|
||||
"read": "Okunmuş",
|
||||
"unread": "Okunmamış"
|
||||
},
|
||||
"authentik": {
|
||||
"users": "Users",
|
||||
@@ -443,7 +443,7 @@
|
||||
"_temp": "Sıcaklık",
|
||||
"warn": "Uyarı",
|
||||
"uptime": "UP",
|
||||
"total": "Total",
|
||||
"total": "Toplam",
|
||||
"free": "Free",
|
||||
"used": "Used",
|
||||
"days": "d",
|
||||
@@ -470,57 +470,57 @@
|
||||
"1-day": "Çoğunlukla Güneşli",
|
||||
"1-night": "Çoğunlukla Açık",
|
||||
"2-day": "Parçalı Bulutlu",
|
||||
"2-night": "Partly Cloudy",
|
||||
"2-night": "Parçalı Bulutlu",
|
||||
"3-day": "Bulutlu",
|
||||
"3-night": "Cloudy",
|
||||
"3-night": "Bulutlu",
|
||||
"45-day": "Sisli",
|
||||
"45-night": "Foggy",
|
||||
"48-day": "Foggy",
|
||||
"48-night": "Foggy",
|
||||
"45-night": "Sisli",
|
||||
"48-day": "Sisli",
|
||||
"48-night": "Sisli",
|
||||
"51-day": "Az Çiseleyen Yağmur",
|
||||
"51-night": "Light Drizzle",
|
||||
"51-night": "Hafif Çiseleme",
|
||||
"53-day": "Çiseleyen Yağmur",
|
||||
"53-night": "Drizzle",
|
||||
"53-night": "Çiseleme",
|
||||
"55-day": "Çok Çiseleyen Yağmur",
|
||||
"55-night": "Heavy Drizzle",
|
||||
"55-night": "Yoğun Çiseleme",
|
||||
"56-day": "Soğuk Az Çiseleyen Yağmur",
|
||||
"56-night": "Light Freezing Drizzle",
|
||||
"56-night": "Hafif Dondurucu Çiseleme",
|
||||
"57-day": "Soğuk Çiseleyen Yağmur",
|
||||
"57-night": "Freezing Drizzle",
|
||||
"57-night": "Dondurucu Çiseleme",
|
||||
"61-day": "Hafif Yağmur",
|
||||
"61-night": "Light Rain",
|
||||
"61-night": "Hafif Yağmur",
|
||||
"63-day": "Yağmur",
|
||||
"63-night": "Rain",
|
||||
"63-night": "Yağmur",
|
||||
"65-day": "Çok Yağmur",
|
||||
"65-night": "Heavy Rain",
|
||||
"65-night": "Şiddetli Yağmur",
|
||||
"66-day": "Dondurucu Yağmur",
|
||||
"66-night": "Freezing Rain",
|
||||
"67-day": "Freezing Rain",
|
||||
"67-night": "Freezing Rain",
|
||||
"66-night": "Dondurucu Yağmur",
|
||||
"67-day": "Dondurucu Yağmur",
|
||||
"67-night": "Dondurucu Yağmur",
|
||||
"71-day": "Hafif Kar",
|
||||
"71-night": "Light Snow",
|
||||
"71-night": "Hafif Kar",
|
||||
"73-day": "Kar",
|
||||
"73-night": "Snow",
|
||||
"73-night": "Kar",
|
||||
"75-day": "Çok Kar",
|
||||
"75-night": "Heavy Snow",
|
||||
"75-night": "Yoğun Kar",
|
||||
"77-day": "Kar Taneleri",
|
||||
"77-night": "Snow Grains",
|
||||
"77-night": "Kar Taneleri",
|
||||
"80-day": "Hafif Sağanak",
|
||||
"80-night": "Light Showers",
|
||||
"80-night": "Hafif Sağanak",
|
||||
"81-day": "Sağanak",
|
||||
"81-night": "Showers",
|
||||
"81-night": "Sağanak",
|
||||
"82-day": "Yoğun Sağanak",
|
||||
"82-night": "Heavy Showers",
|
||||
"82-night": "Yoğun Sağanak",
|
||||
"85-day": "Karlı Sağanak",
|
||||
"85-night": "Snow Showers",
|
||||
"86-day": "Snow Showers",
|
||||
"86-night": "Snow Showers",
|
||||
"85-night": "Karlı Sağanak",
|
||||
"86-day": "Karlı Sağanak",
|
||||
"86-night": "Karlı Sağanak",
|
||||
"95-day": "Gök Gürültülü Fırtına",
|
||||
"95-night": "Thunderstorm",
|
||||
"95-night": "Fırtına",
|
||||
"96-day": "Dolu İle Gök Gürültülü Fırtına",
|
||||
"96-night": "Thunderstorm With Hail",
|
||||
"99-day": "Thunderstorm With Hail",
|
||||
"99-night": "Thunderstorm With Hail"
|
||||
"96-night": "Dolu Yağışlı Fırtına",
|
||||
"99-day": "Dolu Yağışlı Fırtına",
|
||||
"99-night": "Dolu Yağışlı Fırtına"
|
||||
},
|
||||
"homebridge": {
|
||||
"available_update": "Sistem",
|
||||
@@ -530,7 +530,7 @@
|
||||
"child_bridges": "Alt Köprüler",
|
||||
"child_bridges_status": "{{ok}}/{{total}}",
|
||||
"up": "Up",
|
||||
"pending": "Pending",
|
||||
"pending": "Bekleyen",
|
||||
"down": "Down"
|
||||
},
|
||||
"healthchecks": {
|
||||
@@ -539,7 +539,7 @@
|
||||
"grace": "Tolerans Döneminde",
|
||||
"down": "Down",
|
||||
"paused": "Duraklatıldı",
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"last_ping": "Son Ping",
|
||||
"never": "Henüz ping yok"
|
||||
},
|
||||
@@ -549,65 +549,65 @@
|
||||
"containers_failed": "Başarısız"
|
||||
},
|
||||
"autobrr": {
|
||||
"approvedPushes": "Approved",
|
||||
"approvedPushes": "Onaylı",
|
||||
"rejectedPushes": "Reddedildi",
|
||||
"filters": "Süzgeçler",
|
||||
"indexers": "Indexers"
|
||||
"indexers": "İndeksleyici"
|
||||
},
|
||||
"tubearchivist": {
|
||||
"downloads": "Queue",
|
||||
"downloads": "Kuyruk",
|
||||
"videos": "Videolar",
|
||||
"channels": "Kanallar",
|
||||
"playlists": "Oynatma Listeleri"
|
||||
},
|
||||
"truenas": {
|
||||
"load": "Sistem Yükü",
|
||||
"uptime": "Uptime",
|
||||
"alerts": "Alerts"
|
||||
"uptime": "Çalışma Süresi",
|
||||
"alerts": "Alarmlar"
|
||||
},
|
||||
"pyload": {
|
||||
"speed": "Hız",
|
||||
"active": "Active",
|
||||
"queue": "Queue",
|
||||
"total": "Total"
|
||||
"active": "Aktif",
|
||||
"queue": "Kuyruk",
|
||||
"total": "Toplam"
|
||||
},
|
||||
"gluetun": {
|
||||
"public_ip": "Açık IP",
|
||||
"region": "Bölge",
|
||||
"country": "Ülke",
|
||||
"port_forwarded": "Port Forwarded"
|
||||
"port_forwarded": "Yönlendirilen Port"
|
||||
},
|
||||
"hdhomerun": {
|
||||
"channels": "Channels",
|
||||
"channels": "Kanallar",
|
||||
"hd": "HD",
|
||||
"tunerCount": "Ayarlayıcılar",
|
||||
"channelNumber": "Kanal",
|
||||
"channelNetwork": "Ağ",
|
||||
"signalStrength": "Sağlamlık",
|
||||
"signalQuality": "Kalite",
|
||||
"symbolQuality": "Quality",
|
||||
"networkRate": "Bitrate",
|
||||
"symbolQuality": "Kalite",
|
||||
"networkRate": "Bit Oranı",
|
||||
"clientIP": "Alıcı"
|
||||
},
|
||||
"scrutiny": {
|
||||
"passed": "Geçti",
|
||||
"failed": "Failed",
|
||||
"unknown": "Unknown"
|
||||
"failed": "Başarısız",
|
||||
"unknown": "Bilinmeyen"
|
||||
},
|
||||
"paperlessngx": {
|
||||
"inbox": "Gelen Kutusu",
|
||||
"total": "Total"
|
||||
"total": "Toplam"
|
||||
},
|
||||
"peanut": {
|
||||
"battery_charge": "Pil Yüzdesi",
|
||||
"ups_load": "UPS Yükü",
|
||||
"ups_status": "UPS Durumu",
|
||||
"online": "Online",
|
||||
"online": "Çevrimiçi",
|
||||
"on_battery": "Pilde",
|
||||
"low_battery": "Düşük Pil"
|
||||
},
|
||||
"nextdns": {
|
||||
"wait": "Please Wait",
|
||||
"wait": "Lütfen Bekleyin",
|
||||
"no_devices": "Cihaz Verisi Alınamadı"
|
||||
},
|
||||
"mikrotik": {
|
||||
@@ -640,14 +640,14 @@
|
||||
"layers": "Katmanlar"
|
||||
},
|
||||
"octoprint": {
|
||||
"printer_state": "Status",
|
||||
"printer_state": "Durum",
|
||||
"temp_tool": "Araç sıcaklığı",
|
||||
"temp_bed": "Yatak sıcaklığı",
|
||||
"job_completion": "Tamamlanma"
|
||||
},
|
||||
"cloudflared": {
|
||||
"origin_ip": "Gerçek IP",
|
||||
"status": "Status"
|
||||
"status": "Durum"
|
||||
},
|
||||
"pfsense": {
|
||||
"load": "Ort. Yükleme",
|
||||
@@ -706,9 +706,9 @@
|
||||
"people": "İnsan"
|
||||
},
|
||||
"fileflows": {
|
||||
"queue": "Queue",
|
||||
"processing": "Processing",
|
||||
"processed": "Processed",
|
||||
"queue": "Kuyruk",
|
||||
"processing": "İşleniyor",
|
||||
"processed": "İşlendi",
|
||||
"time": "Zaman"
|
||||
},
|
||||
"firefly": {
|
||||
@@ -730,7 +730,7 @@
|
||||
"numshares": "Paylaşılan Öğeler"
|
||||
},
|
||||
"kopia": {
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"size": "Boyut",
|
||||
"lastrun": "Son Çalışma",
|
||||
"nextrun": "Sonraki Çalışma",
|
||||
@@ -773,27 +773,27 @@
|
||||
},
|
||||
"whatsupdocker": {
|
||||
"monitoring": "İzleme",
|
||||
"updates": "Updates"
|
||||
"updates": "Güncellemeler"
|
||||
},
|
||||
"calibreweb": {
|
||||
"books": "Books",
|
||||
"books": "Kitaplar",
|
||||
"authors": "Yazarlar",
|
||||
"categories": "Categories",
|
||||
"series": "Series"
|
||||
"categories": "Kategoriler",
|
||||
"series": "Seriler"
|
||||
},
|
||||
"jdownloader": {
|
||||
"downloadCount": "Queue",
|
||||
"downloadBytesRemaining": "Remaining",
|
||||
"downloadTotalBytes": "Size",
|
||||
"downloadSpeed": "Speed"
|
||||
"downloadCount": "Kuyruk",
|
||||
"downloadBytesRemaining": "Kalan",
|
||||
"downloadTotalBytes": "Boyut",
|
||||
"downloadSpeed": "Hız"
|
||||
},
|
||||
"kavita": {
|
||||
"seriesCount": "Series",
|
||||
"totalFiles": "Files"
|
||||
"totalFiles": "Dosyalar"
|
||||
},
|
||||
"azuredevops": {
|
||||
"result": "Sonuç",
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"buildId": "Yapı Kimliği",
|
||||
"succeeded": "Başarılı",
|
||||
"notStarted": "Henüz Başlamadı",
|
||||
@@ -805,7 +805,7 @@
|
||||
"approved": "Approved"
|
||||
},
|
||||
"gamedig": {
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"online": "Online",
|
||||
"offline": "Offline",
|
||||
"name": "İsim",
|
||||
@@ -830,7 +830,7 @@
|
||||
},
|
||||
"openmediavault": {
|
||||
"downloading": "İndiriliyor",
|
||||
"total": "Total",
|
||||
"total": "Toplam",
|
||||
"running": "Running",
|
||||
"stopped": "Stopped",
|
||||
"passed": "Passed",
|
||||
@@ -845,7 +845,7 @@
|
||||
"bytesRx": "Received"
|
||||
},
|
||||
"uptimerobot": {
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"uptime": "Uptime",
|
||||
"lastDown": "Son Kesinti",
|
||||
"downDuration": "Kesinti Süresi",
|
||||
@@ -933,7 +933,7 @@
|
||||
"connected": "Connected",
|
||||
"enabled": "Enabled",
|
||||
"disabled": "Disabled",
|
||||
"total": "Total"
|
||||
"total": "Toplam"
|
||||
},
|
||||
"swagdashboard": {
|
||||
"proxied": "Proxy Üzerinden",
|
||||
@@ -943,7 +943,7 @@
|
||||
},
|
||||
"myspeed": {
|
||||
"ping": "Ping",
|
||||
"download": "Download",
|
||||
"download": "İndirme",
|
||||
"upload": "Upload"
|
||||
},
|
||||
"stocks": {
|
||||
@@ -989,7 +989,7 @@
|
||||
"name": "Name",
|
||||
"address": "Address",
|
||||
"last_seen": "Last Seen",
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"online": "Online",
|
||||
"offline": "Offline"
|
||||
},
|
||||
@@ -1000,7 +1000,7 @@
|
||||
"down": "Down",
|
||||
"paused": "Paused",
|
||||
"pending": "Pending",
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"updated": "Updated",
|
||||
"cpu": "CPU",
|
||||
"memory": "MEM",
|
||||
@@ -1027,7 +1027,7 @@
|
||||
"projects": "Projects"
|
||||
},
|
||||
"apcups": {
|
||||
"status": "Status",
|
||||
"status": "Durum",
|
||||
"load": "Load",
|
||||
"bcharge": "Battery Charge",
|
||||
"timeleft": "Time Left"
|
||||
@@ -1041,13 +1041,13 @@
|
||||
"tags": "Tags"
|
||||
},
|
||||
"slskd": {
|
||||
"slskStatus": "Network",
|
||||
"slskStatus": "Ağ",
|
||||
"connected": "Connected",
|
||||
"disconnected": "Disconnected",
|
||||
"updateStatus": "Update",
|
||||
"updateStatus": "Güncelleme",
|
||||
"update_yes": "Available",
|
||||
"update_no": "Up to Date",
|
||||
"downloads": "Downloads",
|
||||
"downloads": "İndirmeler",
|
||||
"uploads": "Uploads",
|
||||
"sharedFiles": "Files"
|
||||
},
|
||||
@@ -1062,8 +1062,8 @@
|
||||
"hostErrors": "Host issues"
|
||||
},
|
||||
"komodo": {
|
||||
"total": "Total",
|
||||
"running": "Running",
|
||||
"total": "Toplam",
|
||||
"running": "Çalışıyor",
|
||||
"stopped": "Stopped",
|
||||
"down": "Down",
|
||||
"unhealthy": "Unhealthy",
|
||||
@@ -1075,13 +1075,13 @@
|
||||
"filebrowser": {
|
||||
"available": "Available",
|
||||
"used": "Used",
|
||||
"total": "Total"
|
||||
"total": "Toplam"
|
||||
},
|
||||
"wallos": {
|
||||
"activeSubscriptions": "Subscriptions",
|
||||
"thisMonthlyCost": "This Month",
|
||||
"nextMonthlyCost": "Next Month",
|
||||
"previousMonthlyCost": "Prev. Month",
|
||||
"nextRenewingSubscription": "Next Payment"
|
||||
"activeSubscriptions": "Abonelikler",
|
||||
"thisMonthlyCost": "Bu Ay",
|
||||
"nextMonthlyCost": "Sonraki Ay",
|
||||
"previousMonthlyCost": "Önceki Ay",
|
||||
"nextRenewingSubscription": "Sonraki Ödeme"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -112,7 +112,7 @@
|
||||
"offline_alt": "Offline",
|
||||
"online": "Онлайн",
|
||||
"total": "Total",
|
||||
"unknown": "Unknown"
|
||||
"unknown": "Невідомо"
|
||||
},
|
||||
"evcc": {
|
||||
"pv_power": "Виробництво",
|
||||
|
||||
@@ -63,7 +63,7 @@
|
||||
"wlan_users": "无线局域网用户",
|
||||
"up": "UP",
|
||||
"down": "离线",
|
||||
"wait": "请稍后",
|
||||
"wait": "请稍候",
|
||||
"empty_data": "子系统状态未知"
|
||||
},
|
||||
"docker": {
|
||||
@@ -83,19 +83,19 @@
|
||||
"partial": "部分"
|
||||
},
|
||||
"ping": {
|
||||
"error": "Error",
|
||||
"ping": "Ping",
|
||||
"down": "Down",
|
||||
"up": "Up",
|
||||
"error": "错误",
|
||||
"ping": "延迟",
|
||||
"down": "离线",
|
||||
"up": "在线",
|
||||
"not_available": "不可用"
|
||||
},
|
||||
"siteMonitor": {
|
||||
"http_status": "HTTP 状态",
|
||||
"error": "Error",
|
||||
"error": "错误",
|
||||
"response": "响应",
|
||||
"down": "Down",
|
||||
"up": "Up",
|
||||
"not_available": "Not Available"
|
||||
"down": "离线",
|
||||
"up": "在线",
|
||||
"not_available": "不可用"
|
||||
},
|
||||
"emby": {
|
||||
"playing": "播放中",
|
||||
@@ -116,7 +116,7 @@
|
||||
},
|
||||
"evcc": {
|
||||
"pv_power": "正式环境",
|
||||
"battery_soc": "Battery",
|
||||
"battery_soc": "电量",
|
||||
"grid_power": "Grid",
|
||||
"home_power": "Consumption",
|
||||
"charge_power": "Charger",
|
||||
@@ -189,7 +189,7 @@
|
||||
"plex": {
|
||||
"streams": "活动流",
|
||||
"albums": "专辑",
|
||||
"movies": "Movies",
|
||||
"movies": "电影",
|
||||
"tv": "电视节目"
|
||||
},
|
||||
"sabnzbd": {
|
||||
@@ -204,15 +204,15 @@
|
||||
},
|
||||
"transmission": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"upload": "",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
},
|
||||
"qbittorrent": {
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"download": "下载速率",
|
||||
"upload": "上传速率",
|
||||
"leech": "下载中",
|
||||
"seed": "做种"
|
||||
},
|
||||
"qnap": {
|
||||
"cpuUsage": "处理器",
|
||||
@@ -236,31 +236,31 @@
|
||||
"download": "Download",
|
||||
"upload": "Upload",
|
||||
"leech": "Leech",
|
||||
"seed": "Seed"
|
||||
"seed": "做种"
|
||||
},
|
||||
"sonarr": {
|
||||
"wanted": "想看",
|
||||
"queued": "排队",
|
||||
"series": "Series",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"series": "系列",
|
||||
"queue": "队列",
|
||||
"unknown": "未知"
|
||||
},
|
||||
"radarr": {
|
||||
"wanted": "Wanted",
|
||||
"wanted": "想看",
|
||||
"missing": "丢失",
|
||||
"queued": "Queued",
|
||||
"movies": "Movies",
|
||||
"queue": "Queue",
|
||||
"unknown": "Unknown"
|
||||
"queued": "队列中",
|
||||
"movies": "电影",
|
||||
"queue": "队列",
|
||||
"unknown": "未知"
|
||||
},
|
||||
"lidarr": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"wanted": "想看",
|
||||
"queued": "队列中",
|
||||
"artists": "Artists"
|
||||
},
|
||||
"readarr": {
|
||||
"wanted": "Wanted",
|
||||
"queued": "Queued",
|
||||
"wanted": "想看",
|
||||
"queued": "队列中",
|
||||
"books": "书籍"
|
||||
},
|
||||
"bazarr": {
|
||||
@@ -273,7 +273,7 @@
|
||||
"available": "可用"
|
||||
},
|
||||
"jellyseerr": {
|
||||
"pending": "Pending",
|
||||
"pending": "待办的",
|
||||
"approved": "Approved",
|
||||
"available": "Available"
|
||||
},
|
||||
@@ -437,20 +437,20 @@
|
||||
},
|
||||
"glances": {
|
||||
"cpu": "CPU",
|
||||
"load": "Load",
|
||||
"wait": "Please wait",
|
||||
"temp": "TEMP",
|
||||
"load": "负载",
|
||||
"wait": "请稍候",
|
||||
"temp": "温度",
|
||||
"_temp": "Temp",
|
||||
"warn": "Warn",
|
||||
"uptime": "UP",
|
||||
"total": "Total",
|
||||
"free": "Free",
|
||||
"used": "Used",
|
||||
"days": "d",
|
||||
"hours": "h",
|
||||
"uptime": "运行时间",
|
||||
"total": "总计",
|
||||
"free": "空闲",
|
||||
"used": "已使用",
|
||||
"days": "日",
|
||||
"hours": "时",
|
||||
"crit": "Crit",
|
||||
"read": "Read",
|
||||
"write": "Write",
|
||||
"write": "写入",
|
||||
"gpu": "GPU",
|
||||
"mem": "Mem",
|
||||
"swap": "Swap"
|
||||
|
||||
@@ -37,12 +37,12 @@ export default function Container({ error = false, children, service }) {
|
||||
if (!field.includes(".")) {
|
||||
fullField = `${type}.${field}`;
|
||||
}
|
||||
let matches = fullField === child?.props?.label;
|
||||
let matches = fullField === (child?.props?.field || child?.props?.label);
|
||||
// check if the field is an 'alias'
|
||||
if (matches) {
|
||||
return true;
|
||||
} else if (ALIASED_WIDGETS[type]) {
|
||||
matches = fullField.replace(type, ALIASED_WIDGETS[type]) === child?.props?.label;
|
||||
matches = fullField.replace(type, ALIASED_WIDGETS[type]) === (child?.props?.field || child?.props?.label);
|
||||
|
||||
return matches;
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
import { useTranslation } from "next-i18next";
|
||||
import { useState } from "react";
|
||||
import { useCallback, useEffect, useState } from "react";
|
||||
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
|
||||
import { WiCloudDown } from "react-icons/wi";
|
||||
import useSWR from "swr";
|
||||
@@ -64,7 +64,7 @@ export default function OpenMeteo({ options }) {
|
||||
setLocation({ latitude: options.latitude, longitude: options.longitude });
|
||||
}
|
||||
|
||||
const requestLocation = () => {
|
||||
const requestLocation = useCallback(() => {
|
||||
setRequesting(true);
|
||||
if (typeof window !== "undefined") {
|
||||
navigator.geolocation.getCurrentPosition(
|
||||
@@ -82,7 +82,17 @@ export default function OpenMeteo({ options }) {
|
||||
},
|
||||
);
|
||||
}
|
||||
};
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
if (!options.latitude && !options.longitude && typeof navigator !== "undefined") {
|
||||
navigator.permissions?.query({ name: "geolocation" }).then((result) => {
|
||||
if (result.state === "granted") {
|
||||
requestLocation();
|
||||
}
|
||||
});
|
||||
}
|
||||
}, [options.latitude, options.longitude, requestLocation]);
|
||||
|
||||
if (!location) {
|
||||
return (
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
import { useTranslation } from "next-i18next";
|
||||
import { useState } from "react";
|
||||
import { useCallback, useEffect, useState } from "react";
|
||||
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
|
||||
import { WiCloudDown } from "react-icons/wi";
|
||||
import useSWR from "swr";
|
||||
@@ -59,7 +59,7 @@ export default function OpenWeatherMap({ options }) {
|
||||
setLocation({ latitude: options.latitude, longitude: options.longitude });
|
||||
}
|
||||
|
||||
const requestLocation = () => {
|
||||
const requestLocation = useCallback(() => {
|
||||
setRequesting(true);
|
||||
if (typeof window !== "undefined") {
|
||||
navigator.geolocation.getCurrentPosition(
|
||||
@@ -77,7 +77,17 @@ export default function OpenWeatherMap({ options }) {
|
||||
},
|
||||
);
|
||||
}
|
||||
};
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
if (!options.latitude && !options.longitude && typeof navigator !== "undefined") {
|
||||
navigator.permissions?.query({ name: "geolocation" }).then((result) => {
|
||||
if (result.state === "granted") {
|
||||
requestLocation();
|
||||
}
|
||||
});
|
||||
}
|
||||
}, [options.latitude, options.longitude, requestLocation]);
|
||||
|
||||
if (!location) {
|
||||
return (
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
import { useTranslation } from "next-i18next";
|
||||
import { useState } from "react";
|
||||
import { useCallback, useEffect, useState } from "react";
|
||||
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
|
||||
import { WiCloudDown } from "react-icons/wi";
|
||||
import useSWR from "swr";
|
||||
@@ -63,7 +63,7 @@ export default function WeatherApi({ options }) {
|
||||
setLocation({ latitude: options.latitude, longitude: options.longitude });
|
||||
}
|
||||
|
||||
const requestLocation = () => {
|
||||
const requestLocation = useCallback(() => {
|
||||
setRequesting(true);
|
||||
if (typeof window !== "undefined") {
|
||||
navigator.geolocation.getCurrentPosition(
|
||||
@@ -81,7 +81,17 @@ export default function WeatherApi({ options }) {
|
||||
},
|
||||
);
|
||||
}
|
||||
};
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
if (!options.latitude && !options.longitude && typeof navigator !== "undefined") {
|
||||
navigator.permissions?.query({ name: "geolocation" }).then((result) => {
|
||||
if (result.state === "granted") {
|
||||
requestLocation();
|
||||
}
|
||||
});
|
||||
}
|
||||
}, [options.latitude, options.longitude, requestLocation]);
|
||||
|
||||
if (!location) {
|
||||
return (
|
||||
|
||||
@@ -1,5 +1,3 @@
|
||||
import { existsSync } from "fs";
|
||||
|
||||
import createLogger from "utils/logger";
|
||||
|
||||
const logger = createLogger("resources");
|
||||
@@ -20,17 +18,20 @@ export default async function handler(req, res) {
|
||||
}
|
||||
|
||||
if (type === "disk") {
|
||||
if (!existsSync(target)) {
|
||||
return res.status(404).json({
|
||||
error: "Target not found",
|
||||
});
|
||||
}
|
||||
|
||||
const requested = typeof target === "string" && target ? target : "/";
|
||||
const fsSize = await si.fsSize();
|
||||
logger.debug("fsSize:", JSON.stringify(fsSize));
|
||||
return res.status(200).json({
|
||||
drive: fsSize.find((fs) => fs.mount === target) ?? fsSize.find((fs) => fs.mount === "/"),
|
||||
|
||||
const drive = fsSize.find((fs) => {
|
||||
return fs.mount === requested;
|
||||
});
|
||||
|
||||
if (!drive) {
|
||||
logger.warn(`Drive not found for target: ${requested}`);
|
||||
return res.status(404).json({ error: "Resource not available." });
|
||||
}
|
||||
|
||||
return res.status(200).json({ drive });
|
||||
}
|
||||
|
||||
if (type === "memory") {
|
||||
|
||||
@@ -509,7 +509,7 @@ export default function Wrapper({ initialSettings, fallback }) {
|
||||
if (typeof bg === "object") {
|
||||
backgroundImage = bg.image || "";
|
||||
if (bg.opacity !== undefined) {
|
||||
opacity = bg.opacity / 100;
|
||||
opacity = 1 - bg.opacity / 100;
|
||||
}
|
||||
backgroundBlur = bg.blur !== undefined;
|
||||
backgroundSaturate = bg.saturate !== undefined;
|
||||
@@ -524,7 +524,7 @@ export default function Wrapper({ initialSettings, fallback }) {
|
||||
const body = document.body;
|
||||
|
||||
html.classList.remove("dark", "scheme-dark", "scheme-light");
|
||||
html.classList.add(theme === "dark" ? "dark" : "");
|
||||
html.classList.toggle("dark", theme === "dark");
|
||||
html.classList.add(theme === "dark" ? "scheme-dark" : "scheme-light");
|
||||
|
||||
html.classList.remove(...Array.from(html.classList).filter((cls) => cls.startsWith("theme-")));
|
||||
|
||||
@@ -30,12 +30,13 @@ body,
|
||||
height: 100%;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
background-color: rgb(var(--bg-color));
|
||||
}
|
||||
|
||||
#background {
|
||||
position: fixed;
|
||||
inset: 0;
|
||||
z-index: -1;
|
||||
z-index: 0;
|
||||
background-size: cover;
|
||||
background-position: center;
|
||||
background-repeat: no-repeat;
|
||||
|
||||
@@ -308,7 +308,7 @@ export function cleanServiceGroups(groups) {
|
||||
// gamedig
|
||||
gameToken,
|
||||
|
||||
// beszel, glances, immich, komga, mealie, pihole, pfsense, speedtest
|
||||
// authentik, beszel, glances, immich, komga, mealie, pihole, pfsense, speedtest
|
||||
version,
|
||||
|
||||
// glances
|
||||
@@ -396,6 +396,12 @@ export function cleanServiceGroups(groups) {
|
||||
// unifi
|
||||
site,
|
||||
|
||||
// unraid
|
||||
pool1,
|
||||
pool2,
|
||||
pool3,
|
||||
pool4,
|
||||
|
||||
// vikunja
|
||||
enableTaskList,
|
||||
|
||||
@@ -518,6 +524,7 @@ export function cleanServiceGroups(groups) {
|
||||
}
|
||||
if (
|
||||
[
|
||||
"authentik",
|
||||
"beszel",
|
||||
"glances",
|
||||
"immich",
|
||||
@@ -610,6 +617,12 @@ export function cleanServiceGroups(groups) {
|
||||
if (type === "grafana") {
|
||||
if (alerts) widget.alerts = alerts;
|
||||
}
|
||||
if (type === "unraid") {
|
||||
if (pool1) widget.pool1 = pool1;
|
||||
if (pool2) widget.pool2 = pool2;
|
||||
if (pool3) widget.pool3 = pool3;
|
||||
if (pool4) widget.pool4 = pool4;
|
||||
}
|
||||
return widget;
|
||||
});
|
||||
return cleanedService;
|
||||
|
||||
@@ -10,8 +10,12 @@ export default function Component({ service }) {
|
||||
const { widget } = service;
|
||||
|
||||
const { data: usersData, error: usersError } = useWidgetAPI(widget, "users");
|
||||
const { data: loginsData, error: loginsError } = useWidgetAPI(widget, "login");
|
||||
const { data: failedLoginsData, error: failedLoginsError } = useWidgetAPI(widget, "login_failed");
|
||||
|
||||
const loginsEndpoint = widget.version === 2 ? "loginv2" : "login";
|
||||
const { data: loginsData, error: loginsError } = useWidgetAPI(widget, loginsEndpoint);
|
||||
|
||||
const failedLoginsEndpoint = widget.version === 2 ? "login_failedv2" : "login_failed";
|
||||
const { data: failedLoginsData, error: failedLoginsError } = useWidgetAPI(widget, failedLoginsEndpoint);
|
||||
|
||||
if (usersError || loginsError || failedLoginsError) {
|
||||
const finalError = usersError ?? loginsError ?? failedLoginsError;
|
||||
@@ -28,15 +32,25 @@ export default function Component({ service }) {
|
||||
);
|
||||
}
|
||||
|
||||
const yesterday = new Date(Date.now()).setHours(-24);
|
||||
const loginsLast24H = loginsData.reduce(
|
||||
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total),
|
||||
0,
|
||||
);
|
||||
const failedLoginsLast24H = failedLoginsData.reduce(
|
||||
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total),
|
||||
0,
|
||||
);
|
||||
let loginsLast24H;
|
||||
let failedLoginsLast24H;
|
||||
switch (widget.version) {
|
||||
case 1:
|
||||
const yesterday = new Date(Date.now()).setHours(-24);
|
||||
loginsLast24H = loginsData.reduce(
|
||||
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total),
|
||||
0,
|
||||
);
|
||||
failedLoginsLast24H = failedLoginsData.reduce(
|
||||
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total),
|
||||
0,
|
||||
);
|
||||
break;
|
||||
case 2:
|
||||
loginsLast24H = loginsData[0]?.count || 0;
|
||||
failedLoginsLast24H = failedLoginsData[0]?.count || 0;
|
||||
break;
|
||||
}
|
||||
|
||||
return (
|
||||
<Container service={service}>
|
||||
|
||||
@@ -11,9 +11,15 @@ const widget = {
|
||||
login: {
|
||||
endpoint: "events/events/per_month/?action=login",
|
||||
},
|
||||
loginv2: {
|
||||
endpoint: "events/events/volume/?action=login&&history_days=1",
|
||||
},
|
||||
login_failed: {
|
||||
endpoint: "events/events/per_month/?action=login_failed",
|
||||
},
|
||||
login_failedv2: {
|
||||
endpoint: "events/events/volume/?action=login_failed&&history_days=1",
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
|
||||
@@ -139,6 +139,7 @@ const components = {
|
||||
truenas: dynamic(() => import("./truenas/component")),
|
||||
unifi: dynamic(() => import("./unifi/component")),
|
||||
unmanic: dynamic(() => import("./unmanic/component")),
|
||||
unraid: dynamic(() => import("./unraid/component")),
|
||||
uptimekuma: dynamic(() => import("./uptimekuma/component")),
|
||||
uptimerobot: dynamic(() => import("./uptimerobot/component")),
|
||||
urbackup: dynamic(() => import("./urbackup/component")),
|
||||
|
||||
@@ -29,18 +29,23 @@ export default function Component({ service }) {
|
||||
);
|
||||
}
|
||||
|
||||
// evcc v0.207 changed the API structure so its no longer under 'result'
|
||||
const data = stateData.result ?? stateData;
|
||||
|
||||
// broken by evcc v0.133.0 https://github.com/evcc-io/evcc/commit/9dcb1fa0a7c08dd926b79309aa1f676a5fc6c8aa
|
||||
const gridPower = stateData.result.gridPower ?? stateData.result.grid?.power ?? 0;
|
||||
const gridPower = data.gridPower ?? data.grid?.power ?? 0;
|
||||
|
||||
// Sum chargePower of all loadpoints
|
||||
const totalChargePower = Array.isArray(data.loadpoints)
|
||||
? data.loadpoints.reduce((sum, lp) => sum + (lp.chargePower ?? 0), 0)
|
||||
: 0;
|
||||
|
||||
return (
|
||||
<Container service={service}>
|
||||
<Block label="evcc.pv_power" value={`${toKilowatts(t, stateData.result.pvPower)} ${t("evcc.kilowatt")}`} />
|
||||
<Block label="evcc.pv_power" value={`${toKilowatts(t, data.pvPower)} ${t("evcc.kilowatt")}`} />
|
||||
<Block label="evcc.grid_power" value={`${toKilowatts(t, gridPower)} ${t("evcc.kilowatt")}`} />
|
||||
<Block label="evcc.home_power" value={`${toKilowatts(t, stateData.result.homePower)} ${t("evcc.kilowatt")}`} />
|
||||
<Block
|
||||
label="evcc.charge_power"
|
||||
value={`${toKilowatts(t, stateData.result.loadpoints[0].chargePower)} ${t("evcc.kilowatt")}`}
|
||||
/>
|
||||
<Block label="evcc.home_power" value={`${toKilowatts(t, data.homePower)} ${t("evcc.kilowatt")}`} />
|
||||
<Block label="evcc.charge_power" value={`${toKilowatts(t, totalChargePower)} ${t("evcc.kilowatt")}`} />
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
@@ -24,7 +24,7 @@ export default function Component({ service }) {
|
||||
<Container service={service}>
|
||||
<div
|
||||
className={classNames(
|
||||
"bg-theme-200/50 dark:bg-theme-900/20 rounded-sm m-1 flex-1 flex flex-col items-center justify-center text-center",
|
||||
"bg-theme-200/50 dark:bg-theme-900/20 rounded-sm m-1 flex-1 flex flex-col items-center justify-center text-center scheme-light",
|
||||
"service-block",
|
||||
)}
|
||||
>
|
||||
|
||||
@@ -23,10 +23,13 @@ export default function Component({ service }) {
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
const space = spaceData.results ? spaceData.results[0] : spaceData[0];
|
||||
|
||||
return (
|
||||
<Container service={service}>
|
||||
<Block label="tandoor.users" value={spaceData[0]?.user_count} />
|
||||
<Block label="tandoor.recipes" value={spaceData[0]?.recipe_count} />
|
||||
<Block label="tandoor.users" value={space?.user_count} />
|
||||
<Block label="tandoor.recipes" value={space?.recipe_count} />
|
||||
<Block label="tandoor.keywords" value={keywordData.count} />
|
||||
</Container>
|
||||
);
|
||||
|
||||
93
src/widgets/unraid/component.jsx
Normal file
93
src/widgets/unraid/component.jsx
Normal file
@@ -0,0 +1,93 @@
|
||||
import Block from "components/services/widget/block";
|
||||
import Container from "components/services/widget/container";
|
||||
import { useTranslation } from "next-i18next";
|
||||
|
||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||
|
||||
const UNRAID_DEFAULT_FIELDS = ["status", "cpu", "memoryPercent", "notifications"];
|
||||
const MAX_ALLOWED_FIELDS = 4;
|
||||
|
||||
const POOLS = ["pool1", "pool2", "pool3", "pool4"];
|
||||
const POOL_FIELDS = [
|
||||
{ param: "UsedSpace", label: "poolUsed", valueKey: "fsUsed", valueType: "common.bytes" },
|
||||
{ param: "FreeSpace", label: "poolFree", valueKey: "fsFree", valueType: "common.bytes" },
|
||||
{ param: "UsedPercent", label: "poolUsed", valueKey: "fsUsedPercent", valueType: "common.percent" },
|
||||
];
|
||||
|
||||
export default function Component({ service }) {
|
||||
const { t } = useTranslation();
|
||||
const { widget } = service;
|
||||
|
||||
const { data, error } = useWidgetAPI(widget);
|
||||
|
||||
if (error) {
|
||||
return <Container service={service} error={error} />;
|
||||
}
|
||||
|
||||
if (!widget.fields?.length) {
|
||||
widget.fields = UNRAID_DEFAULT_FIELDS;
|
||||
} else if (widget.fields.length > MAX_ALLOWED_FIELDS) {
|
||||
widget.fields = widget.fields.slice(0, MAX_ALLOWED_FIELDS);
|
||||
}
|
||||
|
||||
if (!data) {
|
||||
return (
|
||||
<Container service={service}>
|
||||
<Block label="unraid.status" />
|
||||
<Block label="unraid.memoryAvailable" />
|
||||
<Block label="unraid.memoryUsed" />
|
||||
<Block field="unraid.memoryPercent" label="unraid.memoryUsed" />
|
||||
<Block label="unraid.cpu" />
|
||||
<Block label="unraid.notifications" />
|
||||
<Block field="unraid.arrayUsedSpace" label="unraid.arrayUsed" />
|
||||
<Block field="unraid.arrayFree" label="unraid.arrayFree" />
|
||||
<Block field="unraid.arrayUsedPercent" label="unraid.arrayUsed" />
|
||||
{...POOLS.flatMap((pool) =>
|
||||
POOL_FIELDS.map(({ param, label }) => (
|
||||
<Block
|
||||
key={`${pool}-${param}`}
|
||||
field={`unraid.${pool}${param}`}
|
||||
label={t(`unraid.${label}`, { pool: widget?.[pool] || pool })}
|
||||
/>
|
||||
)),
|
||||
)}
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
|
||||
return (
|
||||
<Container service={service}>
|
||||
<Block label="unraid.status" value={t(`unraid.${data.arrayState}`)} />
|
||||
<Block label="unraid.memoryAvailable" value={t("common.bbytes", { value: data.memoryAvailable })} />
|
||||
<Block label="unraid.memoryUsed" value={t("common.bbytes", { value: data.memoryUsed })} />
|
||||
<Block
|
||||
field="unraid.memoryPercent"
|
||||
label="unraid.memoryUsed"
|
||||
value={t("common.percent", { value: data.memoryUsedPercent })}
|
||||
/>
|
||||
<Block label="unraid.cpu" value={t("common.percent", { value: data.cpuPercent })} />
|
||||
<Block label="unraid.notifications" value={t("common.number", { value: data.unreadNotifications })} />
|
||||
<Block
|
||||
field="unraid.arrayUsedSpace"
|
||||
label="unraid.arrayUsed"
|
||||
value={t("common.bytes", { value: data.arrayUsed })}
|
||||
/>
|
||||
<Block label="unraid.arrayFree" value={t("common.bytes", { value: data.arrayFree })} />
|
||||
<Block
|
||||
field="unraid.arrayUsedPercent"
|
||||
label="unraid.arrayUsed"
|
||||
value={t("common.percent", { value: data.arrayUsedPercent })}
|
||||
/>
|
||||
{...POOLS.flatMap((pool) =>
|
||||
POOL_FIELDS.map(({ param, label, valueKey, valueType }) => (
|
||||
<Block
|
||||
key={`${pool}-${param}`}
|
||||
field={`unraid.${pool}${param}`}
|
||||
label={t(`unraid.${label}`, { pool: widget?.[pool] || pool })}
|
||||
value={t(valueType, { value: data.caches?.[widget?.[pool]]?.[valueKey] || "-" })}
|
||||
/>
|
||||
)),
|
||||
)}
|
||||
</Container>
|
||||
);
|
||||
}
|
||||
138
src/widgets/unraid/proxy.js
Normal file
138
src/widgets/unraid/proxy.js
Normal file
@@ -0,0 +1,138 @@
|
||||
import getServiceWidget from "utils/config/service-helpers";
|
||||
import createLogger from "utils/logger";
|
||||
import { asJson } from "utils/proxy/api-helpers";
|
||||
import { httpProxy } from "utils/proxy/http";
|
||||
|
||||
const logger = createLogger("unraidProxyHandler");
|
||||
|
||||
const graphqlQuery = `
|
||||
{
|
||||
array {
|
||||
state
|
||||
capacity {
|
||||
kilobytes {
|
||||
free
|
||||
total
|
||||
used
|
||||
}
|
||||
}
|
||||
caches {
|
||||
name
|
||||
fsType
|
||||
fsSize
|
||||
fsFree
|
||||
fsUsed
|
||||
}
|
||||
}
|
||||
metrics {
|
||||
memory {
|
||||
active
|
||||
available
|
||||
percentTotal
|
||||
}
|
||||
cpu {
|
||||
percentTotal
|
||||
}
|
||||
}
|
||||
notifications {
|
||||
overview {
|
||||
unread {
|
||||
total
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
`;
|
||||
|
||||
function processUnraidResponse(data) {
|
||||
const response = {};
|
||||
|
||||
try {
|
||||
data = asJson(data)?.data;
|
||||
|
||||
response["memoryUsedPercent"] = data?.metrics?.memory?.percentTotal ?? null;
|
||||
response["memoryUsed"] = data?.metrics?.memory?.active ?? null;
|
||||
response["memoryAvailable"] = data?.metrics?.memory?.available ?? null;
|
||||
response["cpuPercent"] = data?.metrics?.cpu?.percentTotal ?? null;
|
||||
response["unreadNotifications"] = data?.notifications?.overview?.unread?.total ?? null;
|
||||
response["arrayState"] = data?.array?.state ?? null;
|
||||
response["arrayFree"] = data?.array?.capacity?.kilobytes?.free * 1000 ?? null;
|
||||
response["arrayUsed"] = data?.array?.capacity?.kilobytes?.used * 1000 ?? null;
|
||||
response["arrayUsedPercent"] =
|
||||
(data?.array?.capacity?.kilobytes?.used / data?.array?.capacity?.kilobytes?.total) * 100 ?? null;
|
||||
|
||||
response["caches"] = {};
|
||||
if (data?.array?.caches) {
|
||||
data.array.caches.forEach((cache) => {
|
||||
if (cache.fsType) {
|
||||
response.caches[cache.name] = {
|
||||
fsFree: cache.fsFree * 1000,
|
||||
fsUsed: cache.fsUsed * 1000,
|
||||
fsUsedPercent: (cache.fsUsed / cache.fsSize) * 100 ?? null,
|
||||
};
|
||||
}
|
||||
});
|
||||
}
|
||||
} catch (error) {
|
||||
return { error: error.message };
|
||||
}
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
export default async function unraidProxyHandler(req, res) {
|
||||
const { group, service, index } = req.query;
|
||||
|
||||
if (!group || !service) {
|
||||
logger.debug("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, index);
|
||||
if (!widget) {
|
||||
logger.debug("Invalid or missing widget for service '%s' in group '%s'", service, group);
|
||||
return res.status(400).json({ error: "Invalid proxy service type" });
|
||||
}
|
||||
|
||||
const url = new URL(widget.url + "/graphql");
|
||||
|
||||
const headers = {
|
||||
"Content-Type": "application/json",
|
||||
Accept: `application/json`,
|
||||
"X-API-Key": `${widget.key}`,
|
||||
};
|
||||
|
||||
const params = {
|
||||
method: "POST",
|
||||
headers,
|
||||
};
|
||||
params.body = JSON.stringify({
|
||||
query: graphqlQuery,
|
||||
});
|
||||
|
||||
const [status, , data] = await httpProxy(url, params);
|
||||
|
||||
if (status === 204 || status === 304) {
|
||||
return res.status(status).end();
|
||||
}
|
||||
|
||||
if (status !== 200) {
|
||||
logger.error(
|
||||
"Error getting data from Unraid for service '%s' in group '%s': %d. Data: %s",
|
||||
service,
|
||||
group,
|
||||
status,
|
||||
data,
|
||||
);
|
||||
return res.status(status).send({ error: { message: "Error calling Unraid API.", data } });
|
||||
}
|
||||
|
||||
const result = processUnraidResponse(data);
|
||||
if (result.error) {
|
||||
logger.error("Error processing Unraid data: %s", result.error);
|
||||
return res.status(500).json({ error: result.error });
|
||||
}
|
||||
|
||||
res.setHeader("Content-Type", "application/json");
|
||||
return res.status(status).send(result);
|
||||
}
|
||||
7
src/widgets/unraid/widget.js
Normal file
7
src/widgets/unraid/widget.js
Normal file
@@ -0,0 +1,7 @@
|
||||
import unraidProxyHandler from "./proxy";
|
||||
|
||||
const widget = {
|
||||
proxyHandler: unraidProxyHandler,
|
||||
};
|
||||
|
||||
export default widget;
|
||||
@@ -31,6 +31,10 @@ export default function Component({ service }) {
|
||||
);
|
||||
}
|
||||
|
||||
if (uptimerobotData.error) {
|
||||
return <Container service={service} error={uptimerobotData.error} />;
|
||||
}
|
||||
|
||||
// multiple monitors
|
||||
if (uptimerobotData.pagination?.total > 1) {
|
||||
const sitesUp = uptimerobotData.monitors.filter((m) => m.status === 2).length;
|
||||
|
||||
@@ -130,6 +130,7 @@ import truenas from "./truenas/widget";
|
||||
import tubearchivist from "./tubearchivist/widget";
|
||||
import unifi from "./unifi/widget";
|
||||
import unmanic from "./unmanic/widget";
|
||||
import unraid from "./unraid/widget";
|
||||
import uptimekuma from "./uptimekuma/widget";
|
||||
import uptimerobot from "./uptimerobot/widget";
|
||||
import urbackup from "./urbackup/widget";
|
||||
@@ -278,6 +279,7 @@ const widgets = {
|
||||
unifi,
|
||||
unifi_console: unifi,
|
||||
unmanic,
|
||||
unraid,
|
||||
uptimekuma,
|
||||
uptimerobot,
|
||||
urbackup,
|
||||
|
||||
Reference in New Issue
Block a user