Compare commits

...

60 Commits

Author SHA1 Message Date
Crowdin Bot
3b3f82472c New Crowdin translations by GitHub Action 2025-09-27 12:11:57 +00:00
AdamWHY2K
8f756d4084 Enhancement: Add size of torrent(s) in leechProgress list to qbittorrent widget (#5803) 2025-09-26 23:28:15 -07:00
Yevhen Kuzmovych
02089a35ee Feature: Your spotify widget (#5813)
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2025-09-24 21:08:15 -07:00
shamoon
4028194830 Bump version to 1.5.0 2025-09-22 08:18:10 -07:00
shamoon
4c04a7a45f Merge branch 'dev' 2025-09-22 08:17:08 -07:00
github-actions[bot]
ce344a9db5 New Crowdin translations by GitHub Action (#5800)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-09-22 07:57:35 -07:00
github-actions[bot]
8e90ece498 New Crowdin translations by GitHub Action (#5695)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-09-21 16:30:51 -07:00
shamoon
151ad552ca Fix: dont lose color when switching light / dark (#5796) 2025-09-21 16:29:37 -07:00
shamoon
251cb65e12 Enhancement: mobile QuickLaunch button (#5789) 2025-09-18 22:52:16 -07:00
Ariel David Buena
8ebd0d0b2e Documentation: fix typo (#5770) 2025-09-11 18:46:27 -07:00
shamoon
c20f71738b Change Crowdin project link in sponsors.md 2025-09-10 19:48:31 -07:00
shamoon
78b73e8166 Refactor basic auth header generation 2025-09-04 10:23:43 -07:00
dependabot[bot]
547ef0c4c5 Chore(deps): Bump actions/setup-python from 5 to 6 (#5746)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-04 16:55:44 +00:00
dependabot[bot]
11d148fff0 Chore(deps): Bump actions/setup-node from 4 to 5 (#5747)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-04 16:44:40 +00:00
dependabot[bot]
eb61d69626 Chore(deps): Bump actions/stale from 9 to 10 (#5745)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-04 16:29:39 +00:00
dependabot[bot]
876304cda5 Chore(deps): Bump actions/github-script from 7 to 8 (#5744)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-04 09:13:22 -07:00
dNhax
65dce6d387 Enhancement: support multiple proxmox nodes (#5539)
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2025-09-04 08:49:41 +00:00
Derek Kaser
7b60a60d4e Feature: Backrest widget (#5741)
Co-authored-by: Renan Greca <renangreca@gmail.com>
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2025-09-03 21:47:10 +00:00
dependabot[bot]
8d37cad871 Chore(deps): Bump next from 15.4.5 to 15.5.2 (#5738)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-03 20:09:13 +00:00
dependabot[bot]
cd25ae3258 Chore(deps): Bump recharts from 2.15.3 to 3.1.2 (#5739)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-03 20:01:08 +00:00
dependabot[bot]
a27cdbc284 Chore(deps): Bump tough-cookie from 5.1.2 to 6.0.0 (#5737)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-03 19:32:00 +00:00
dependabot[bot]
e772ef0ad1 Chore(deps): Bump gamedig from 5.2.0 to 5.3.1 (#5736)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-03 19:23:44 +00:00
dependabot[bot]
8cc00ae09a Chore(deps): Bump @headlessui/react from 1.7.19 to 2.2.7 (#5735)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-09-03 12:14:04 -07:00
shamoon
f4efc71350 Update jellyseerr.md 2025-08-29 17:22:41 -07:00
AdamWHY2K
b663e56174 Enhancement: Add issues field to Jellyseerr widget (#5725)
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2025-08-29 18:14:13 +00:00
shamoon
5fe5a3869e Chore: update mkdocs (#5708) 2025-08-23 16:21:30 -07:00
Kieran
a9ec5aa1e7 Documentation: Document needed permissions for Immich (#5706) 2025-08-23 20:28:08 +00:00
shamoon
44405b4aae Merge branch 'main' into dev 2025-08-21 13:06:07 -07:00
Derek Kaser
842cec2fee Feature: Unraid widget (#5683)
Co-authored-by: shamoon <4887959+shamoon@users.noreply.github.com>
2025-08-21 18:06:49 +00:00
shamoon
c6ad937619 Bump version to 1.4.6 2025-08-21 06:55:46 -07:00
shamoon
a6ab095ff9 Update component.jsx 2025-08-20 13:29:43 -07:00
shamoon
9a085bcb17 Enhancement: handle authentik v2025.8.0 breaking API changes (#5687) 2025-08-20 13:27:21 -07:00
github-actions[bot]
6d7be1c7f2 New Crowdin translations by GitHub Action (#5679)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-08-18 23:55:25 -07:00
shamoon
25cd51cee9 Update repo-maintenance.yml 2025-08-18 23:54:22 -07:00
Vincent Verdeil
495de204d1 Documentation: fix typo in docs/configs/settings.md (#5671) 2025-08-14 17:30:48 -07:00
shamoon
8e5f4d55c9 Bump version to 1.4.5 2025-08-13 06:44:47 -07:00
shamoon
184fd65c76 Update resources.js 2025-08-13 06:44:47 -07:00
shamoon
15817f9b27 Update package.json 2025-08-13 06:35:11 -07:00
shamoon
79671ac30e Merge branch 'dev' 2025-08-13 06:17:38 -07:00
github-actions[bot]
1d5db612fd New Crowdin translations by GitHub Action (#5655)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-08-13 06:16:35 -07:00
shamoon
d30016304b Security: refactor disk resource lookup logic (#5666) 2025-08-13 06:16:12 -07:00
Markus Thierolf
f0fd125e37 Enhancement: summarize charge power of all loadpoints in evcc widget (#5663) 2025-08-12 08:46:23 -07:00
dependabot[bot]
9ed4b85d5a Chore(deps): Bump actions/checkout from 4 to 5 (#5660)
Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2025-08-11 17:21:06 -07:00
shamoon
f607d806d0 Bump version to 1.4.4 2025-08-08 11:32:46 -04:00
shamoon
c0ddb5f816 Merge branch 'dev' 2025-08-08 11:32:29 -04:00
github-actions[bot]
fc563532e1 New Crowdin translations by GitHub Action (#5626)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-08-08 11:28:06 -04:00
shamoon
98248903c6 Enhancement: support Tandoor v2 api structure (#5646) 2025-08-06 15:57:02 -04:00
shamoon
5870111d11 Enhancement: Auto-request geolocation if permission already granted (#5638) 2025-08-04 23:16:22 -04:00
shamoon
bb23c25690 Fix: try to restore iframe transparency by restoring light scheme (#5637) 2025-08-04 23:01:26 -04:00
shamoon
4084c8dafc Add fields to trilium docs 2025-08-04 14:52:10 -04:00
Matan Heimann
cb1dde1b79 Documentation: fix missing references to Wallos documentation doc (#5633)
Co-authored-by: MH <m@terramail.co>
2025-08-04 14:50:15 -04:00
shamoon
1691711a52 Bump version to 1.4.3 2025-08-03 11:02:00 -04:00
shamoon
b5d8f6c01c Merge branch 'dev' 2025-08-03 11:01:44 -04:00
github-actions[bot]
db86b5408a New Crowdin translations by GitHub Action (#5614)
Co-authored-by: Crowdin Bot <support+bot@crowdin.com>
2025-08-03 11:01:23 -04:00
shamoon
4be2c2868b Fix bg opacity calculation (#5622) 2025-08-03 10:52:45 -04:00
Yann Hodiesne
c6197a9f92 Fix: properly handle UptimeRobot errors (#5621) 2025-08-03 10:50:26 -04:00
shamoon
dd861d7d1c Enhancement: handle evcc 0.207 breaking change (#5619) 2025-08-03 08:12:19 -04:00
shamoon
e65f8c46f9 Update package.json 2025-08-02 18:52:19 -04:00
shamoon
082e1316c1 Fix: set body background color (#5611) 2025-08-02 17:44:35 -04:00
shamoon
a4b5e72d82 Fix: properly handle classlist with light theme (#5612) 2025-08-02 17:38:00 -04:00
97 changed files with 4983 additions and 2548 deletions

View File

@@ -17,7 +17,7 @@ jobs:
steps: steps:
- name: Checkout - name: Checkout
uses: actions/checkout@v4 uses: actions/checkout@v5
- name: crowdin action - name: crowdin action
uses: crowdin/github-action@v2 uses: crowdin/github-action@v2
with: with:

View File

@@ -22,10 +22,10 @@ jobs:
runs-on: ubuntu-22.04 runs-on: ubuntu-22.04
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v5
- name: Install python - name: Install python
uses: actions/setup-python@v5 uses: actions/setup-python@v6
with: with:
python-version: 3.x python-version: 3.x
@@ -38,7 +38,7 @@ jobs:
run_install: false run_install: false
- name: Setup Node.js - name: Setup Node.js
uses: actions/setup-node@v4 uses: actions/setup-node@v5
with: with:
node-version: 20 node-version: 20
cache: 'pnpm' cache: 'pnpm'
@@ -61,7 +61,7 @@ jobs:
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v5
- name: Extract Docker metadata - name: Extract Docker metadata
id: meta id: meta
@@ -96,7 +96,7 @@ jobs:
run_install: false run_install: false
- name: Setup Node.js - name: Setup Node.js
uses: actions/setup-node@v4 uses: actions/setup-node@v5
with: with:
node-version: 20 node-version: 20
cache: 'pnpm' cache: 'pnpm'

View File

@@ -17,9 +17,9 @@ jobs:
runs-on: ubuntu-22.04 runs-on: ubuntu-22.04
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v5
- name: Install python - name: Install python
uses: actions/setup-python@v5 uses: actions/setup-python@v6
with: with:
python-version: 3.x python-version: 3.x
- name: Check files - name: Check files
@@ -32,8 +32,8 @@ jobs:
needs: needs:
- pre-commit - pre-commit
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v5
- uses: actions/setup-python@v5 - uses: actions/setup-python@v6
with: with:
python-version: 3.x python-version: 3.x
- run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV - run: echo "cache_id=$(date --utc '+%V')" >> $GITHUB_ENV
@@ -54,12 +54,12 @@ jobs:
needs: needs:
- pre-commit - pre-commit
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v5
- name: Configure Git Credentials - name: Configure Git Credentials
run: | run: |
git config user.name github-actions[bot] git config user.name github-actions[bot]
git config user.email 41898282+github-actions[bot]@users.noreply.github.com git config user.email 41898282+github-actions[bot]@users.noreply.github.com
- uses: actions/setup-python@v5 - uses: actions/setup-python@v6
with: with:
python-version: 3.x python-version: 3.x
- run: echo "cache_id=${{github.sha}}" >> $GITHUB_ENV - run: echo "cache_id=${{github.sha}}" >> $GITHUB_ENV

View File

@@ -18,7 +18,7 @@ jobs:
name: 'Stale' name: 'Stale'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/stale@v9 - uses: actions/stale@v10
with: with:
days-before-stale: 7 days-before-stale: 7
days-before-close: 14 days-before-close: 14
@@ -57,7 +57,7 @@ jobs:
name: 'Close Answered Discussions' name: 'Close Answered Discussions'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/github-script@v7 - uses: actions/github-script@v8
with: with:
script: | script: |
function sleep(ms) { function sleep(ms) {
@@ -113,7 +113,7 @@ jobs:
name: 'Close Outdated Discussions' name: 'Close Outdated Discussions'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/github-script@v7 - uses: actions/github-script@v8
with: with:
script: | script: |
function sleep(ms) { function sleep(ms) {
@@ -204,7 +204,7 @@ jobs:
name: 'Close Unsupported Feature Requests' name: 'Close Unsupported Feature Requests'
runs-on: ubuntu-latest runs-on: ubuntu-latest
steps: steps:
- uses: actions/github-script@v7 - uses: actions/github-script@v8
with: with:
script: | script: |
function sleep(ms) { function sleep(ms) {
@@ -212,9 +212,9 @@ jobs:
} }
const CUTOFF_1_DAYS = 180; const CUTOFF_1_DAYS = 180;
const CUTOFF_1_COUNT = 10; const CUTOFF_1_COUNT = 20;
const CUTOFF_2_DAYS = 365; const CUTOFF_2_DAYS = 365;
const CUTOFF_2_COUNT = 20; const CUTOFF_2_COUNT = 40;
const cutoff1Date = new Date(); const cutoff1Date = new Date();
cutoff1Date.setDate(cutoff1Date.getDate() - CUTOFF_1_DAYS); cutoff1Date.setDate(cutoff1Date.getDate() - CUTOFF_1_DAYS);

View File

@@ -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. - 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 with a marked answer will be automatically closed.
- Discussions in the 'General' or 'Support' categories will be closed after 180 days of inactivity. - 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. 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. Finally, remember that all information remains searchable and 'closed' feature requests can still serve as inspiration for new features.

View File

@@ -4,11 +4,13 @@ description: Proxmox Configuration
--- ---
The Proxmox connection is configured in the `proxmox.yaml` file. See [Create token](#create-token) section below for details on how to generate the required API token. The Proxmox connection is configured in the `proxmox.yaml` file. See [Create token](#create-token) section below for details on how to generate the required API token.
You can configure multiple nodes - be sure to use the exact `proxmoxNode` identifier!
```yaml ```yaml
url: https://proxmox.host.or.ip:8006 pve:
token: username@pam!Token ID url: https://proxmox.host.or.ip:8006
secret: secret token: username@pam!Token ID
secret: secret
``` ```
## Services ## Services
@@ -17,7 +19,7 @@ Once the Proxmox connection is configured, individual services can be configured
### Configuration Options ### Configuration Options
- `proxmoxNode`: The name of the Proxmox node where your VM/LXC is running - `proxmoxNode`: The name of the Proxmox node where your VM/LXC is running, must match with a node configured in the `proxmox.yaml`
- `proxmoxVMID`: The ID of the Proxmox VM or LXC container - `proxmoxVMID`: The ID of the Proxmox VM or LXC container
- `proxmoxType`: (Optional) The type of Proxmox virtual machine. Defaults to `qemu` for VMs, but can be set to `lxc` for LXC containers - `proxmoxType`: (Optional) The type of Proxmox virtual machine. Defaults to `qemu` for VMs, but can be set to `lxc` for LXC containers

View File

@@ -264,7 +264,7 @@ fullWidth: true
### Maximum Group Columns ### 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 ```yaml
maxGroupColumns: 8 # default is 4 for services, 6 for bookmarks, max 8 maxGroupColumns: 8 # default is 4 for services, 6 for bookmarks, max 8
@@ -441,6 +441,7 @@ There are a few optional settings for the Quick Launch feature:
- `showSearchSuggestions`: show search suggestions for the internet search. If this is not specified then the setting will be inherited from the search widget. If it is not specified there either, it will default to false. For custom providers the `suggestionUrl` needs to be set in order for this to work. - `showSearchSuggestions`: show search suggestions for the internet search. If this is not specified then the setting will be inherited from the search widget. If it is not specified there either, it will default to false. For custom providers the `suggestionUrl` needs to be set in order for this to work.
- `provider`: search engine provider. If none is specified it will try to use the provider set for the Search Widget, if neither are present then internet search will be disabled. - `provider`: search engine provider. If none is specified it will try to use the provider set for the Search Widget, if neither are present then internet search will be disabled.
- `hideVisitURL`: disable detecting and offering an option to open URLs. This is false by default, enabling the feature. - `hideVisitURL`: disable detecting and offering an option to open URLs. This is false by default, enabling the feature.
- `mobileButtonPosition`: enables and sets the position of the mobile quicklaunch button. Options are `top-left`, `top-right`, `bottom-left`, `bottom-right`. This is empty by default, disabling the feature.
```yaml ```yaml
quicklaunch: quicklaunch:

View File

@@ -28,7 +28,7 @@ These companies help the Homepage project by providing services, tools, and reso
</div> </div>
<div style="margin-bottom: 16px;"> <div style="margin-bottom: 16px;">
<a href="https://crowdin.com/project/homepage"><img src="https://support.crowdin.com/assets/logos/core-logo/png/crowdin-core-logo-cWhite.png" alt="Crowdin" style="max-width: 100%; height: 64px; display: block;" /></a> <a href="https://crowdin.com/project/gethomepage"><img src="https://support.crowdin.com/assets/logos/core-logo/png/crowdin-core-logo-cWhite.png" alt="Crowdin" style="max-width: 100%; height: 64px; display: block;" /></a>
<p> <p>
Crowdin provides the translation platform for the project. Making it easy to translate the project into multiple languages. Crowdin provides the translation platform for the project. Making it easy to translate the project into multiple languages.
</p> </p>

View File

@@ -32,7 +32,7 @@ More detail on configuring service widgets can be found in the [Service Widgets
## Info Widgets ## Info Widgets
Info widgets are used to display information in the header, often about your system or environment. Info widgets are defined your `widgets.yaml` file. Here's an example: Info widgets are used to display information in the header, often about your system or environment. Info widgets are defined in your `widgets.yaml` file. Here's an example:
```yaml ```yaml
- openmeteo: - openmeteo:

View File

@@ -17,9 +17,15 @@ The account you made the API token for also needs the following **Assigned globa
Allowed fields: `["users", "loginsLast24H", "failedLoginsLast24H"]`. Allowed fields: `["users", "loginsLast24H", "failedLoginsLast24H"]`.
| Authentik Version | Homepage Widget Version |
| ----------------- | ----------------------- |
| < 2025.8.0 | 1 (default) |
| >= 2025.8.0 | 2 |
```yaml ```yaml
widget: widget:
type: authentik type: authentik
url: http://authentik.host.or.ip:port url: http://authentik.host.or.ip:port
key: api_token key: api_token
version: 2 # optional, default is 1
``` ```

View File

@@ -0,0 +1,17 @@
---
title: Backrest
description: Backrest Widget Configuration
---
[Backrest](https://garethgeorge.github.io/backrest/) is a web-based frontend for
the [Restic](https://restic.net/) backup tool.
**Allowed fields:** `["num_success_latest","num_failure_latest","num_success_30","num_plans","num_failure_30","bytes_added_30"]`
```yaml
widget:
type: backrest
url: http://backrest.host.or.ip
username: admin # optional if auth is enabled in Backrest
password: admin # optional if auth is enabled in Backrest
```

View File

@@ -10,7 +10,8 @@ Learn more about [Immich](https://github.com/immich-app/immich).
| < v1.118 | 1 (default) | | < v1.118 | 1 (default) |
| >= v1.118 | 2 | | >= v1.118 | 2 |
Find your API key under `Account Settings > API Keys`. Find your API key under `Account Settings > API Keys`. The key should have the
`server.statistics` permission.
Allowed fields: `["users" ,"photos", "videos", "storage"]`. Allowed fields: `["users" ,"photos", "videos", "storage"]`.

View File

@@ -15,6 +15,7 @@ You can also find a list of all available service widgets in the sidebar navigat
- [Authentik](authentik.md) - [Authentik](authentik.md)
- [Autobrr](autobrr.md) - [Autobrr](autobrr.md)
- [Azure DevOps](azuredevops.md) - [Azure DevOps](azuredevops.md)
- [Backrest](backrest.md)
- [Bazarr](bazarr.md) - [Bazarr](bazarr.md)
- [Beszel](beszel.md) - [Beszel](beszel.md)
- [Caddy](caddy.md) - [Caddy](caddy.md)
@@ -139,10 +140,12 @@ You can also find a list of all available service widgets in the sidebar navigat
- [TubeArchivist](tubearchivist.md) - [TubeArchivist](tubearchivist.md)
- [UniFi Controller](unifi-controller.md) - [UniFi Controller](unifi-controller.md)
- [Unmanic](unmanic.md) - [Unmanic](unmanic.md)
- [Unraid](unraid.md)
- [Uptime Kuma](uptime-kuma.md) - [Uptime Kuma](uptime-kuma.md)
- [UptimeRobot](uptimerobot.md) - [UptimeRobot](uptimerobot.md)
- [UrBackup](urbackup.md) - [UrBackup](urbackup.md)
- [Vikunja](vikunja.md) - [Vikunja](vikunja.md)
- [Wallos](wallos.md)
- [Watchtower](watchtower.md) - [Watchtower](watchtower.md)
- [WGEasy](wgeasy.md) - [WGEasy](wgeasy.md)
- [WhatsUpDocker](whatsupdocker.md) - [WhatsUpDocker](whatsupdocker.md)

View File

@@ -7,7 +7,8 @@ Learn more about [Jellyseerr](https://github.com/Fallenbagel/jellyseerr).
Find your API key under `Settings > General > API Key`. Find your API key under `Settings > General > API Key`.
Allowed fields: `["pending", "approved", "available"]`. Allowed fields: `["pending", "approved", "available", "issues"]`.
Default fields: `["pending", "approved", "available"]`.
```yaml ```yaml
widget: widget:

View File

@@ -16,4 +16,5 @@ widget:
username: username username: username
password: password password: password
enableLeechProgress: true # optional, defaults to false enableLeechProgress: true # optional, defaults to false
enableLeechSize: true # optional, defaults to false
``` ```

View File

@@ -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`. Find (or create) your ETAPI key under `Options > ETAPI > Create new ETAPI token`.
Allowed fields: `["version", "notesCount", "dbSize"]`
```yaml ```yaml
widget: widget:
type: trilium type: trilium

View 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
```

View File

@@ -0,0 +1,28 @@
---
title: Your Spotify
description: Your Spotify Widget Configuration
---
Learn more about [Your Spotify](https://github.com/Yooooomi/your_spotify).
Find your API key under `Settings > Account > Public token`, click `Generate` if not yet generated, copy key after
`?token=`.
Allowed fields: `["songs", "time", "artists"]`.
```yaml
widget:
type: yourspotify
url: http://your-spotify-server.host.or.ip # if using lsio image, add /api/
key: apikeyapikeyapikeyapikeyapikey
interval: month # optional, defaults to week
```
#### Interval
Allowed values for `interval`: `day`, `week`, `month`, `year`, `all`.
!!! note
`interval` is different from predefined intervals you see in `Your Spotify`'s UI.
For example, `This week` in UI means _from the start of this week_, here `week` means _past 7 days_.

View File

@@ -39,6 +39,7 @@ nav:
- widgets/services/authentik.md - widgets/services/authentik.md
- widgets/services/autobrr.md - widgets/services/autobrr.md
- widgets/services/azuredevops.md - widgets/services/azuredevops.md
- widgets/services/backrest.md
- widgets/services/bazarr.md - widgets/services/bazarr.md
- widgets/services/beszel.md - widgets/services/beszel.md
- widgets/services/caddy.md - widgets/services/caddy.md
@@ -165,14 +166,17 @@ nav:
- widgets/services/tubearchivist.md - widgets/services/tubearchivist.md
- widgets/services/unifi-controller.md - widgets/services/unifi-controller.md
- widgets/services/unmanic.md - widgets/services/unmanic.md
- widgets/services/unraid.md
- widgets/services/uptime-kuma.md - widgets/services/uptime-kuma.md
- widgets/services/uptimerobot.md - widgets/services/uptimerobot.md
- widgets/services/urbackup.md - widgets/services/urbackup.md
- widgets/services/vikunja.md - widgets/services/vikunja.md
- widgets/services/wallos.md
- widgets/services/watchtower.md - widgets/services/watchtower.md
- widgets/services/wgeasy.md - widgets/services/wgeasy.md
- widgets/services/whatsupdocker.md - widgets/services/whatsupdocker.md
- widgets/services/xteve.md - widgets/services/xteve.md
- widgets/services/yourspotify.md
- widgets/services/zabbix.md - widgets/services/zabbix.md
- "Information Widgets": - "Information Widgets":
- widgets/info/index.md - widgets/info/index.md

View File

@@ -1,6 +1,6 @@
{ {
"name": "homepage", "name": "homepage",
"version": "1.4.1", "version": "1.5.0",
"private": true, "private": true,
"scripts": { "scripts": {
"preinstall": "npx only-allow pnpm", "preinstall": "npx only-allow pnpm",
@@ -11,13 +11,13 @@
"telemetry": "next telemetry disable" "telemetry": "next telemetry disable"
}, },
"dependencies": { "dependencies": {
"@headlessui/react": "^1.7.19", "@headlessui/react": "^2.2.7",
"@kubernetes/client-node": "^1.0.0", "@kubernetes/client-node": "^1.0.0",
"classnames": "^2.5.1", "classnames": "^2.5.1",
"compare-versions": "^6.1.1", "compare-versions": "^6.1.1",
"dockerode": "^4.0.7", "dockerode": "^4.0.7",
"follow-redirects": "^1.15.11", "follow-redirects": "^1.15.11",
"gamedig": "^5.2.0", "gamedig": "^5.3.1",
"i18next": "^24.2.3", "i18next": "^24.2.3",
"ical.js": "^2.1.0", "ical.js": "^2.1.0",
"js-yaml": "^4.1.0", "js-yaml": "^4.1.0",
@@ -25,7 +25,7 @@
"luxon": "^3.6.1", "luxon": "^3.6.1",
"memory-cache": "^0.2.0", "memory-cache": "^0.2.0",
"minecraftstatuspinger": "^1.2.2", "minecraftstatuspinger": "^1.2.2",
"next": "^15.4.5", "next": "^15.5.2",
"next-i18next": "^12.1.0", "next-i18next": "^12.1.0",
"ping": "^0.4.4", "ping": "^0.4.4",
"pretty-bytes": "^6.1.1", "pretty-bytes": "^6.1.1",
@@ -34,10 +34,10 @@
"react-dom": "^18.3.1", "react-dom": "^18.3.1",
"react-i18next": "^15.5.3", "react-i18next": "^15.5.3",
"react-icons": "^5.4.0", "react-icons": "^5.4.0",
"recharts": "^2.15.3", "recharts": "^3.1.2",
"swr": "^2.3.3", "swr": "^2.3.3",
"systeminformation": "^5.27.7", "systeminformation": "^5.27.7",
"tough-cookie": "^5.1.2", "tough-cookie": "^6.0.0",
"urbackup-server-api": "^0.8.9", "urbackup-server-api": "^0.8.9",
"winston": "^3.17.0", "winston": "^3.17.0",
"xml-js": "^1.6.11" "xml-js": "^1.6.11"
@@ -72,6 +72,7 @@
}, },
"pnpm": { "pnpm": {
"onlyBuiltDependencies": [ "onlyBuiltDependencies": [
"osx-temperature-sensor",
"sharp" "sharp"
] ]
} }

679
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Afwagtend", "pending": "Afwagtend",
"approved": "Goedgekeur", "approved": "Goedgekeur",
"available": "Beskikbaar" "available": "Beskikbaar",
"issues": "Oop Kwessies"
}, },
"overseerr": { "overseerr": {
"pending": "Afwagtend", "pending": "Afwagtend",
@@ -1073,15 +1074,50 @@
"containers": "Houers" "containers": "Houers"
}, },
"filebrowser": { "filebrowser": {
"available": "Available", "available": "Beskikbaar",
"used": "Used", "used": "Gebruik",
"total": "Total" "total": "Totaal"
}, },
"wallos": { "wallos": {
"activeSubscriptions": "Subscriptions", "activeSubscriptions": "Intekeninge",
"thisMonthlyCost": "This Month", "thisMonthlyCost": "Hierdie Maand",
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Volgende Maand",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Vorige Maand",
"nextRenewingSubscription": "Next Payment" "nextRenewingSubscription": "Volgende paaiement"
},
"unraid": {
"STARTED": "Begin",
"STOPPED": "Gestop",
"NEW_ARRAY": "Nuwe Skikking",
"RECON_DISK": "Rekonstruksie van Skyf",
"DISABLE_DISK": "Skyf Gedeaktiveer",
"SWAP_DSBL": "Ruil Gedeaktiveer",
"INVALID_EXPANSION": "Ongeldige Uitbreiding",
"PARITY_NOT_BIGGEST": "Pariteit nie die grootste nie",
"TOO_MANY_MISSING_DISKS": "Te Veel Ontbrekende Skywe",
"NEW_DISK_TOO_SMALL": "Nuwe Skyf te Klein",
"NO_DATA_DISKS": "Geen Data Skywe",
"notifications": "Kennisgewings",
"status": "Status",
"cpu": "SVE",
"memoryUsed": "Geheue Gebruik",
"memoryAvailable": "Geheue Beskikbaar",
"arrayUsed": "Skikking Gebruik",
"arrayFree": "Skikking Vry",
"poolUsed": "{{pool}} Gebruik",
"poolFree": "{{pool}} Vry"
},
"backrest": {
"num_plans": "Planne",
"num_success_30": "Suksesse",
"num_failure_30": "Mislukkings",
"num_success_latest": "Slaag",
"num_failure_latest": "Mislukking",
"bytes_added_30": "Grepe bygevoeg"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Wartend", "pending": "Wartend",
"approved": "Genehmigt", "approved": "Genehmigt",
"available": "Verfügbar" "available": "Verfügbar",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Wartend", "pending": "Wartend",
@@ -629,9 +630,9 @@
}, },
"opnsense": { "opnsense": {
"cpu": "CPU-Last", "cpu": "CPU-Last",
"memory": "Aktiver RAM", "memory": "RAM aktiv",
"wanUpload": "WAN-Upload", "wanUpload": "WAN Up",
"wanDownload": "WAN-Download" "wanDownload": "WAN Down"
}, },
"moonraker": { "moonraker": {
"printer_state": "Druckerstatus", "printer_state": "Druckerstatus",
@@ -785,7 +786,7 @@
"downloadCount": "Warteschlange", "downloadCount": "Warteschlange",
"downloadBytesRemaining": "Verbleibend", "downloadBytesRemaining": "Verbleibend",
"downloadTotalBytes": "Größe", "downloadTotalBytes": "Größe",
"downloadSpeed": "Geschwindigkeit" "downloadSpeed": "Datenrate"
}, },
"kavita": { "kavita": {
"seriesCount": "Serien", "seriesCount": "Serien",
@@ -996,8 +997,8 @@
"beszel": { "beszel": {
"name": "Name", "name": "Name",
"systems": "Systeme", "systems": "Systeme",
"up": "Offline", "up": "Up",
"down": "Offline", "down": "Down",
"paused": "Pausiert", "paused": "Pausiert",
"pending": "Wartend", "pending": "Wartend",
"status": "Status", "status": "Status",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Nächster Monat", "nextMonthlyCost": "Nächster Monat",
"previousMonthlyCost": "Vorh. Monat", "previousMonthlyCost": "Vorh. Monat",
"nextRenewingSubscription": "Nächste Zahlung" "nextRenewingSubscription": "Nächste Zahlung"
},
"unraid": {
"STARTED": "Gestartet",
"STOPPED": "Angehalten",
"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}} verwendet",
"poolFree": "{{pool}} frei"
},
"backrest": {
"num_plans": "Pläne",
"num_success_30": "Erfolgreich",
"num_failure_30": "Fehlerhaft",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Titel",
"time": "Zeit",
"artists": "Künstler"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -30,7 +30,7 @@
"response_data": "Données de réponse" "response_data": "Données de réponse"
}, },
"weather": { "weather": {
"current": "Localisation actuelle", "current": "Emplacement actuel",
"allow": "Cliquez pour autoriser", "allow": "Cliquez pour autoriser",
"updating": "Mise à jour", "updating": "Mise à jour",
"wait": "Veuillez patienter" "wait": "Veuillez patienter"
@@ -47,7 +47,7 @@
"load": "Charge", "load": "Charge",
"temp": "Température", "temp": "Température",
"max": "Max", "max": "Max",
"uptime": "Démarré depuis" "uptime": "Actif"
}, },
"unifi": { "unifi": {
"users": "Utilisateurs", "users": "Utilisateurs",
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "En attente", "pending": "En attente",
"approved": "Approuvé", "approved": "Approuvé",
"available": "Disponible" "available": "Disponible",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "En attente", "pending": "En attente",
@@ -439,8 +440,8 @@
"cpu": "CPU", "cpu": "CPU",
"load": "Charge", "load": "Charge",
"wait": "Veuillez patienter", "wait": "Veuillez patienter",
"temp": "Température", "temp": "TEMP",
"_temp": "Température", "_temp": "Temp",
"warn": "Alerte", "warn": "Alerte",
"uptime": "Démarré depuis", "uptime": "Démarré depuis",
"total": "Total", "total": "Total",
@@ -655,7 +656,7 @@
"wanStatus": "Statut WAN", "wanStatus": "Statut WAN",
"up": "Haut", "up": "Haut",
"down": "Bas", "down": "Bas",
"temp": "Température", "temp": "Temp",
"disk": "Util. Disque", "disk": "Util. Disque",
"wanIP": "IP WAN" "wanIP": "IP WAN"
}, },
@@ -1073,15 +1074,50 @@
"containers": "Conteneurs" "containers": "Conteneurs"
}, },
"filebrowser": { "filebrowser": {
"available": "Available", "available": "Disponible",
"used": "Used", "used": "Utilisé",
"total": "Total" "total": "Total"
}, },
"wallos": { "wallos": {
"activeSubscriptions": "Subscriptions", "activeSubscriptions": "Abonnements",
"thisMonthlyCost": "This Month", "thisMonthlyCost": "Ce mois",
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Mois prochain",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Mois précédent",
"nextRenewingSubscription": "Next Payment" "nextRenewingSubscription": "Prochain paiement"
},
"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": "État",
"cpu": "UCT",
"memoryUsed": "Mémoire Utilisé",
"memoryAvailable": "Mémoire Disponible",
"arrayUsed": "Array Used",
"arrayFree": "Array Free",
"poolUsed": "{{pool}} Used",
"poolFree": "{{pool}} Free"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "ממתין לאישור", "pending": "ממתין לאישור",
"approved": "מאושר", "approved": "מאושר",
"available": "זמין" "available": "זמין",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "ממתין לאישור", "pending": "ממתין לאישור",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "חודש הבא", "nextMonthlyCost": "חודש הבא",
"previousMonthlyCost": "חודש קודם", "previousMonthlyCost": "חודש קודם",
"nextRenewingSubscription": "תשלום הבא" "nextRenewingSubscription": "תשלום הבא"
},
"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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -61,16 +61,16 @@
"wlan_devices": "WLAN Eszközök", "wlan_devices": "WLAN Eszközök",
"lan_users": "LAN Felhasználók", "lan_users": "LAN Felhasználók",
"wlan_users": "WLAN Felhasználók", "wlan_users": "WLAN Felhasználók",
"up": "UP", "up": "FUT",
"down": "ÁLL", "down": "ÁLL",
"wait": "Please wait", "wait": "Kérjük várjon",
"empty_data": "Az alrendszer állapota ismeretlen" "empty_data": "Az alrendszer állapota ismeretlen"
}, },
"docker": { "docker": {
"rx": "RX", "rx": "RX",
"tx": "TX", "tx": "TX",
"mem": "MEM", "mem": "MEM",
"cpu": "CPU", "cpu": "Processzor",
"running": "Futó", "running": "Futó",
"offline": "Nem elérhető", "offline": "Nem elérhető",
"error": "Hiba", "error": "Hiba",
@@ -93,8 +93,8 @@
"http_status": "HTTP állapot", "http_status": "HTTP állapot",
"error": "Hiba", "error": "Hiba",
"response": "Válasz", "response": "Válasz",
"down": "Down", "down": "Leállt",
"up": "Up", "up": "Fut",
"not_available": "Nem elérhető" "not_available": "Nem elérhető"
}, },
"emby": { "emby": {
@@ -108,10 +108,10 @@
"songs": "Zeneszám" "songs": "Zeneszám"
}, },
"esphome": { "esphome": {
"offline": "Offline", "offline": "Nem elérhető",
"offline_alt": "Offline", "offline_alt": "Nem elérhető",
"online": "Csatlakozva", "online": "Csatlakozva",
"total": "Total", "total": "Összes",
"unknown": "Ismeretlen" "unknown": "Ismeretlen"
}, },
"evcc": { "evcc": {
@@ -133,7 +133,7 @@
"unread": "Olvasatlan" "unread": "Olvasatlan"
}, },
"fritzbox": { "fritzbox": {
"connectionStatus": "Status", "connectionStatus": "Státusz",
"connectionStatusUnconfigured": "Nem beállított", "connectionStatusUnconfigured": "Nem beállított",
"connectionStatusConnecting": "Kapcsolódás", "connectionStatusConnecting": "Kapcsolódás",
"connectionStatusAuthenticating": "Hitelesítés", "connectionStatusAuthenticating": "Hitelesítés",
@@ -141,16 +141,16 @@
"connectionStatusDisconnecting": "Kapcsolat bontása", "connectionStatusDisconnecting": "Kapcsolat bontása",
"connectionStatusDisconnected": "Kapcsolat bontva", "connectionStatusDisconnected": "Kapcsolat bontva",
"connectionStatusConnected": "Csatlakozva", "connectionStatusConnected": "Csatlakozva",
"uptime": "Uptime", "uptime": "Működési idő",
"maxDown": "Max let.", "maxDown": "Max let.",
"maxUp": "Max felt.", "maxUp": "Max felt.",
"down": "Down", "down": "Leállt",
"up": "Up", "up": "Fut",
"received": "Fogadott", "received": "Fogadott",
"sent": "Küldött", "sent": "Küldött",
"externalIPAddress": "Külső IP cím", "externalIPAddress": "Külső IP cím",
"externalIPv6Address": "Ext. IPv6", "externalIPv6Address": "Küls. IPv6",
"externalIPv6Prefix": "Ext. IPv6-Prefix" "externalIPv6Prefix": "Küls. IPv6-Prefix"
}, },
"caddy": { "caddy": {
"upstreams": "Upstreamek", "upstreams": "Upstreamek",
@@ -168,17 +168,17 @@
"passes": "Engedélyek" "passes": "Engedélyek"
}, },
"tautulli": { "tautulli": {
"playing": "Playing", "playing": "Lejátszás",
"transcoding": "Transcoding", "transcoding": "Transzkódolás",
"bitrate": "Bitrate", "bitrate": "Bitráta",
"no_active": "No Active Streams", "no_active": "Nincs aktív lejátszás",
"plex_connection_error": "Plex kapcsolat ellenőrzése" "plex_connection_error": "Plex kapcsolat ellenőrzése"
}, },
"omada": { "omada": {
"connectedAp": "Csatlakoztatott AP-k", "connectedAp": "Csatlakoztatott AP-k",
"activeUser": "Aktív eszközök", "activeUser": "Aktív eszközök",
"alerts": "Riasztások", "alerts": "Riasztások",
"connectedGateways": "Connected gateways", "connectedGateways": "Csatlakoztatott gateway-ek",
"connectedSwitches": "Csatlakoztatott switch-ek" "connectedSwitches": "Csatlakoztatott switch-ek"
}, },
"nzbget": { "nzbget": {
@@ -189,11 +189,11 @@
"plex": { "plex": {
"streams": "Aktív Stream-ek", "streams": "Aktív Stream-ek",
"albums": "Albumok", "albums": "Albumok",
"movies": "Movies", "movies": "Filmek",
"tv": "TV műsorok" "tv": "TV műsorok"
}, },
"sabnzbd": { "sabnzbd": {
"rate": "Rate", "rate": "Ráta",
"queue": "Sor", "queue": "Sor",
"timeleft": "Hátralévő idő" "timeleft": "Hátralévő idő"
}, },
@@ -233,34 +233,34 @@
"cachemissbytes": "Gyorsítótárban Hibás Bitek" "cachemissbytes": "Gyorsítótárban Hibás Bitek"
}, },
"downloadstation": { "downloadstation": {
"download": "Download", "download": "Letöltés",
"upload": "Upload", "upload": "Feltöltés",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
"sonarr": { "sonarr": {
"wanted": "Keresett", "wanted": "Keresett",
"queued": "Sorban áll", "queued": "Sorban áll",
"series": "Series", "series": "Sorozatok",
"queue": "Queue", "queue": "Várólista",
"unknown": "Unknown" "unknown": "Ismeretlen"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "Keresett",
"missing": "Hiányzik", "missing": "Hiányzik",
"queued": "Queued", "queued": "Sorban áll",
"movies": "Movies", "movies": "Filmek",
"queue": "Queue", "queue": "Várólista",
"unknown": "Unknown" "unknown": "Ismeretlen"
}, },
"lidarr": { "lidarr": {
"wanted": "Wanted", "wanted": "Keresett",
"queued": "Queued", "queued": "Sorban áll",
"artists": "Előadók" "artists": "Előadók"
}, },
"readarr": { "readarr": {
"wanted": "Wanted", "wanted": "Keresett",
"queued": "Queued", "queued": "Sorban áll",
"books": "Könyvek" "books": "Könyvek"
}, },
"bazarr": { "bazarr": {
@@ -273,19 +273,20 @@
"available": "Elérhető" "available": "Elérhető"
}, },
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Függőben lévő",
"approved": "Approved", "approved": "Jóváhagyott",
"available": "Available" "available": "Elérhető",
"issues": "Nyitott problémák"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Függőben lévő",
"processing": "Feldolgozás", "processing": "Feldolgozás",
"approved": "Approved", "approved": "Jóváhagyott",
"available": "Available" "available": "Elérhető"
}, },
"netalertx": { "netalertx": {
"total": "Total", "total": "Összes",
"connected": "Connected", "connected": "Csatlakoztatott",
"new_devices": "Új eszközök", "new_devices": "Új eszközök",
"down_alerts": "Leállási riasztások" "down_alerts": "Leállási riasztások"
}, },
@@ -296,26 +297,26 @@
"gravity": "Gravitáció" "gravity": "Gravitáció"
}, },
"adguard": { "adguard": {
"queries": "Queries", "queries": "Lekérdezések",
"blocked": "Blocked", "blocked": "Blokkolt",
"filtered": "Szűrt", "filtered": "Szűrt",
"latency": "Késleltetés" "latency": "Késleltetés"
}, },
"speedtest": { "speedtest": {
"upload": "Upload", "upload": "Feltöltés",
"download": "Download", "download": "Letöltés",
"ping": "Ping" "ping": "Ping"
}, },
"portainer": { "portainer": {
"running": "Running", "running": "Folyamatban",
"stopped": "Megállított", "stopped": "Megállított",
"total": "Total" "total": "Összes"
}, },
"suwayomi": { "suwayomi": {
"download": "Downloaded", "download": "Letöltött",
"nondownload": "Nem Letöltött", "nondownload": "Nem Letöltött",
"read": "Read", "read": "Olvasott",
"unread": "Unread", "unread": "Olvasatlan",
"downloadedread": "Letöltött & Olvasott", "downloadedread": "Letöltött & Olvasott",
"downloadedunread": "Letöltött & Olvasatlan", "downloadedunread": "Letöltött & Olvasatlan",
"nondownloadedread": "Nem Letöltött & Olvasatlan", "nondownloadedread": "Nem Letöltött & Olvasatlan",
@@ -336,7 +337,7 @@
"ago": "{{value}} Ezelőtt" "ago": "{{value}} Ezelőtt"
}, },
"technitium": { "technitium": {
"totalQueries": "Queries", "totalQueries": "Lekérdezések",
"totalNoError": "Sikerek", "totalNoError": "Sikerek",
"totalServerFailure": "Hibák", "totalServerFailure": "Hibák",
"totalNxDomain": "NX Domainek", "totalNxDomain": "NX Domainek",
@@ -344,12 +345,12 @@
"totalAuthoritative": "Irányadó", "totalAuthoritative": "Irányadó",
"totalRecursive": "Rekurzív", "totalRecursive": "Rekurzív",
"totalCached": "Gyorsítótárazott", "totalCached": "Gyorsítótárazott",
"totalBlocked": "Blocked", "totalBlocked": "Blokkolt",
"totalDropped": "Eldobott", "totalDropped": "Eldobott",
"totalClients": "Kliensek" "totalClients": "Kliensek"
}, },
"tdarr": { "tdarr": {
"queue": "Queue", "queue": "Várólista",
"processed": "Feldolgozott", "processed": "Feldolgozott",
"errored": "Hibás", "errored": "Hibás",
"saved": "Mentett" "saved": "Mentett"
@@ -360,19 +361,19 @@
"middleware": "Közvetítő" "middleware": "Közvetítő"
}, },
"trilium": { "trilium": {
"version": "Version", "version": "Verzió",
"notesCount": "Notes", "notesCount": "Jegyzetek",
"dbSize": "Database Size", "dbSize": "Adatbázis mérete",
"unknown": "Unknown" "unknown": "Ismeretlen"
}, },
"navidrome": { "navidrome": {
"nothing_streaming": "No Active Streams", "nothing_streaming": "Nincs aktív lejátszás",
"please_wait": "Kérjük Várjon" "please_wait": "Kérjük Várjon"
}, },
"npm": { "npm": {
"enabled": "Bekapcsolva", "enabled": "Bekapcsolva",
"disabled": "Kikapcsolva", "disabled": "Kikapcsolva",
"total": "Total" "total": "Összes"
}, },
"coinmarketcap": { "coinmarketcap": {
"configure": "Állíts be egy vagy több Cryptovalutát a követéshez", "configure": "Állíts be egy vagy több Cryptovalutát a követéshez",
@@ -383,73 +384,73 @@
}, },
"gotify": { "gotify": {
"apps": "Applikációk", "apps": "Applikációk",
"clients": "Clients", "clients": "Kliensek",
"messages": "Üzenetek" "messages": "Üzenetek"
}, },
"prowlarr": { "prowlarr": {
"enableIndexers": "Indexerek", "enableIndexers": "Indexerek",
"numberOfGrabs": "Fogott", "numberOfGrabs": "Fogott",
"numberOfQueries": "Queries", "numberOfQueries": "Lekérdezések",
"numberOfFailGrabs": "Hibás fogások", "numberOfFailGrabs": "Hibás fogások",
"numberOfFailQueries": "Hibás lekérdezések" "numberOfFailQueries": "Hibás lekérdezések"
}, },
"jackett": { "jackett": {
"configured": "Beállított", "configured": "Beállított",
"errored": "Errored" "errored": "Hibák"
}, },
"strelaysrv": { "strelaysrv": {
"numActiveSessions": "Munkamenetek", "numActiveSessions": "Munkamenetek",
"numConnections": "Csatlakozások", "numConnections": "Csatlakozások",
"dataRelayed": "Átirányított", "dataRelayed": "Átirányított",
"transferRate": "Rate" "transferRate": "Ráta"
}, },
"mastodon": { "mastodon": {
"user_count": "Users", "user_count": "Felhasználók",
"status_count": "Posztok", "status_count": "Posztok",
"domain_count": "Domainek" "domain_count": "Domainek"
}, },
"medusa": { "medusa": {
"wanted": "Wanted", "wanted": "Keresett",
"queued": "Queued", "queued": "Sorban áll",
"series": "Series" "series": "Sorozatok"
}, },
"minecraft": { "minecraft": {
"players": "Lejátszók", "players": "Lejátszók",
"version": "Verzió", "version": "Verzió",
"status": "Status", "status": "Státusz",
"up": "Online", "up": "Kapcsolódva",
"down": "Offline" "down": "Nem elérhető"
}, },
"miniflux": { "miniflux": {
"read": "Olvasott", "read": "Olvasott",
"unread": "Unread" "unread": "Olvasatlan"
}, },
"authentik": { "authentik": {
"users": "Users", "users": "Felhasználók",
"loginsLast24H": "Bejelentkezések (24 óra)", "loginsLast24H": "Bejelentkezések (24 óra)",
"failedLoginsLast24H": "Sikertelen bejelentkezések (24h)" "failedLoginsLast24H": "Sikertelen bejelentkezések (24h)"
}, },
"proxmox": { "proxmox": {
"mem": "MEM", "mem": "MEM",
"cpu": "CPU", "cpu": "Processzor",
"lxc": "LXC-k", "lxc": "LXC-k",
"vms": "VM-ek" "vms": "VM-ek"
}, },
"glances": { "glances": {
"cpu": "CPU", "cpu": "Processzor",
"load": "Load", "load": "Terhelés",
"wait": "Please wait", "wait": "Kérem várjon",
"temp": "TEMP", "temp": "HŐM",
"_temp": "Hőmérséklet", "_temp": "Hőmérséklet",
"warn": "Figyelmeztet", "warn": "Figyelmeztet",
"uptime": "UP", "uptime": "FUT",
"total": "Total", "total": "Összes",
"free": "Free", "free": "Szabad",
"used": "Used", "used": "Felhasznált",
"days": "d", "days": "n",
"hours": "h", "hours": "ó",
"crit": "Kritikus", "crit": "Kritikus",
"read": "Read", "read": "Olvasott",
"write": "Írás", "write": "Írás",
"gpu": "GPU", "gpu": "GPU",
"mem": "Memória", "mem": "Memória",
@@ -470,57 +471,57 @@
"1-day": "Többnyire napos", "1-day": "Többnyire napos",
"1-night": "Többnyire derült", "1-night": "Többnyire derült",
"2-day": "Részben felhős", "2-day": "Részben felhős",
"2-night": "Partly Cloudy", "2-night": "Részben felhős",
"3-day": "Felhős", "3-day": "Felhős",
"3-night": "Cloudy", "3-night": "Felhős",
"45-day": "Ködös", "45-day": "Ködös",
"45-night": "Foggy", "45-night": "Ködös",
"48-day": "Foggy", "48-day": "Ködös",
"48-night": "Foggy", "48-night": "Ködös",
"51-day": "Enyhe szitálás", "51-day": "Enyhe szitálás",
"51-night": "Light Drizzle", "51-night": "Enyhe szitálás",
"53-day": "Szitálás", "53-day": "Szitálás",
"53-night": "Drizzle", "53-night": "Szitálás",
"55-day": "Erős szitálás", "55-day": "Erős szitálás",
"55-night": "Heavy Drizzle", "55-night": "Erős szitálás",
"56-day": "Enyhe fagyos szitálás", "56-day": "Enyhe fagyos szitálás",
"56-night": "Light Freezing Drizzle", "56-night": "Enyhe fagyos szitálás",
"57-day": "Fagyos szitálás", "57-day": "Fagyos szitálás",
"57-night": "Freezing Drizzle", "57-night": "Fagyos szitálás",
"61-day": "Enyhe eső", "61-day": "Enyhe eső",
"61-night": "Light Rain", "61-night": "Enyhe eső",
"63-day": "Eső", "63-day": "Eső",
"63-night": "Rain", "63-night": "Eső",
"65-day": "Heves eső", "65-day": "Heves eső",
"65-night": "Heavy Rain", "65-night": "Heves eső",
"66-day": "Ónos eső", "66-day": "Ónos eső",
"66-night": "Freezing Rain", "66-night": "Ónos eső",
"67-day": "Freezing Rain", "67-day": "Ónos eső",
"67-night": "Freezing Rain", "67-night": "Ónos eső",
"71-day": "Enyhe havazás", "71-day": "Enyhe havazás",
"71-night": "Light Snow", "71-night": "Enyhe havazás",
"73-day": "Hó", "73-day": "Hó",
"73-night": "Snow", "73-night": "Havazás",
"75-day": "Erős havazás", "75-day": "Erős havazás",
"75-night": "Heavy Snow", "75-night": "Erős havazás",
"77-day": "Hódara", "77-day": "Hódara",
"77-night": "Snow Grains", "77-night": "Hódara",
"80-day": "Enyhe záporok", "80-day": "Enyhe záporok",
"80-night": "Light Showers", "80-night": "Enyhe záporok",
"81-day": "Záporok", "81-day": "Záporok",
"81-night": "Showers", "81-night": "Záporok",
"82-day": "Heves záporok", "82-day": "Heves záporok",
"82-night": "Heavy Showers", "82-night": "Heves záporok",
"85-day": "Hózáporok", "85-day": "Hózáporok",
"85-night": "Snow Showers", "85-night": "Hózáporok",
"86-day": "Snow Showers", "86-day": "Hózáporok",
"86-night": "Snow Showers", "86-night": "Hózáporok",
"95-day": "Zivatar", "95-day": "Zivatar",
"95-night": "Thunderstorm", "95-night": "Vihar",
"96-day": "Zivatar jégesővel", "96-day": "Zivatar jégesővel",
"96-night": "Thunderstorm With Hail", "96-night": "Zivatar jégesővel",
"99-day": "Thunderstorm With Hail", "99-day": "Zivatar jégesővel",
"99-night": "Thunderstorm With Hail" "99-night": "Zivatar jégesővel"
}, },
"homebridge": { "homebridge": {
"available_update": "Rendszer", "available_update": "Rendszer",
@@ -529,17 +530,17 @@
"up_to_date": "Naprakész", "up_to_date": "Naprakész",
"child_bridges": "Gyerek Hidak", "child_bridges": "Gyerek Hidak",
"child_bridges_status": "{{ok}}/{{total}}", "child_bridges_status": "{{ok}}/{{total}}",
"up": "Up", "up": "Fut",
"pending": "Pending", "pending": "Függőben lévő",
"down": "Down" "down": "Leállt"
}, },
"healthchecks": { "healthchecks": {
"new": "Új", "new": "Új",
"up": "Up", "up": "Fut",
"grace": "Türelmi idő alatt", "grace": "Türelmi idő alatt",
"down": "Down", "down": "Leállt",
"paused": "Szünetel", "paused": "Szünetel",
"status": "Status", "status": "Státusz",
"last_ping": "Legutóbbi Ping", "last_ping": "Legutóbbi Ping",
"never": "Még nincsenek ping-ek" "never": "Még nincsenek ping-ek"
}, },
@@ -549,21 +550,21 @@
"containers_failed": "Sikertelen" "containers_failed": "Sikertelen"
}, },
"autobrr": { "autobrr": {
"approvedPushes": "Approved", "approvedPushes": "Jóváhagyott",
"rejectedPushes": "Elutasított", "rejectedPushes": "Elutasított",
"filters": "Szűrők", "filters": "Szűrők",
"indexers": "Indexers" "indexers": "Indexerek"
}, },
"tubearchivist": { "tubearchivist": {
"downloads": "Queue", "downloads": "Várólista",
"videos": "Videók", "videos": "Videók",
"channels": "Csatornák", "channels": "Csatornák",
"playlists": "Lejátszási listák" "playlists": "Lejátszási listák"
}, },
"truenas": { "truenas": {
"load": "Rendszerterhelés", "load": "Rendszerterhelés",
"uptime": "Uptime", "uptime": "Működési idő",
"alerts": "Alerts" "alerts": "Figyelmeztetések"
}, },
"pyload": { "pyload": {
"speed": "Sebesség", "speed": "Sebesség",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -241,16 +241,16 @@
"sonarr": { "sonarr": {
"wanted": "Poszukiwane", "wanted": "Poszukiwane",
"queued": "W kolejce", "queued": "W kolejce",
"series": "Series", "series": "Seriale",
"queue": "Queue", "queue": "Kolejka",
"unknown": "Unknown" "unknown": "Nieznany"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "Poszukiwane",
"missing": "Brakujące", "missing": "Brakujące",
"queued": "Queued", "queued": "W kolejce",
"movies": "Movies", "movies": "Filmy",
"queue": "Queue", "queue": "Kolejka",
"unknown": "Unknown" "unknown": "Unknown"
}, },
"lidarr": { "lidarr": {
@@ -273,15 +273,16 @@
"available": "Dostępne" "available": "Dostępne"
}, },
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Oczekujące",
"approved": "Approved", "approved": "Zaakceptowane",
"available": "Available" "available": "Dostępne",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Oczekujące",
"processing": "Przetwarzane", "processing": "Przetwarzane",
"approved": "Approved", "approved": "Zaakceptowane",
"available": "Available" "available": "Dostępne"
}, },
"netalertx": { "netalertx": {
"total": "Total", "total": "Total",
@@ -296,8 +297,8 @@
"gravity": "Grawitacja" "gravity": "Grawitacja"
}, },
"adguard": { "adguard": {
"queries": "Queries", "queries": "Zapytania",
"blocked": "Blocked", "blocked": "Zablokowane",
"filtered": "Przefiltrowane", "filtered": "Przefiltrowane",
"latency": "Opóźnienia" "latency": "Opóźnienia"
}, },
@@ -312,7 +313,7 @@
"total": "Total" "total": "Total"
}, },
"suwayomi": { "suwayomi": {
"download": "Downloaded", "download": "Pobrano",
"nondownload": "Niepobrane", "nondownload": "Niepobrane",
"read": "Read", "read": "Read",
"unread": "Unread", "unread": "Unread",
@@ -366,7 +367,7 @@
"unknown": "Unknown" "unknown": "Unknown"
}, },
"navidrome": { "navidrome": {
"nothing_streaming": "No Active Streams", "nothing_streaming": "Brak aktywnych strumieni",
"please_wait": "Proszę czekać" "please_wait": "Proszę czekać"
}, },
"npm": { "npm": {
@@ -425,33 +426,33 @@
"unread": "Unread" "unread": "Unread"
}, },
"authentik": { "authentik": {
"users": "Users", "users": "Użytkownicy",
"loginsLast24H": "Logowania (24h)", "loginsLast24H": "Logowania (24h)",
"failedLoginsLast24H": "Nieudane logowania (24h)" "failedLoginsLast24H": "Nieudane logowania (24h)"
}, },
"proxmox": { "proxmox": {
"mem": "MEM", "mem": "RAM",
"cpu": "Procesor", "cpu": "Procesor",
"lxc": "Kontenery LXC", "lxc": "Kontenery LXC",
"vms": "Maszyn wirtualnych" "vms": "Maszyn wirtualnych"
}, },
"glances": { "glances": {
"cpu": "Procesor", "cpu": "Procesor",
"load": "Load", "load": "Obciążenie",
"wait": "Proszę czekać", "wait": "Proszę czekać",
"temp": "TEMP", "temp": "TEMP.",
"_temp": "Temperatura", "_temp": "Temperatura",
"warn": "Ostrzeżenie", "warn": "Ostrzeżenie",
"uptime": "UP", "uptime": "UP",
"total": "Total", "total": "Total",
"free": "Free", "free": "Wolne",
"used": "Used", "used": "Used",
"days": "d", "days": "d",
"hours": "h", "hours": "h",
"crit": "Krytyczyny", "crit": "Krytyczyny",
"read": "Read", "read": "Read",
"write": "Zapis", "write": "Zapis",
"gpu": "Karta graficzna", "gpu": "GPU",
"mem": "Pamięć", "mem": "Pamięć",
"swap": "Swap" "swap": "Swap"
}, },
@@ -470,57 +471,57 @@
"1-day": "Głównie słoneczny", "1-day": "Głównie słoneczny",
"1-night": "Głównie bezchmurny", "1-night": "Głównie bezchmurny",
"2-day": "Częściowo pochmurnie", "2-day": "Częściowo pochmurnie",
"2-night": "Partly Cloudy", "2-night": "Częściowo pochmurnie",
"3-day": "Pochmurnie", "3-day": "Pochmurnie",
"3-night": "Cloudy", "3-night": "Pochmurnie",
"45-day": "Mgliście", "45-day": "Mgliście",
"45-night": "Foggy", "45-night": "Mgliście",
"48-day": "Foggy", "48-day": "Mgliście",
"48-night": "Foggy", "48-night": "Mgliście",
"51-day": "Lekka mżawka", "51-day": "Lekka mżawka",
"51-night": "Light Drizzle", "51-night": "Lekka mżawka",
"53-day": "Mżawka", "53-day": "Mżawka",
"53-night": "Drizzle", "53-night": "Mżawka",
"55-day": "Gęsta mżawka", "55-day": "Gęsta mżawka",
"55-night": "Heavy Drizzle", "55-night": "Gęsta mżawka",
"56-day": "Lekko chłodna mżawka", "56-day": "Lekko chłodna mżawka",
"56-night": "Light Freezing Drizzle", "56-night": "Lekko chłodna mżawka",
"57-day": "Chłodna mżawka", "57-day": "Chłodna mżawka",
"57-night": "Freezing Drizzle", "57-night": "Chłodna mżawka",
"61-day": "Lekki deszcz", "61-day": "Lekki deszcz",
"61-night": "Light Rain", "61-night": "Lekki deszcz",
"63-day": "Deszcz", "63-day": "Deszcz",
"63-night": "Rain", "63-night": "Deszcz",
"65-day": "Ciężki deszcz", "65-day": "Ciężki deszcz",
"65-night": "Heavy Rain", "65-night": "Ciężki deszcz",
"66-day": "Mroźny deszcz", "66-day": "Mroźny deszcz",
"66-night": "Freezing Rain", "66-night": "Mroźny deszcz",
"67-day": "Freezing Rain", "67-day": "Mroźny deszcz",
"67-night": "Freezing Rain", "67-night": "Mroźny deszcz",
"71-day": "Lekki śnieg", "71-day": "Lekki śnieg",
"71-night": "Light Snow", "71-night": "Lekki śnieg",
"73-day": "Śnieg", "73-day": "Śnieg",
"73-night": "Snow", "73-night": "Śnieg",
"75-day": "Ciężki śnieg", "75-day": "Ciężki śnieg",
"75-night": "Heavy Snow", "75-night": "Ciężki śnieg",
"77-day": "Ziarnisty śnieg", "77-day": "Ziarnisty śnieg",
"77-night": "Snow Grains", "77-night": "Ziarnisty śnieg",
"80-day": "Lekkie opady", "80-day": "Lekkie opady",
"80-night": "Light Showers", "80-night": "Lekkie opady",
"81-day": "Opady", "81-day": "Opady",
"81-night": "Showers", "81-night": "Opady",
"82-day": "Ciężkie opady", "82-day": "Ciężkie opady",
"82-night": "Heavy Showers", "82-night": "Ciężkie opady",
"85-day": "Opady śniegu", "85-day": "Opady śniegu",
"85-night": "Snow Showers", "85-night": "Opady śniegu",
"86-day": "Snow Showers", "86-day": "Opady śniegu",
"86-night": "Snow Showers", "86-night": "Opady śniegu",
"95-day": "Burze z piorunami", "95-day": "Burze z piorunami",
"95-night": "Thunderstorm", "95-night": "Burze z piorunami",
"96-day": "Burza z gradobiciem", "96-day": "Burza z gradobiciem",
"96-night": "Thunderstorm With Hail", "96-night": "Burza z gradobiciem",
"99-day": "Thunderstorm With Hail", "99-day": "Burza z gradobiciem",
"99-night": "Thunderstorm With Hail" "99-night": "Burza z gradobiciem"
}, },
"homebridge": { "homebridge": {
"available_update": "System", "available_update": "System",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -212,7 +212,7 @@
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Upload",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Semear"
}, },
"qnap": { "qnap": {
"cpuUsage": "Utilização do CPU", "cpuUsage": "Utilização do CPU",
@@ -223,39 +223,39 @@
"invalid": "Inválido" "invalid": "Inválido"
}, },
"deluge": { "deluge": {
"download": "Download", "download": "Baixar",
"upload": "Upload", "upload": "Upload",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Semear"
}, },
"develancacheui": { "develancacheui": {
"cachehitbytes": "Bytes de Acerto na Memória transitória", "cachehitbytes": "Bytes de Acerto na Memória transitória",
"cachemissbytes": "Bytes de Falha de Memória transitória" "cachemissbytes": "Bytes de Falha de Memória transitória"
}, },
"downloadstation": { "downloadstation": {
"download": "Download", "download": "Baixar",
"upload": "Upload", "upload": "Envio de Dados",
"leech": "Leech", "leech": "Sanguessuga",
"seed": "Seed" "seed": "Semear"
}, },
"sonarr": { "sonarr": {
"wanted": "Desejados", "wanted": "Desejados",
"queued": "Em fila de espera", "queued": "Em fila de espera",
"series": "Series", "series": "Séries",
"queue": "Queue", "queue": "Fila",
"unknown": "Unknown" "unknown": "Desconhecido"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "Desejado",
"missing": "Em falta", "missing": "Em falta",
"queued": "Queued", "queued": "Na Fila",
"movies": "Movies", "movies": "Filmes",
"queue": "Queue", "queue": "Fila",
"unknown": "Unknown" "unknown": "Desconhecido"
}, },
"lidarr": { "lidarr": {
"wanted": "Wanted", "wanted": "Desejado",
"queued": "Queued", "queued": "Na Fila",
"artists": "Artistas" "artists": "Artistas"
}, },
"readarr": { "readarr": {
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Próximo mês", "nextMonthlyCost": "Próximo mês",
"previousMonthlyCost": "Mês anterior", "previousMonthlyCost": "Mês anterior",
"nextRenewingSubscription": "Próximo pagamento" "nextRenewingSubscription": "Próximo pagamento"
},
"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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -63,7 +63,7 @@
"wlan_users": "Usuários de WLAN", "wlan_users": "Usuários de WLAN",
"up": "UP", "up": "UP",
"down": "Desligado", "down": "Desligado",
"wait": "Please wait", "wait": "Por favor, aguarde",
"empty_data": "Status do Subsistema desconhecido" "empty_data": "Status do Subsistema desconhecido"
}, },
"docker": { "docker": {
@@ -83,7 +83,7 @@
"partial": "Parcial" "partial": "Parcial"
}, },
"ping": { "ping": {
"error": "Error", "error": "Erro",
"ping": "Tempo de resposta", "ping": "Tempo de resposta",
"down": "Inativo", "down": "Inativo",
"up": "Ativo", "up": "Ativo",
@@ -91,11 +91,11 @@
}, },
"siteMonitor": { "siteMonitor": {
"http_status": "Estado HTTP", "http_status": "Estado HTTP",
"error": "Error", "error": "Erro",
"response": "Resposta", "response": "Resposta",
"down": "Down", "down": "Inativo",
"up": "Up", "up": "Ativo",
"not_available": "Not Available" "not_available": "Não Disponível"
}, },
"emby": { "emby": {
"playing": "A reproduzir", "playing": "A reproduzir",
@@ -112,7 +112,7 @@
"offline_alt": "Offline", "offline_alt": "Offline",
"online": "Disponível", "online": "Disponível",
"total": "Total", "total": "Total",
"unknown": "Unknown" "unknown": "Desconhecido"
}, },
"evcc": { "evcc": {
"pv_power": "Produção", "pv_power": "Produção",
@@ -141,11 +141,11 @@
"connectionStatusDisconnecting": "Desconectando", "connectionStatusDisconnecting": "Desconectando",
"connectionStatusDisconnected": "Desconectado", "connectionStatusDisconnected": "Desconectado",
"connectionStatusConnected": "Conectado", "connectionStatusConnected": "Conectado",
"uptime": "Uptime", "uptime": "Tempo ativo",
"maxDown": "Tempo de inatividade máximo", "maxDown": "Tempo de inatividade máximo",
"maxUp": "Máx. Acima", "maxUp": "Máx. Acima",
"down": "Down", "down": "Inativo",
"up": "Up", "up": "Ativo",
"received": "Recebido", "received": "Recebido",
"sent": "Enviado", "sent": "Enviado",
"externalIPAddress": "IP Externo", "externalIPAddress": "IP Externo",
@@ -168,10 +168,10 @@
"passes": "Passes" "passes": "Passes"
}, },
"tautulli": { "tautulli": {
"playing": "Playing", "playing": "Tocando",
"transcoding": "Transcoding", "transcoding": "Transcodificando",
"bitrate": "Bitrate", "bitrate": "Taxa de bits",
"no_active": "No Active Streams", "no_active": "Sem Streams Ativos",
"plex_connection_error": "Verifique a conexão do Plex" "plex_connection_error": "Verifique a conexão do Plex"
}, },
"omada": { "omada": {
@@ -189,28 +189,28 @@
"plex": { "plex": {
"streams": "Streams Ativas", "streams": "Streams Ativas",
"albums": "Álbuns", "albums": "Álbuns",
"movies": "Movies", "movies": "Filmes",
"tv": "Series de TV" "tv": "Series de TV"
}, },
"sabnzbd": { "sabnzbd": {
"rate": "Rate", "rate": "Taxa",
"queue": "Fila", "queue": "Fila",
"timeleft": "Tempo restante" "timeleft": "Tempo restante"
}, },
"rutorrent": { "rutorrent": {
"active": "Ativo", "active": "Ativo",
"upload": "Upload", "upload": "Carregar",
"download": "Download" "download": "Descarregar"
}, },
"transmission": { "transmission": {
"download": "Download", "download": "Descarregar",
"upload": "Upload", "upload": "Carregar",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
"qbittorrent": { "qbittorrent": {
"download": "Download", "download": "Descarregar",
"upload": "Upload", "upload": "Carregar",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
@@ -223,8 +223,8 @@
"invalid": "Inválido" "invalid": "Inválido"
}, },
"deluge": { "deluge": {
"download": "Download", "download": "Descarregar",
"upload": "Upload", "upload": "Carregar",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
@@ -233,25 +233,25 @@
"cachemissbytes": "Bytes de Falha de Cache" "cachemissbytes": "Bytes de Falha de Cache"
}, },
"downloadstation": { "downloadstation": {
"download": "Download", "download": "Descarregar",
"upload": "Upload", "upload": "Carregar",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
"sonarr": { "sonarr": {
"wanted": "Desejada", "wanted": "Desejada",
"queued": "Em fila", "queued": "Em fila",
"series": "Series", "series": "Séries",
"queue": "Queue", "queue": "Fila",
"unknown": "Unknown" "unknown": "Desconhecido"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "Wanted",
"missing": "Faltando", "missing": "Faltando",
"queued": "Queued", "queued": "Em fila",
"movies": "Movies", "movies": "Filmes",
"queue": "Queue", "queue": "Fila",
"unknown": "Unknown" "unknown": "Desconhecido"
}, },
"lidarr": { "lidarr": {
"wanted": "Wanted", "wanted": "Wanted",
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -241,7 +241,7 @@
"sonarr": { "sonarr": {
"wanted": "Розыск", "wanted": "Розыск",
"queued": "В очереди", "queued": "В очереди",
"series": "Серии", "series": "Сериалы",
"queue": "Очередь", "queue": "Очередь",
"unknown": "Неизвестно" "unknown": "Неизвестно"
}, },
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Ожидают", "pending": "Ожидают",
"approved": "Одобрено", "approved": "Одобрено",
"available": "Доступно" "available": "Доступно",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Ожидают", "pending": "Ожидают",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Следующий месяц", "nextMonthlyCost": "Следующий месяц",
"previousMonthlyCost": "Прошлый месяц", "previousMonthlyCost": "Прошлый месяц",
"nextRenewingSubscription": "Следующая оплата" "nextRenewingSubscription": "Следующая оплата"
},
"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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -61,9 +61,9 @@
"wlan_devices": "Zariadenia WLAN", "wlan_devices": "Zariadenia WLAN",
"lan_users": "Použ. LAN", "lan_users": "Použ. LAN",
"wlan_users": "Použ. WLAN", "wlan_users": "Použ. WLAN",
"up": "UP", "up": "BEŽÍ",
"down": "NEBEŽÍ", "down": "NEBEŽÍ",
"wait": "Please wait", "wait": "Čakajte, prosím",
"empty_data": "Stav podsystému neznámy" "empty_data": "Stav podsystému neznámy"
}, },
"docker": { "docker": {
@@ -94,8 +94,8 @@
"error": "Chyba", "error": "Chyba",
"response": "Odpoveď", "response": "Odpoveď",
"down": "Down", "down": "Down",
"up": "Up", "up": "Beží",
"not_available": "Not Available" "not_available": "Nedostupné"
}, },
"emby": { "emby": {
"playing": "Prehrávané", "playing": "Prehrávané",
@@ -112,7 +112,7 @@
"offline_alt": "Offline", "offline_alt": "Offline",
"online": "Online", "online": "Online",
"total": "Celkom", "total": "Celkom",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"evcc": { "evcc": {
"pv_power": "Produkcia", "pv_power": "Produkcia",
@@ -141,11 +141,11 @@
"connectionStatusDisconnecting": "Odpájanie", "connectionStatusDisconnecting": "Odpájanie",
"connectionStatusDisconnected": "Odpojené", "connectionStatusDisconnected": "Odpojené",
"connectionStatusConnected": "Pripojené", "connectionStatusConnected": "Pripojené",
"uptime": "Uptime", "uptime": "Dostupnosť",
"maxDown": "Max. sťahovanie", "maxDown": "Max. sťahovanie",
"maxUp": "Max. nahrávanie", "maxUp": "Max. nahrávanie",
"down": "Down", "down": "Down",
"up": "Up", "up": "Beží",
"received": "Prijaté", "received": "Prijaté",
"sent": "Odoslané", "sent": "Odoslané",
"externalIPAddress": "Ext. IP", "externalIPAddress": "Ext. IP",
@@ -189,7 +189,7 @@
"plex": { "plex": {
"streams": "Aktívne vysielanie", "streams": "Aktívne vysielanie",
"albums": "Albumy", "albums": "Albumy",
"movies": "Movies", "movies": "Filmov",
"tv": "Seriály" "tv": "Seriály"
}, },
"sabnzbd": { "sabnzbd": {
@@ -199,18 +199,18 @@
}, },
"rutorrent": { "rutorrent": {
"active": "Aktívne", "active": "Aktívne",
"upload": "Upload", "upload": "Nahrávanie",
"download": "Download" "download": "Download"
}, },
"transmission": { "transmission": {
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Nahrávanie",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
"qbittorrent": { "qbittorrent": {
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Nahrávanie",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
@@ -224,7 +224,7 @@
}, },
"deluge": { "deluge": {
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Nahrávanie",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
@@ -234,7 +234,7 @@
}, },
"downloadstation": { "downloadstation": {
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Nahrávanie",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
@@ -242,25 +242,25 @@
"wanted": "Žiadané", "wanted": "Žiadané",
"queued": "V poradí", "queued": "V poradí",
"series": "Series", "series": "Series",
"queue": "Queue", "queue": "Poradie",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "Wanted",
"missing": "Chýbajúce", "missing": "Chýbajúce",
"queued": "Queued", "queued": "V poradí",
"movies": "Movies", "movies": "Filmov",
"queue": "Queue", "queue": "Poradie",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"lidarr": { "lidarr": {
"wanted": "Wanted", "wanted": "Wanted",
"queued": "Queued", "queued": "V poradí",
"artists": "Interpreti" "artists": "Interpreti"
}, },
"readarr": { "readarr": {
"wanted": "Wanted", "wanted": "Wanted",
"queued": "Queued", "queued": "V poradí",
"books": "Knihy" "books": "Knihy"
}, },
"bazarr": { "bazarr": {
@@ -273,19 +273,20 @@
"available": "Dostupné" "available": "Dostupné"
}, },
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Čakajúce",
"approved": "Approved", "approved": "Schválené",
"available": "Available" "available": "Dostupné",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Čakajúce",
"processing": "Spracovávané", "processing": "Spracovávané",
"approved": "Approved", "approved": "Schválené",
"available": "Available" "available": "Dostupné"
}, },
"netalertx": { "netalertx": {
"total": "Total", "total": "Celkom",
"connected": "Connected", "connected": "Pripojené",
"new_devices": "Nové zariadenia", "new_devices": "Nové zariadenia",
"down_alerts": "Upozornenia o výpadkoch" "down_alerts": "Upozornenia o výpadkoch"
}, },
@@ -296,26 +297,26 @@
"gravity": "Gravity" "gravity": "Gravity"
}, },
"adguard": { "adguard": {
"queries": "Queries", "queries": "Požiadaviek",
"blocked": "Blocked", "blocked": "Blokované",
"filtered": "Filtrované", "filtered": "Filtrované",
"latency": "Odozva" "latency": "Odozva"
}, },
"speedtest": { "speedtest": {
"upload": "Upload", "upload": "Nahrávanie",
"download": "Download", "download": "Download",
"ping": "Ping" "ping": "Odozva"
}, },
"portainer": { "portainer": {
"running": "Running", "running": "Beží",
"stopped": "Zastavené", "stopped": "Zastavené",
"total": "Total" "total": "Celkom"
}, },
"suwayomi": { "suwayomi": {
"download": "Downloaded", "download": "Downloaded",
"nondownload": "Non-Downloaded", "nondownload": "Non-Downloaded",
"read": "Read", "read": "Read",
"unread": "Unread", "unread": "Neprečítané",
"downloadedread": "Downloaded & Read", "downloadedread": "Downloaded & Read",
"downloadedunread": "Downloaded & Unread", "downloadedunread": "Downloaded & Unread",
"nondownloadedread": "Non-Downloaded & Read", "nondownloadedread": "Non-Downloaded & Read",
@@ -336,7 +337,7 @@
"ago": "Pred {{value}}" "ago": "Pred {{value}}"
}, },
"technitium": { "technitium": {
"totalQueries": "Queries", "totalQueries": "Požiadaviek",
"totalNoError": "Success", "totalNoError": "Success",
"totalServerFailure": "Failures", "totalServerFailure": "Failures",
"totalNxDomain": "NX Domains", "totalNxDomain": "NX Domains",
@@ -344,12 +345,12 @@
"totalAuthoritative": "Authoritative", "totalAuthoritative": "Authoritative",
"totalRecursive": "Recursive", "totalRecursive": "Recursive",
"totalCached": "Cached", "totalCached": "Cached",
"totalBlocked": "Blocked", "totalBlocked": "Blokované",
"totalDropped": "Dropped", "totalDropped": "Dropped",
"totalClients": "Klienti" "totalClients": "Klienti"
}, },
"tdarr": { "tdarr": {
"queue": "Queue", "queue": "Poradie",
"processed": "Spracované", "processed": "Spracované",
"errored": "Chybné", "errored": "Chybné",
"saved": "Uložené" "saved": "Uložené"
@@ -360,10 +361,10 @@
"middleware": "Midlvér" "middleware": "Midlvér"
}, },
"trilium": { "trilium": {
"version": "Version", "version": "Verzia",
"notesCount": "Notes", "notesCount": "Notes",
"dbSize": "Database Size", "dbSize": "Database Size",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"navidrome": { "navidrome": {
"nothing_streaming": "No Active Streams", "nothing_streaming": "No Active Streams",
@@ -372,7 +373,7 @@
"npm": { "npm": {
"enabled": "Povolené", "enabled": "Povolené",
"disabled": "Zakázané", "disabled": "Zakázané",
"total": "Total" "total": "Celkom"
}, },
"coinmarketcap": { "coinmarketcap": {
"configure": "Nastavte jednu alebo viac kryptomien na sledovanie", "configure": "Nastavte jednu alebo viac kryptomien na sledovanie",
@@ -389,7 +390,7 @@
"prowlarr": { "prowlarr": {
"enableIndexers": "Indexery", "enableIndexers": "Indexery",
"numberOfGrabs": "Zachytení", "numberOfGrabs": "Zachytení",
"numberOfQueries": "Queries", "numberOfQueries": "Požiadaviek",
"numberOfFailGrabs": "Neúspešné zachytenia", "numberOfFailGrabs": "Neúspešné zachytenia",
"numberOfFailQueries": "Neúspešné dopyty" "numberOfFailQueries": "Neúspešné dopyty"
}, },
@@ -404,48 +405,48 @@
"transferRate": "Rate" "transferRate": "Rate"
}, },
"mastodon": { "mastodon": {
"user_count": "Users", "user_count": "Používateľov",
"status_count": "Príspevky", "status_count": "Príspevky",
"domain_count": "Domény" "domain_count": "Domény"
}, },
"medusa": { "medusa": {
"wanted": "Wanted", "wanted": "Wanted",
"queued": "Queued", "queued": "V poradí",
"series": "Series" "series": "Series"
}, },
"minecraft": { "minecraft": {
"players": "Hráči", "players": "Hráči",
"version": "Verzia", "version": "Verzia",
"status": "Status", "status": "Stav",
"up": "Online", "up": "Online",
"down": "Offline" "down": "Offline"
}, },
"miniflux": { "miniflux": {
"read": "Prečítané", "read": "Prečítané",
"unread": "Unread" "unread": "Neprečítané"
}, },
"authentik": { "authentik": {
"users": "Users", "users": "Používateľov",
"loginsLast24H": "Prihlás. (24 hod.)", "loginsLast24H": "Prihlás. (24 hod.)",
"failedLoginsLast24H": "Neúspešné prihlás. (24 hod.)" "failedLoginsLast24H": "Neúspešné prihlás. (24 hod.)"
}, },
"proxmox": { "proxmox": {
"mem": "MEM", "mem": "RAM",
"cpu": "CPU", "cpu": "CPU",
"lxc": "LXC", "lxc": "LXC",
"vms": "Virtuálne stroje" "vms": "Virtuálne stroje"
}, },
"glances": { "glances": {
"cpu": "CPU", "cpu": "CPU",
"load": "Load", "load": "Záťaž",
"wait": "Please wait", "wait": "Čakajte, prosím",
"temp": "TEMP", "temp": "TEMP",
"_temp": "Teplota", "_temp": "Teplota",
"warn": "Upozornení", "warn": "Upozornení",
"uptime": "UP", "uptime": "BEŽÍ",
"total": "Total", "total": "Celkom",
"free": "Free", "free": "Voľné",
"used": "Used", "used": "Využité",
"days": "d", "days": "d",
"hours": "h", "hours": "h",
"crit": "Kritické", "crit": "Kritické",
@@ -461,7 +462,7 @@
"search": "Hľadať", "search": "Hľadať",
"custom": "Vlastné", "custom": "Vlastné",
"visit": "Navštíviť", "visit": "Navštíviť",
"url": "URL", "url": "URL adresa",
"searchsuggestion": "Návrh" "searchsuggestion": "Návrh"
}, },
"wmo": { "wmo": {
@@ -470,57 +471,57 @@
"1-day": "Prevažne slnečno", "1-day": "Prevažne slnečno",
"1-night": "Prevažne jasno", "1-night": "Prevažne jasno",
"2-day": "Čiastočne zamračené", "2-day": "Čiastočne zamračené",
"2-night": "Partly Cloudy", "2-night": "Čiastočne zamračené",
"3-day": "Oblačno", "3-day": "Oblačno",
"3-night": "Cloudy", "3-night": "Oblačno",
"45-day": "Hmlisto", "45-day": "Hmlisto",
"45-night": "Foggy", "45-night": "Hmlisto",
"48-day": "Foggy", "48-day": "Hmlisto",
"48-night": "Foggy", "48-night": "Hmlisto",
"51-day": "Mierne mrholenie", "51-day": "Mierne mrholenie",
"51-night": "Light Drizzle", "51-night": "Slabé mrholenie",
"53-day": "Mrholenie", "53-day": "Mrholenie",
"53-night": "Drizzle", "53-night": "Drizzle",
"55-day": "Silné mrholenie", "55-day": "Silné mrholenie",
"55-night": "Heavy Drizzle", "55-night": "Silné mrholenie",
"56-day": "Mierne mrazivé mrholenie", "56-day": "Mierne mrazivé mrholenie",
"56-night": "Light Freezing Drizzle", "56-night": "Light Freezing Drizzle",
"57-day": "Mrazivé mrholenie", "57-day": "Mrazivé mrholenie",
"57-night": "Freezing Drizzle", "57-night": "Freezing Drizzle",
"61-day": "Slabý dážď", "61-day": "Slabý dážď",
"61-night": "Light Rain", "61-night": "Slabý dážď",
"63-day": "Dážď", "63-day": "Dážď",
"63-night": "Rain", "63-night": "Dážď",
"65-day": "Silný dážď", "65-day": "Silný dážď",
"65-night": "Heavy Rain", "65-night": "Silný dážď",
"66-day": "Mrazivý dážď", "66-day": "Mrazivý dážď",
"66-night": "Mrznúci dážď", "66-night": "Mrznúci dážď",
"67-day": "Mrznúci dážď", "67-day": "Mrznúci dážď",
"67-night": "Mrznúci dážď", "67-night": "Mrznúci dážď",
"71-day": "Mierne sneženie", "71-day": "Mierne sneženie",
"71-night": "Light Snow", "71-night": "Slabé sneženie",
"73-day": "Sneženie", "73-day": "Sneženie",
"73-night": "Snow", "73-night": "Sneženie",
"75-day": "Silné sneženie", "75-day": "Silné sneženie",
"75-night": "Heavy Snow", "75-night": "Husté sneženie",
"77-day": "Snehové vločky", "77-day": "Snehové vločky",
"77-night": "Snow Grains", "77-night": "Snow Grains",
"80-day": "Mierne prehánky", "80-day": "Mierne prehánky",
"80-night": "Light Showers", "80-night": "Mierne prehánky",
"81-day": "Prehánky", "81-day": "Prehánky",
"81-night": "Showers", "81-night": "Prehánky",
"82-day": "Silné prehánky", "82-day": "Silné prehánky",
"82-night": "Heavy Showers", "82-night": "Silné prehánky",
"85-day": "Snehové prehánky", "85-day": "Snehové prehánky",
"85-night": "Snow Showers", "85-night": "Snehové prehánky",
"86-day": "Snow Showers", "86-day": "Snehové prehánky",
"86-night": "Snow Showers", "86-night": "Snehové prehánky",
"95-day": "Búrka", "95-day": "Búrka",
"95-night": "Thunderstorm", "95-night": "Búrka",
"96-day": "Búrka s krupobitím", "96-day": "Búrka s krupobitím",
"96-night": "Thunderstorm With Hail", "96-night": "Búrka s krupobitím",
"99-day": "Thunderstorm With Hail", "99-day": "Búrka s krupobitím",
"99-night": "Thunderstorm With Hail" "99-night": "Búrka s krupobitím"
}, },
"homebridge": { "homebridge": {
"available_update": "Systém", "available_update": "Systém",
@@ -529,17 +530,17 @@
"up_to_date": "Aktuálny", "up_to_date": "Aktuálny",
"child_bridges": "Podradené premostenia", "child_bridges": "Podradené premostenia",
"child_bridges_status": "{{ok}}/{{total}}", "child_bridges_status": "{{ok}}/{{total}}",
"up": "Up", "up": "Beží",
"pending": "Pending", "pending": "Čakajúce",
"down": "Down" "down": "Down"
}, },
"healthchecks": { "healthchecks": {
"new": "Nový", "new": "Nový",
"up": "Up", "up": "Beží",
"grace": "V dodatočnej lehote", "grace": "V dodatočnej lehote",
"down": "Down", "down": "Down",
"paused": "Pozastavené", "paused": "Pozastavené",
"status": "Status", "status": "Stav",
"last_ping": "Poslendný ping", "last_ping": "Poslendný ping",
"never": "Zatiaľ žiadne ping-y" "never": "Zatiaľ žiadne ping-y"
}, },
@@ -549,27 +550,27 @@
"containers_failed": "Zlyhané" "containers_failed": "Zlyhané"
}, },
"autobrr": { "autobrr": {
"approvedPushes": "Approved", "approvedPushes": "Schválené",
"rejectedPushes": "Odmietnuté", "rejectedPushes": "Odmietnuté",
"filters": "Filtre", "filters": "Filtre",
"indexers": "Indexers" "indexers": "Indexers"
}, },
"tubearchivist": { "tubearchivist": {
"downloads": "Queue", "downloads": "Poradie",
"videos": "Videá", "videos": "Videá",
"channels": "Kanály", "channels": "Kanály",
"playlists": "Playlisty" "playlists": "Playlisty"
}, },
"truenas": { "truenas": {
"load": "Záťaž systému", "load": "Záťaž systému",
"uptime": "Uptime", "uptime": "Dostupnosť",
"alerts": "Alerts" "alerts": "Upozornenia"
}, },
"pyload": { "pyload": {
"speed": "Rýchlosť", "speed": "Rýchlosť",
"active": "Active", "active": "Active",
"queue": "Queue", "queue": "Poradie",
"total": "Total" "total": "Celkom"
}, },
"gluetun": { "gluetun": {
"public_ip": "Verejná IP", "public_ip": "Verejná IP",
@@ -585,18 +586,18 @@
"channelNetwork": "Sieť", "channelNetwork": "Sieť",
"signalStrength": "Sila", "signalStrength": "Sila",
"signalQuality": "Kvalita", "signalQuality": "Kvalita",
"symbolQuality": "Quality", "symbolQuality": "Kvalita",
"networkRate": "Bitrate", "networkRate": "Bitrate",
"clientIP": "Klient" "clientIP": "Klient"
}, },
"scrutiny": { "scrutiny": {
"passed": "Úspešný", "passed": "Úspešný",
"failed": "Failed", "failed": "Failed",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"paperlessngx": { "paperlessngx": {
"inbox": "Schránka správ", "inbox": "Schránka správ",
"total": "Total" "total": "Celkom"
}, },
"peanut": { "peanut": {
"battery_charge": "Nabitie batérie", "battery_charge": "Nabitie batérie",
@@ -607,13 +608,13 @@
"low_battery": "Slabá batéria" "low_battery": "Slabá batéria"
}, },
"nextdns": { "nextdns": {
"wait": "Please Wait", "wait": "Čakajte, prosím",
"no_devices": "Informácie o zariadení nezískané" "no_devices": "Informácie o zariadení nezískané"
}, },
"mikrotik": { "mikrotik": {
"cpuLoad": "Využitie CPU", "cpuLoad": "Využitie CPU",
"memoryUsed": "Využitie pamäte", "memoryUsed": "Využitie pamäte",
"uptime": "Uptime", "uptime": "Dostupnosť",
"numberOfLeases": "Pridelené adresy" "numberOfLeases": "Pridelené adresy"
}, },
"xteve": { "xteve": {
@@ -628,7 +629,7 @@
"limit": "Limit" "limit": "Limit"
}, },
"opnsense": { "opnsense": {
"cpu": "CPU Load", "cpu": "Zátaž procesora",
"memory": "Aktívna pamäť", "memory": "Aktívna pamäť",
"wanUpload": "WAN nahrávanie", "wanUpload": "WAN nahrávanie",
"wanDownload": "WAN sťahovanie" "wanDownload": "WAN sťahovanie"
@@ -640,20 +641,20 @@
"layers": "Vrstvy" "layers": "Vrstvy"
}, },
"octoprint": { "octoprint": {
"printer_state": "Status", "printer_state": "Stav",
"temp_tool": "Teplota extrudéra", "temp_tool": "Teplota extrudéra",
"temp_bed": "Teplota podložky", "temp_bed": "Teplota podložky",
"job_completion": "Priebeh" "job_completion": "Priebeh"
}, },
"cloudflared": { "cloudflared": {
"origin_ip": "Zdrojová IP", "origin_ip": "Zdrojová IP",
"status": "Status" "status": "Stav"
}, },
"pfsense": { "pfsense": {
"load": "Priemerné zaťaženie", "load": "Priemerné zaťaženie",
"memory": "Využitie pamäte", "memory": "Využitie pamäte",
"wanStatus": "Stav WAN", "wanStatus": "Stav WAN",
"up": "Up", "up": "Beží",
"down": "Down", "down": "Down",
"temp": "Temp", "temp": "Temp",
"disk": "Využitie disku", "disk": "Využitie disku",
@@ -666,15 +667,15 @@
"memory_usage": "Pamäť" "memory_usage": "Pamäť"
}, },
"immich": { "immich": {
"users": "Users", "users": "Používateľov",
"photos": "Fotografie", "photos": "Fotografií",
"videos": "Videos", "videos": "Videí",
"storage": "Úložisko" "storage": "Úložisko"
}, },
"uptimekuma": { "uptimekuma": {
"up": "Weby dostupné", "up": "Weby dostupné",
"down": "Weby nedostupné", "down": "Weby nedostupné",
"uptime": "Uptime", "uptime": "Dostupnosť",
"incident": "Udalosť", "incident": "Udalosť",
"m": "m" "m": "m"
}, },
@@ -691,8 +692,8 @@
}, },
"diskstation": { "diskstation": {
"days": "Days", "days": "Days",
"uptime": "Uptime", "uptime": "Dostupnosť",
"volumeAvailable": "Available" "volumeAvailable": "Dostupné"
}, },
"mylar": { "mylar": {
"series": "Series", "series": "Series",
@@ -700,15 +701,15 @@
"wanted": "Wanted" "wanted": "Wanted"
}, },
"photoprism": { "photoprism": {
"albums": "Albums", "albums": "Albumov",
"photos": "Photos", "photos": "Fotografií",
"videos": "Videos", "videos": "Videí",
"people": "Ľudia" "people": "Ľudia"
}, },
"fileflows": { "fileflows": {
"queue": "Queue", "queue": "Poradie",
"processing": "Processing", "processing": "Processing",
"processed": "Processed", "processed": "Spracované",
"time": "Čas" "time": "Čas"
}, },
"firefly": { "firefly": {
@@ -730,7 +731,7 @@
"numshares": "Zdieľané položky" "numshares": "Zdieľané položky"
}, },
"kopia": { "kopia": {
"status": "Status", "status": "Stav",
"size": "Veľkosť", "size": "Veľkosť",
"lastrun": "Naposledy spustené", "lastrun": "Naposledy spustené",
"nextrun": "Nasledujúce spustenie", "nextrun": "Nasledujúce spustenie",
@@ -753,10 +754,10 @@
"gatus": { "gatus": {
"up": "Sites Up", "up": "Sites Up",
"down": "Sites Down", "down": "Sites Down",
"uptime": "Uptime" "uptime": "Dostupnosť"
}, },
"ghostfolio": { "ghostfolio": {
"gross_percent_today": "Today", "gross_percent_today": "Dnes",
"gross_percent_1y": "Jeden rok", "gross_percent_1y": "Jeden rok",
"gross_percent_max": "Za celý čas" "gross_percent_max": "Za celý čas"
}, },
@@ -778,22 +779,22 @@
"calibreweb": { "calibreweb": {
"books": "Books", "books": "Books",
"authors": "Autori", "authors": "Autori",
"categories": "Categories", "categories": "Kategórie",
"series": "Series" "series": "Series"
}, },
"jdownloader": { "jdownloader": {
"downloadCount": "Queue", "downloadCount": "Poradie",
"downloadBytesRemaining": "Remaining", "downloadBytesRemaining": "Zostávajúce",
"downloadTotalBytes": "Size", "downloadTotalBytes": "Veľkosť",
"downloadSpeed": "Speed" "downloadSpeed": "Speed"
}, },
"kavita": { "kavita": {
"seriesCount": "Series", "seriesCount": "Series",
"totalFiles": "Files" "totalFiles": "Súborov"
}, },
"azuredevops": { "azuredevops": {
"result": "Výsledok", "result": "Výsledok",
"status": "Status", "status": "Stav",
"buildId": "ID zostavy", "buildId": "ID zostavy",
"succeeded": "Úspešný", "succeeded": "Úspešný",
"notStarted": "Nespustený", "notStarted": "Nespustený",
@@ -802,10 +803,10 @@
"inProgress": "Prebieha", "inProgress": "Prebieha",
"totalPrs": "Počet PR-ok", "totalPrs": "Počet PR-ok",
"myPrs": "Moje PR-ka", "myPrs": "Moje PR-ka",
"approved": "Approved" "approved": "Schválené"
}, },
"gamedig": { "gamedig": {
"status": "Status", "status": "Stav",
"online": "Online", "online": "Online",
"offline": "Offline", "offline": "Offline",
"name": "Meno", "name": "Meno",
@@ -814,7 +815,7 @@
"players": "Players", "players": "Players",
"maxPlayers": "Maximálny počet hráčov", "maxPlayers": "Maximálny počet hráčov",
"bots": "Boti", "bots": "Boti",
"ping": "Ping" "ping": "Odozva"
}, },
"urbackup": { "urbackup": {
"ok": "Ok", "ok": "Ok",
@@ -824,39 +825,39 @@
}, },
"mealie": { "mealie": {
"recipes": "Recepty", "recipes": "Recepty",
"users": "Users", "users": "Používateľov",
"categories": "Categories", "categories": "Kategórie",
"tags": "Štítky" "tags": "Štítky"
}, },
"openmediavault": { "openmediavault": {
"downloading": "Sťahovanie", "downloading": "Sťahovanie",
"total": "Total", "total": "Celkom",
"running": "Running", "running": "Beží",
"stopped": "Stopped", "stopped": "Stopped",
"passed": "Passed", "passed": "Passed",
"failed": "Failed" "failed": "Failed"
}, },
"openwrt": { "openwrt": {
"uptime": "Uptime", "uptime": "Dostupnosť",
"cpuLoad": "Záťaž CPU priem. (5m)", "cpuLoad": "Záťaž CPU priem. (5m)",
"up": "Up", "up": "Beží",
"down": "Down", "down": "Down",
"bytesTx": "Prenesených", "bytesTx": "Prenesených",
"bytesRx": "Received" "bytesRx": "Prijaté"
}, },
"uptimerobot": { "uptimerobot": {
"status": "Status", "status": "Stav",
"uptime": "Uptime", "uptime": "Dostupnosť",
"lastDown": "Posledný čas nedostupnosti", "lastDown": "Posledný čas nedostupnosti",
"downDuration": "Trvanie nedostupnosti", "downDuration": "Trvanie nedostupnosti",
"sitesUp": "Sites Up", "sitesUp": "Sites Up",
"sitesDown": "Sites Down", "sitesDown": "Sites Down",
"paused": "Paused", "paused": "Pozastavené",
"notyetchecked": "Neskontrolované", "notyetchecked": "Neskontrolované",
"up": "Up", "up": "Beží",
"seemsdown": "Javí sa nedostupný", "seemsdown": "Javí sa nedostupný",
"down": "Down", "down": "Down",
"unknown": "Unknown" "unknown": "Neznáme"
}, },
"calendar": { "calendar": {
"inCinemas": "V kinách", "inCinemas": "V kinách",
@@ -872,13 +873,13 @@
"saves": "Saves", "saves": "Saves",
"states": "States", "states": "States",
"screenshots": "Screenshots", "screenshots": "Screenshots",
"totalfilesize": "Total Size" "totalfilesize": "Celková veľkosť"
}, },
"mailcow": { "mailcow": {
"domains": "Domains", "domains": "Domains",
"mailboxes": "Mailboxes", "mailboxes": "Mailboxes",
"mails": "Mails", "mails": "Mails",
"storage": "Storage" "storage": "Úložisko"
}, },
"netdata": { "netdata": {
"warnings": "Upozornenia", "warnings": "Upozornenia",
@@ -887,7 +888,7 @@
"plantit": { "plantit": {
"events": "Udalosti", "events": "Udalosti",
"plants": "Rastliny", "plants": "Rastliny",
"photos": "Photos", "photos": "Fotografií",
"species": "Druhy" "species": "Druhy"
}, },
"gitea": { "gitea": {
@@ -908,13 +909,13 @@
"galleries": "Galérie", "galleries": "Galérie",
"performers": "Herci", "performers": "Herci",
"studios": "Štúdiá", "studios": "Štúdiá",
"movies": "Movies", "movies": "Filmov",
"tags": "Tags", "tags": "Štítky",
"oCount": "O Count" "oCount": "O Count"
}, },
"tandoor": { "tandoor": {
"users": "Users", "users": "Používateľov",
"recipes": "Recipes", "recipes": "Recepty",
"keywords": "Kľúčové slová" "keywords": "Kľúčové slová"
}, },
"homebox": { "homebox": {
@@ -922,18 +923,18 @@
"totalWithWarranty": "So zárukou", "totalWithWarranty": "So zárukou",
"locations": "Umiestnenia", "locations": "Umiestnenia",
"labels": "Štítky", "labels": "Štítky",
"users": "Users", "users": "Používateľov",
"totalValue": "Celková hodnota" "totalValue": "Celková hodnota"
}, },
"crowdsec": { "crowdsec": {
"alerts": "Alerts", "alerts": "Upozornenia",
"bans": "Bany" "bans": "Bany"
}, },
"wgeasy": { "wgeasy": {
"connected": "Connected", "connected": "Pripojené",
"enabled": "Enabled", "enabled": "Enabled",
"disabled": "Disabled", "disabled": "Disabled",
"total": "Total" "total": "Celkom"
}, },
"swagdashboard": { "swagdashboard": {
"proxied": "Proxied", "proxied": "Proxied",
@@ -942,68 +943,68 @@
"banned": "Zabanovaný" "banned": "Zabanovaný"
}, },
"myspeed": { "myspeed": {
"ping": "Ping", "ping": "Odozva",
"download": "Download", "download": "Download",
"upload": "Upload" "upload": "Nahrávanie"
}, },
"stocks": { "stocks": {
"stocks": "Stocks", "stocks": "Stocks",
"loading": "Loading", "loading": "Načítava sa",
"open": "Open - US Market", "open": "Open - US Market",
"closed": "Closed - US Market", "closed": "Closed - US Market",
"invalidConfiguration": "Invalid Configuration" "invalidConfiguration": "Invalid Configuration"
}, },
"frigate": { "frigate": {
"cameras": "Cameras", "cameras": "Kamery",
"uptime": "Uptime", "uptime": "Dostupnosť",
"version": "Version" "version": "Verzia"
}, },
"linkwarden": { "linkwarden": {
"links": "Links", "links": "Odkazy",
"collections": "Collections", "collections": "Collections",
"tags": "Tags" "tags": "Štítky"
}, },
"zabbix": { "zabbix": {
"unclassified": "Not classified", "unclassified": "Not classified",
"information": "Information", "information": "Informácie",
"warning": "Warning", "warning": "Warning",
"average": "Average", "average": "Average",
"high": "High", "high": "High",
"disaster": "Disaster" "disaster": "Disaster"
}, },
"lubelogger": { "lubelogger": {
"vehicle": "Vehicle", "vehicle": "Vozidlo",
"vehicles": "Vehicles", "vehicles": "Vozidlá",
"serviceRecords": "Service Records", "serviceRecords": "Service Records",
"reminders": "Reminders", "reminders": "Reminders",
"nextReminder": "Next Reminder", "nextReminder": "Next Reminder",
"none": "None" "none": "Žiadne"
}, },
"vikunja": { "vikunja": {
"projects": "Active Projects", "projects": "Aktívne projekty",
"tasks7d": "Tasks Due This Week", "tasks7d": "Tasks Due This Week",
"tasksOverdue": "Overdue Tasks", "tasksOverdue": "Overdue Tasks",
"tasksInProgress": "Tasks In Progress" "tasksInProgress": "Tasks In Progress"
}, },
"headscale": { "headscale": {
"name": "Name", "name": "Name",
"address": "Address", "address": "Adresa",
"last_seen": "Last Seen", "last_seen": "Last Seen",
"status": "Status", "status": "Stav",
"online": "Online", "online": "Online",
"offline": "Offline" "offline": "Offline"
}, },
"beszel": { "beszel": {
"name": "Name", "name": "Name",
"systems": "Systems", "systems": "Systems",
"up": "Up", "up": "Beží",
"down": "Down", "down": "Down",
"paused": "Paused", "paused": "Pozastavené",
"pending": "Pending", "pending": "Čakajúce",
"status": "Status", "status": "Stav",
"updated": "Updated", "updated": "Updated",
"cpu": "CPU", "cpu": "CPU",
"memory": "MEM", "memory": "RAM",
"disk": "Disk", "disk": "Disk",
"network": "NET" "network": "NET"
}, },
@@ -1011,14 +1012,14 @@
"apps": "Apps", "apps": "Apps",
"synced": "Synced", "synced": "Synced",
"outOfSync": "Out Of Sync", "outOfSync": "Out Of Sync",
"healthy": "Healthy", "healthy": "Zdravý",
"degraded": "Degraded", "degraded": "Degraded",
"progressing": "Progressing", "progressing": "Progressing",
"missing": "Missing", "missing": "Missing",
"suspended": "Suspended" "suspended": "Suspended"
}, },
"spoolman": { "spoolman": {
"loading": "Loading" "loading": "Načítava sa"
}, },
"gitlab": { "gitlab": {
"groups": "Groups", "groups": "Groups",
@@ -1027,8 +1028,8 @@
"projects": "Projects" "projects": "Projects"
}, },
"apcups": { "apcups": {
"status": "Status", "status": "Stav",
"load": "Load", "load": "Záťaž",
"bcharge": "Battery Charge", "bcharge": "Battery Charge",
"timeleft": "Time Left" "timeleft": "Time Left"
}, },
@@ -1037,45 +1038,45 @@
"favorites": "Favorites", "favorites": "Favorites",
"archived": "Archived", "archived": "Archived",
"highlights": "Highlights", "highlights": "Highlights",
"lists": "Lists", "lists": "Zoznamy",
"tags": "Tags" "tags": "Štítky"
}, },
"slskd": { "slskd": {
"slskStatus": "Network", "slskStatus": "Network",
"connected": "Connected", "connected": "Pripojené",
"disconnected": "Disconnected", "disconnected": "Odpojené",
"updateStatus": "Update", "updateStatus": "Update",
"update_yes": "Available", "update_yes": "Dostupné",
"update_no": "Up to Date", "update_no": "Up to Date",
"downloads": "Downloads", "downloads": "Downloads",
"uploads": "Uploads", "uploads": "Uploads",
"sharedFiles": "Files" "sharedFiles": "Files"
}, },
"jellystat": { "jellystat": {
"songs": "Songs", "songs": "Skladieb",
"movies": "Movies", "movies": "Filmov",
"episodes": "Episodes", "episodes": "Epizód",
"other": "Other" "other": "Ostatné"
}, },
"checkmk": { "checkmk": {
"serviceErrors": "Service issues", "serviceErrors": "Service issues",
"hostErrors": "Host issues" "hostErrors": "Host issues"
}, },
"komodo": { "komodo": {
"total": "Total", "total": "Celkom",
"running": "Running", "running": "Beží",
"stopped": "Stopped", "stopped": "Stopped",
"down": "Down", "down": "Down",
"unhealthy": "Unhealthy", "unhealthy": "Nezdravý",
"unknown": "Unknown", "unknown": "Neznáme",
"servers": "Servers", "servers": "Servers",
"stacks": "Stacks", "stacks": "Stacks",
"containers": "Containers" "containers": "Containers"
}, },
"filebrowser": { "filebrowser": {
"available": "Available", "available": "Dostupné",
"used": "Used", "used": "Využité",
"total": "Total" "total": "Celkom"
}, },
"wallos": { "wallos": {
"activeSubscriptions": "Subscriptions", "activeSubscriptions": "Subscriptions",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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": "Oznámenia",
"status": "Stav",
"cpu": "CPU",
"memoryUsed": "Memory Used",
"memoryAvailable": "Memory Available",
"arrayUsed": "Array Used",
"arrayFree": "Array Free",
"poolUsed": "{{pool}} Used",
"poolFree": "{{pool}} Free"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "На чекању", "pending": "На чекању",
"approved": "Одобрено", "approved": "Одобрено",
"available": "Доступно" "available": "Доступно",
"issues": "Отворених питања"
}, },
"overseerr": { "overseerr": {
"pending": "На чекању", "pending": "На чекању",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Следећи месец", "nextMonthlyCost": "Следећи месец",
"previousMonthlyCost": "Претходни месец", "previousMonthlyCost": "Претходни месец",
"nextRenewingSubscription": "Следећа уплата" "nextRenewingSubscription": "Следећа уплата"
},
"unraid": {
"STARTED": "Покренуто",
"STOPPED": "Заустављено",
"NEW_ARRAY": "Нови Array",
"RECON_DISK": "Реконструкција диска",
"DISABLE_DISK": "Диск је онемогућен",
"SWAP_DSBL": "Swap је онемогућен",
"INVALID_EXPANSION": "Неважеће проширење",
"PARITY_NOT_BIGGEST": "Паритет није највећи",
"TOO_MANY_MISSING_DISKS": "Превише недостајућих дискова",
"NEW_DISK_TOO_SMALL": "Нови диск је премали",
"NO_DATA_DISKS": "Нема дискова са подацима",
"notifications": "Обавештења",
"status": "Статус",
"cpu": "Процесор",
"memoryUsed": "Искоришћена меморија",
"memoryAvailable": "Доступна меморија",
"arrayUsed": "Коришћени Array",
"arrayFree": "Слободан Array",
"poolUsed": "{{pool}} коришћено",
"poolFree": "{{pool}} слободно"
},
"backrest": {
"num_plans": "Планови",
"num_success_30": "Успешно",
"num_failure_30": "Неуспешно",
"num_success_latest": "Успевајући",
"num_failure_latest": "Неуспешно",
"bytes_added_30": "Додати бајтови"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

File diff suppressed because it is too large Load Diff

View File

@@ -112,7 +112,7 @@
"offline_alt": "Offline", "offline_alt": "Offline",
"online": "Онлайн", "online": "Онлайн",
"total": "Total", "total": "Total",
"unknown": "Unknown" "unknown": "Невідомо"
}, },
"evcc": { "evcc": {
"pv_power": "Виробництво", "pv_power": "Виробництво",
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -14,20 +14,20 @@
"date": "{{value, date}}", "date": "{{value, date}}",
"relativeDate": "{{value, relativeDate}}", "relativeDate": "{{value, relativeDate}}",
"duration": "{{value, duration}}", "duration": "{{value, duration}}",
"months": "mo", "months": "tháng",
"days": "d", "days": "ngày",
"hours": "h", "hours": "giờ",
"minutes": "m", "minutes": "phút",
"seconds": "s" "seconds": "giây"
}, },
"widget": { "widget": {
"missing_type": "Thiếu loại Widget: {{type}}", "missing_type": "Thiếu loại Widget: {{type}}",
"api_error": "Lỗi API", "api_error": "Lỗi API",
"information": "Information", "information": "Thông tin",
"status": "Trạng thái", "status": "Trạng thái",
"url": "URL", "url": "URL",
"raw_error": "Raw Error", "raw_error": "Lỗi thô",
"response_data": "Response Data" "response_data": "Dữ liệu phản hồi"
}, },
"weather": { "weather": {
"current": "Vị trí hiện tại", "current": "Vị trí hiện tại",
@@ -44,106 +44,106 @@
"total": "Tổng", "total": "Tổng",
"free": "Dư", "free": "Dư",
"used": "Đã dùng", "used": "Đã dùng",
"load": "Load", "load": "\n",
"temp": "TEMP", "temp": "TEMP",
"max": "Max", "max": "Tối đa",
"uptime": "UP" "uptime": "UP"
}, },
"unifi": { "unifi": {
"users": "Users", "users": "Người dùng",
"uptime": "Uptime", "uptime": "Thời gian hoạt động",
"days": "Days", "days": "Ngày",
"wan": "WAN", "wan": "WAN",
"lan": "LAN", "lan": "LAN",
"wlan": "WLAN", "wlan": "WLAN",
"devices": "Devices", "devices": "Thiết bị",
"lan_devices": "LAN Devices", "lan_devices": "Thiết bị trong mạng LAN",
"wlan_devices": "WLAN Devices", "wlan_devices": "Thiết bị trong mạng WLAN",
"lan_users": "LAN Users", "lan_users": "Người dùng mạng LAN",
"wlan_users": "WLAN Users", "wlan_users": "Người dùng mạng WLAN",
"up": "UP", "up": "UP",
"down": "DOWN", "down": "DOWN",
"wait": "Please wait", "wait": "Vui lòng chờ",
"empty_data": "Subsystem status unknown" "empty_data": "Trạng thái hệ thống phụ không xác định"
}, },
"docker": { "docker": {
"rx": "RX", "rx": "RX",
"tx": "TX", "tx": "TX",
"mem": "MEM", "mem": "Bộ nhớ",
"cpu": "CPU", "cpu": "CPU",
"running": "Running", "running": "Đang hoạt động",
"offline": "Ngoại tuyến", "offline": "Ngoại tuyến",
"error": "Error", "error": "Lỗi",
"unknown": "Unknown", "unknown": "Không xác định",
"healthy": "Healthy", "healthy": "Ổn định",
"starting": "Starting", "starting": "Đang bắt đầu",
"unhealthy": "Unhealthy", "unhealthy": "Bất thường",
"not_found": "Not Found", "not_found": "Không tìm thấy",
"exited": "Exited", "exited": "Exited",
"partial": "Partial" "partial": "Partial"
}, },
"ping": { "ping": {
"error": "Error", "error": "Lỗi",
"ping": "Ping", "ping": "Ping",
"down": "Down", "down": "Down",
"up": "Up", "up": "Up",
"not_available": "Không khả dụng" "not_available": "Không khả dụng"
}, },
"siteMonitor": { "siteMonitor": {
"http_status": "HTTP status", "http_status": "Trạng thái HTTP",
"error": "Error", "error": "Lỗi",
"response": "Response", "response": "Phản hồi",
"down": "Down", "down": "Down",
"up": "Up", "up": "Up",
"not_available": "Not Available" "not_available": "Không có sẵn"
}, },
"emby": { "emby": {
"playing": "Đang chơi", "playing": "Đang chơi",
"transcoding": "Chuyển định dạng", "transcoding": "Chuyển định dạng",
"bitrate": "Bitrate", "bitrate": "Bitrate",
"no_active": "No Active Streams", "no_active": "No Active Streams",
"movies": "Movies", "movies": "Phim ảnh",
"series": "Series", "series": "Series",
"episodes": "Episodes", "episodes": "Episodes",
"songs": "Songs" "songs": "Bài hát"
}, },
"esphome": { "esphome": {
"offline": "Offline", "offline": "Offline",
"offline_alt": "Offline", "offline_alt": "Offline",
"online": "Online", "online": "Online",
"total": "Total", "total": "Total",
"unknown": "Unknown" "unknown": "Không xác định"
}, },
"evcc": { "evcc": {
"pv_power": "Production", "pv_power": "Production",
"battery_soc": "Battery", "battery_soc": "Pin",
"grid_power": "Grid", "grid_power": "Lưới",
"home_power": "Consumption", "home_power": "Consumption",
"charge_power": "Charger", "charge_power": "Bộ sạc",
"kilowatt": "kW" "kilowatt": "kW"
}, },
"flood": { "flood": {
"download": "Download", "download": "Tải xuống",
"upload": "Upload", "upload": "Tải lên",
"leech": "Leech", "leech": "",
"seed": "Seed" "seed": "Seed"
}, },
"freshrss": { "freshrss": {
"subscriptions": "Subscriptions", "subscriptions": "Đăng ký",
"unread": "Unread" "unread": "Chưa đọc"
}, },
"fritzbox": { "fritzbox": {
"connectionStatus": "Status", "connectionStatus": "Trạng thái",
"connectionStatusUnconfigured": "Unconfigured", "connectionStatusUnconfigured": "Chưa được cấu hình",
"connectionStatusConnecting": "Connecting", "connectionStatusConnecting": "Đang kết nối",
"connectionStatusAuthenticating": "Authenticating", "connectionStatusAuthenticating": "Đang uỷ quyền",
"connectionStatusPendingDisconnect": "Pending Disconnect", "connectionStatusPendingDisconnect": "Đang chờ ngắt kết nối",
"connectionStatusDisconnecting": "Disconnecting", "connectionStatusDisconnecting": "Đang ngắt kết nối",
"connectionStatusDisconnected": "Disconnected", "connectionStatusDisconnected": "Đã ngắt kết nối",
"connectionStatusConnected": "Connected", "connectionStatusConnected": "Đã kết nối",
"uptime": "Uptime", "uptime": "Thời gian hoạt động",
"maxDown": "Max. Down", "maxDown": "Tải xuống tối đa",
"maxUp": "Max. Up", "maxUp": "Tải lên tối đa",
"down": "Down", "down": "Down",
"up": "Up", "up": "Up",
"received": "Received", "received": "Received",
@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -998,64 +999,64 @@
"systems": "Systems", "systems": "Systems",
"up": "Up", "up": "Up",
"down": "Down", "down": "Down",
"paused": "Paused", "paused": "Đã tạm dừng",
"pending": "Pending", "pending": "Đang xử lý",
"status": "Status", "status": "Trạng thái",
"updated": "Updated", "updated": "Đã cập nhật",
"cpu": "CPU", "cpu": "CPU",
"memory": "MEM", "memory": "MEM",
"disk": "Disk", "disk": "Ổ đĩa",
"network": "NET" "network": "NET"
}, },
"argocd": { "argocd": {
"apps": "Apps", "apps": "Ứng dụng",
"synced": "Synced", "synced": "Synced",
"outOfSync": "Out Of Sync", "outOfSync": "Out Of Sync",
"healthy": "Healthy", "healthy": "Ổn định",
"degraded": "Degraded", "degraded": "Degraded",
"progressing": "Progressing", "progressing": "Progressing",
"missing": "Missing", "missing": "Bị thiếu",
"suspended": "Suspended" "suspended": "Suspended"
}, },
"spoolman": { "spoolman": {
"loading": "Loading" "loading": "Đang tải"
}, },
"gitlab": { "gitlab": {
"groups": "Groups", "groups": "Nhóm",
"issues": "Issues", "issues": "Vấn đề",
"merges": "Merge Requests", "merges": "Yêu cầu Hợp nhất",
"projects": "Projects" "projects": "Dự án"
}, },
"apcups": { "apcups": {
"status": "Status", "status": "Trạng thái",
"load": "Load", "load": "Đang tải\n",
"bcharge": "Battery Charge", "bcharge": "Sạc pin",
"timeleft": "Time Left" "timeleft": "Thời gian còn lại"
}, },
"karakeep": { "karakeep": {
"bookmarks": "Bookmarks", "bookmarks": "Dấu trang",
"favorites": "Favorites", "favorites": "Mục yêu thích",
"archived": "Archived", "archived": "Đã lưu trữ",
"highlights": "Highlights", "highlights": "Tâm điểm",
"lists": "Lists", "lists": "Danh sách",
"tags": "Tags" "tags": "Thẻ"
}, },
"slskd": { "slskd": {
"slskStatus": "Network", "slskStatus": "Mạng",
"connected": "Connected", "connected": "Đã kết nối",
"disconnected": "Disconnected", "disconnected": "Mất kết nối",
"updateStatus": "Update", "updateStatus": "Cập nhật",
"update_yes": "Available", "update_yes": "Khả dụng",
"update_no": "Up to Date", "update_no": "Đã cập nhật",
"downloads": "Downloads", "downloads": "Tải xuống",
"uploads": "Uploads", "uploads": "Tải lên",
"sharedFiles": "Files" "sharedFiles": "Tập tin"
}, },
"jellystat": { "jellystat": {
"songs": "Songs", "songs": "Bài hát",
"movies": "Movies", "movies": "Phim ảnh",
"episodes": "Episodes", "episodes": "Tập",
"other": "Other" "other": "Khác"
}, },
"checkmk": { "checkmk": {
"serviceErrors": "Service issues", "serviceErrors": "Service issues",
@@ -1066,8 +1067,8 @@
"running": "Running", "running": "Running",
"stopped": "Stopped", "stopped": "Stopped",
"down": "Down", "down": "Down",
"unhealthy": "Unhealthy", "unhealthy": "Không ổn định",
"unknown": "Unknown", "unknown": "Không xác định",
"servers": "Servers", "servers": "Servers",
"stacks": "Stacks", "stacks": "Stacks",
"containers": "Containers" "containers": "Containers"
@@ -1075,13 +1076,48 @@
"filebrowser": { "filebrowser": {
"available": "Available", "available": "Available",
"used": "Used", "used": "Used",
"total": "Total" "total": "Tổng"
}, },
"wallos": { "wallos": {
"activeSubscriptions": "Subscriptions", "activeSubscriptions": "Đăng ký",
"thisMonthlyCost": "This Month", "thisMonthlyCost": "Tháng này",
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Tháng sau",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Tháng trước",
"nextRenewingSubscription": "Next Payment" "nextRenewingSubscription": "Lần thanh toán kế tiếp"
},
"unraid": {
"STARTED": "Đã bắt đầu",
"STOPPED": "Đã dừng",
"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": "Không có dữ liệu ổ đĩa",
"notifications": "Thông báo",
"status": "Trạng thái",
"cpu": "CPU",
"memoryUsed": "Memory Used",
"memoryAvailable": "Memory Available",
"arrayUsed": "Array Used",
"arrayFree": "Array Free",
"poolUsed": "{{pool}} Used",
"poolFree": "{{pool}} Free"
},
"backrest": {
"num_plans": "Các kế hoạch",
"num_success_30": "Thành công",
"num_failure_30": "Thất bại",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Bài hát",
"time": "Thời gian",
"artists": "Nghệ sĩ"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -63,7 +63,7 @@
"wlan_users": "无线局域网用户", "wlan_users": "无线局域网用户",
"up": "UP", "up": "UP",
"down": "离线", "down": "离线",
"wait": "请稍", "wait": "请稍",
"empty_data": "子系统状态未知" "empty_data": "子系统状态未知"
}, },
"docker": { "docker": {
@@ -83,19 +83,19 @@
"partial": "部分" "partial": "部分"
}, },
"ping": { "ping": {
"error": "Error", "error": "错误",
"ping": "Ping", "ping": "延迟",
"down": "Down", "down": "离线",
"up": "Up", "up": "在线",
"not_available": "不可用" "not_available": "不可用"
}, },
"siteMonitor": { "siteMonitor": {
"http_status": "HTTP 状态", "http_status": "HTTP 状态",
"error": "Error", "error": "错误",
"response": "响应", "response": "响应",
"down": "Down", "down": "离线",
"up": "Up", "up": "在线",
"not_available": "Not Available" "not_available": "不可用"
}, },
"emby": { "emby": {
"playing": "播放中", "playing": "播放中",
@@ -116,7 +116,7 @@
}, },
"evcc": { "evcc": {
"pv_power": "正式环境", "pv_power": "正式环境",
"battery_soc": "Battery", "battery_soc": "电量",
"grid_power": "Grid", "grid_power": "Grid",
"home_power": "Consumption", "home_power": "Consumption",
"charge_power": "Charger", "charge_power": "Charger",
@@ -189,7 +189,7 @@
"plex": { "plex": {
"streams": "活动流", "streams": "活动流",
"albums": "专辑", "albums": "专辑",
"movies": "Movies", "movies": "电影",
"tv": "电视节目" "tv": "电视节目"
}, },
"sabnzbd": { "sabnzbd": {
@@ -204,15 +204,15 @@
}, },
"transmission": { "transmission": {
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "Seed"
}, },
"qbittorrent": { "qbittorrent": {
"download": "Download", "download": "下载速率",
"upload": "Upload", "upload": "上传速率",
"leech": "Leech", "leech": "下载中",
"seed": "Seed" "seed": "做种"
}, },
"qnap": { "qnap": {
"cpuUsage": "处理器", "cpuUsage": "处理器",
@@ -236,31 +236,31 @@
"download": "Download", "download": "Download",
"upload": "Upload", "upload": "Upload",
"leech": "Leech", "leech": "Leech",
"seed": "Seed" "seed": "做种"
}, },
"sonarr": { "sonarr": {
"wanted": "想看", "wanted": "想看",
"queued": "排队", "queued": "排队",
"series": "Series", "series": "系列",
"queue": "Queue", "queue": "队列",
"unknown": "Unknown" "unknown": "未知"
}, },
"radarr": { "radarr": {
"wanted": "Wanted", "wanted": "想看",
"missing": "丢失", "missing": "丢失",
"queued": "Queued", "queued": "队列中",
"movies": "Movies", "movies": "电影",
"queue": "Queue", "queue": "队列",
"unknown": "Unknown" "unknown": "未知"
}, },
"lidarr": { "lidarr": {
"wanted": "Wanted", "wanted": "想看",
"queued": "Queued", "queued": "队列中",
"artists": "Artists" "artists": "Artists"
}, },
"readarr": { "readarr": {
"wanted": "Wanted", "wanted": "想看",
"queued": "Queued", "queued": "队列中",
"books": "书籍" "books": "书籍"
}, },
"bazarr": { "bazarr": {
@@ -273,9 +273,10 @@
"available": "可用" "available": "可用"
}, },
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "待办的",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -360,13 +361,13 @@
"middleware": "中间件" "middleware": "中间件"
}, },
"trilium": { "trilium": {
"version": "Version", "version": "版本",
"notesCount": "Notes", "notesCount": "笔记",
"dbSize": "Database Size", "dbSize": "数据库大小",
"unknown": "Unknown" "unknown": "Unknown"
}, },
"navidrome": { "navidrome": {
"nothing_streaming": "No Active Streams", "nothing_streaming": "",
"please_wait": "请等待" "please_wait": "请等待"
}, },
"npm": { "npm": {
@@ -437,20 +438,20 @@
}, },
"glances": { "glances": {
"cpu": "CPU", "cpu": "CPU",
"load": "Load", "load": "负载",
"wait": "Please wait", "wait": "请稍候",
"temp": "TEMP", "temp": "温度",
"_temp": "Temp", "_temp": "Temp",
"warn": "Warn", "warn": "Warn",
"uptime": "UP", "uptime": "运行时间",
"total": "Total", "total": "总计",
"free": "Free", "free": "空闲",
"used": "Used", "used": "已使用",
"days": "d", "days": "",
"hours": "h", "hours": "",
"crit": "Crit", "crit": "Crit",
"read": "Read", "read": "Read",
"write": "Write", "write": "写入",
"gpu": "GPU", "gpu": "GPU",
"mem": "Mem", "mem": "Mem",
"swap": "Swap" "swap": "Swap"
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -275,7 +275,8 @@
"jellyseerr": { "jellyseerr": {
"pending": "Pending", "pending": "Pending",
"approved": "Approved", "approved": "Approved",
"available": "Available" "available": "Available",
"issues": "Open Issues"
}, },
"overseerr": { "overseerr": {
"pending": "Pending", "pending": "Pending",
@@ -1083,5 +1084,40 @@
"nextMonthlyCost": "Next Month", "nextMonthlyCost": "Next Month",
"previousMonthlyCost": "Prev. Month", "previousMonthlyCost": "Prev. Month",
"nextRenewingSubscription": "Next Payment" "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"
},
"backrest": {
"num_plans": "Plans",
"num_success_30": "Successes",
"num_failure_30": "Failures",
"num_success_latest": "Succeeding",
"num_failure_latest": "Failing",
"bytes_added_30": "Bytes Added"
},
"yourspotify": {
"songs": "Songs",
"time": "Time",
"artists": "Artists"
} }
} }

View File

@@ -1,21 +1,37 @@
Babel==2.12.1 Babel==2.12.1
backrefs==5.9
cairocffi==1.7.1
CairoSVG==2.7.1
certifi==2023.7.22 certifi==2023.7.22
cffi==1.17.1
cfgv==3.4.0
charset-normalizer==3.2.0 charset-normalizer==3.2.0
click==8.1.7 click==8.1.7
colorama==0.4.6 colorama==0.4.6
cssselect2==0.7.0
defusedxml==0.7.1
distlib==0.3.9
filelock==3.17.0
ghp-import==2.1.0 ghp-import==2.1.0
identify==2.6.7
idna==3.4 idna==3.4
Jinja2==3.1.2 Jinja2==3.1.2
Markdown==3.4.4 Markdown==3.4.4
MarkupSafe==2.1.3 MarkupSafe==2.1.3
mergedeep==1.3.4 mergedeep==1.3.4
mkdocs==1.6 mkdocs==1.6.0
mkdocs-material==9.5.26 mkdocs-get-deps==0.2.0
mkdocs-material==9.6.18
mkdocs-material-extensions==1.3.1 mkdocs-material-extensions==1.3.1
mkdocs-redirects==1.2.1
nodeenv==1.9.1
packaging==23.1 packaging==23.1
paginate==0.5.6 paginate==0.5.6
pathspec==0.11.2 pathspec==0.11.2
pillow==10.4.0
platformdirs==3.10.0 platformdirs==3.10.0
pre-commit==3.5.0
pycparser==2.22
Pygments==2.16.1 Pygments==2.16.1
pymdown-extensions==10.3 pymdown-extensions==10.3
python-dateutil==2.8.2 python-dateutil==2.8.2
@@ -24,8 +40,8 @@ pyyaml_env_tag==0.1
regex==2023.8.8 regex==2023.8.8
requests==2.31.0 requests==2.31.0
six==1.16.0 six==1.16.0
tinycss2==1.4.0
urllib3==2.0.5 urllib3==2.0.5
virtualenv==20.29.2
watchdog==3.0.0 watchdog==3.0.0
pre-commit==3.5.0 webencodings==0.5.1
mkdocs-material[imaging]==9.5.26
mkdocs-redirects==1.2.1

View File

@@ -1,13 +1,21 @@
import classNames from "classnames"; import classNames from "classnames";
import { useTranslation } from "next-i18next"; import { useTranslation } from "next-i18next";
import { useCallback, useContext, useEffect, useRef, useState } from "react"; import { useCallback, useContext, useEffect, useRef, useState } from "react";
import { FiSearch } from "react-icons/fi";
import useSWR from "swr"; import useSWR from "swr";
import { SettingsContext } from "utils/contexts/settings"; import { SettingsContext } from "utils/contexts/settings";
import ResolvedIcon from "./resolvedicon"; import ResolvedIcon from "./resolvedicon";
import { getStoredProvider, searchProviders } from "./widgets/search/search"; import { getStoredProvider, searchProviders } from "./widgets/search/search";
export default function QuickLaunch({ servicesAndBookmarks, searchString, setSearchString, isOpen, close }) { const MOBILE_BUTTON_POSITIONS = {
"top-left": "top-4 left-4",
"top-right": "top-4 right-4",
"bottom-left": "bottom-4 left-4",
"bottom-right": "bottom-4 right-4",
};
export default function QuickLaunch({ servicesAndBookmarks, searchString, setSearchString, isOpen, setSearching }) {
const { t } = useTranslation(); const { t } = useTranslation();
const { settings } = useContext(SettingsContext); const { settings } = useContext(SettingsContext);
@@ -49,6 +57,10 @@ export default function QuickLaunch({ servicesAndBookmarks, searchString, setSea
); );
} }
let mobileButtonPosition = settings.quicklaunch?.mobileButtonPosition
? MOBILE_BUTTON_POSITIONS[settings.quicklaunch.mobileButtonPosition]
: null;
function openCurrentItem(newWindow) { function openCurrentItem(newWindow) {
const result = results[currentItemIndex]; const result = results[currentItemIndex];
window.open( window.open(
@@ -59,13 +71,13 @@ export default function QuickLaunch({ servicesAndBookmarks, searchString, setSea
} }
const closeAndReset = useCallback(() => { const closeAndReset = useCallback(() => {
close(false); setSearching(false);
setTimeout(() => { setTimeout(() => {
setSearchString(""); setSearchString("");
setCurrentItemIndex(null); setCurrentItemIndex(null);
setSearchSuggestions([]); setSearchSuggestions([]);
}, 200); // delay a little for animations }, 200); // delay a little for animations
}, [close, setSearchString, setCurrentItemIndex, setSearchSuggestions]); }, [setSearching, setSearchString, setCurrentItemIndex, setSearchSuggestions]);
function handleSearchChange(event) { function handleSearchChange(event) {
const rawSearchString = event.target.value; const rawSearchString = event.target.value;
@@ -245,86 +257,98 @@ export default function QuickLaunch({ servicesAndBookmarks, searchString, setSea
} }
return ( return (
<div <>
className={classNames( <div
"relative z-40 ease-in-out duration-300 transition-opacity", className={classNames(
hidden && !isOpen && "hidden", "relative z-40 ease-in-out duration-300 transition-opacity",
!hidden && isOpen && "opacity-100", hidden && !isOpen && "hidden",
!isOpen && "opacity-0", !hidden && isOpen && "opacity-100",
)} !isOpen && "opacity-0",
role="dialog" )}
aria-modal="true" role="dialog"
> aria-modal="true"
<div className="fixed inset-0 bg-gray-500 opacity-50" /> >
<div className="fixed inset-0 z-20 overflow-y-auto"> <div className="fixed inset-0 bg-gray-500 opacity-50" />
<div className="flex min-h-full min-w-full items-start justify-center text-center"> <div className="fixed inset-0 z-20 overflow-y-auto">
<dialog className="mt-[10%] mx-auto min-w-[90%] max-w-[90%] md:min-w-[40%] md:max-w-[40%] rounded-md p-0 block font-medium text-theme-700 dark:text-theme-200 dark:hover:text-theme-300 shadow-md shadow-theme-900/10 dark:shadow-theme-900/20 bg-theme-50 dark:bg-theme-800"> <div className="flex min-h-full min-w-full items-start justify-center text-center">
<input <dialog className="mt-[10%] mx-auto min-w-[90%] max-w-[90%] md:min-w-[40%] md:max-w-[40%] rounded-md p-0 block font-medium text-theme-700 dark:text-theme-200 dark:hover:text-theme-300 shadow-md shadow-theme-900/10 dark:shadow-theme-900/20 bg-theme-50 dark:bg-theme-800">
placeholder="Search" <input
className={classNames( placeholder="Search"
results.length > 0 && "rounded-t-md", className={classNames(
results.length === 0 && "rounded-md", results.length > 0 && "rounded-t-md",
"w-full p-4 m-0 border-0 border-b border-slate-700 focus:border-slate-700 focus:outline-0 focus:ring-0 text-sm md:text-xl text-theme-700 dark:text-theme-200 bg-theme-60 dark:bg-theme-800", results.length === 0 && "rounded-md",
)} "w-full p-4 m-0 border-0 border-b border-slate-700 focus:border-slate-700 focus:outline-0 focus:ring-0 text-sm md:text-xl text-theme-700 dark:text-theme-200 bg-theme-60 dark:bg-theme-800",
type="text" )}
autoCorrect="false" type="text"
ref={searchField} autoCorrect="false"
value={searchString} ref={searchField}
onChange={handleSearchChange} value={searchString}
onKeyDown={handleSearchKeyDown} onChange={handleSearchChange}
/> onKeyDown={handleSearchKeyDown}
{results.length > 0 && ( />
<ul className="max-h-[60vh] overflow-y-auto m-2"> {results.length > 0 && (
{results.map((r, i) => ( <ul className="max-h-[60vh] overflow-y-auto m-2">
<li key={[r.name, r.container, r.app, r.href].filter((s) => s).join("-")}> {results.map((r, i) => (
<button <li key={[r.name, r.container, r.app, r.href].filter((s) => s).join("-")}>
type="button" <button
data-index={i} type="button"
onMouseEnter={handleItemHover} data-index={i}
onClick={handleItemClick} onMouseEnter={handleItemHover}
onKeyDown={handleItemKeyDown} onClick={handleItemClick}
className={classNames( onKeyDown={handleItemKeyDown}
"flex flex-row w-full items-center justify-between rounded-md text-sm md:text-xl py-2 px-4 cursor-pointer text-theme-700 dark:text-theme-200", className={classNames(
i === currentItemIndex && "bg-theme-300/50 dark:bg-theme-700/50", "flex flex-row w-full items-center justify-between rounded-md text-sm md:text-xl py-2 px-4 cursor-pointer text-theme-700 dark:text-theme-200",
)} i === currentItemIndex && "bg-theme-300/50 dark:bg-theme-700/50",
>
<div className="flex flex-row items-center mr-4 pointer-events-none">
{(r.icon || r.abbr) && (
<div className="w-5 text-xs mr-4">
{r.icon && <ResolvedIcon icon={r.icon} />}
{r.abbr && r.abbr}
</div>
)} )}
<div className="flex flex-col md:flex-row text-left items-baseline mr-4 pointer-events-none"> >
{r.type !== "searchSuggestion" && <span className="mr-4">{r.name}</span>} <div className="flex flex-row items-center mr-4 pointer-events-none">
{r.type === "searchSuggestion" && ( {(r.icon || r.abbr) && (
<div className="flex-nowrap"> <div className="w-5 text-xs mr-4">
<span className="whitespace-pre"> {r.icon && <ResolvedIcon icon={r.icon} />}
{r.name.indexOf(searchString) === 0 ? searchString : ""} {r.abbr && r.abbr}
</span>
<span className="whitespace-pre opacity-50">
{r.name.indexOf(searchString) === 0 ? r.name.substring(searchString.length) : r.name}
</span>
</div> </div>
)} )}
{r.description && ( <div className="flex flex-col md:flex-row text-left items-baseline mr-4 pointer-events-none">
<span className="text-xs text-theme-600 text-light"> {r.type !== "searchSuggestion" && <span className="mr-4">{r.name}</span>}
{searchDescriptions && r.priority < 2 ? highlightText(r.description) : r.description} {r.type === "searchSuggestion" && (
</span> <div className="flex-nowrap">
)} <span className="whitespace-pre">
{r.name.indexOf(searchString) === 0 ? searchString : ""}
</span>
<span className="whitespace-pre opacity-50">
{r.name.indexOf(searchString) === 0 ? r.name.substring(searchString.length) : r.name}
</span>
</div>
)}
{r.description && (
<span className="text-xs text-theme-600 text-light">
{searchDescriptions && r.priority < 2 ? highlightText(r.description) : r.description}
</span>
)}
</div>
</div> </div>
</div> <div className="text-xs text-theme-600 font-bold pointer-events-none">
<div className="text-xs text-theme-600 font-bold pointer-events-none"> {t(`quicklaunch.${r.type ? r.type.toLowerCase() : "bookmark"}`)}
{t(`quicklaunch.${r.type ? r.type.toLowerCase() : "bookmark"}`)} </div>
</div> </button>
</button> </li>
</li> ))}
))} </ul>
</ul> )}
)} </dialog>
</dialog> </div>
</div> </div>
</div> </div>
</div> {mobileButtonPosition && (
<button
type="button"
onClick={setSearching.bind(this, !isOpen)}
className={`fixed ${mobileButtonPosition} z-40 p-2 rounded-full sm:hidden text-theme-700 dark:text-theme-200 bg-theme-50 dark:bg-theme-800 shadow-md shadow-theme-900/10 dark:shadow-theme-900/20 transition-opacity duration-100`}
style={{ opacity: isOpen ? 0 : 1 }}
>
<FiSearch className="w-4 h-4" />
</button>
)}
</>
); );
} }

View File

@@ -37,12 +37,12 @@ export default function Container({ error = false, children, service }) {
if (!field.includes(".")) { if (!field.includes(".")) {
fullField = `${type}.${field}`; 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' // check if the field is an 'alias'
if (matches) { if (matches) {
return true; return true;
} else if (ALIASED_WIDGETS[type]) { } 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; return matches;
} }

View File

@@ -1,5 +1,5 @@
import { useTranslation } from "next-i18next"; import { useTranslation } from "next-i18next";
import { useState } from "react"; import { useCallback, useEffect, useState } from "react";
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md"; import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
import { WiCloudDown } from "react-icons/wi"; import { WiCloudDown } from "react-icons/wi";
import useSWR from "swr"; import useSWR from "swr";
@@ -64,7 +64,7 @@ export default function OpenMeteo({ options }) {
setLocation({ latitude: options.latitude, longitude: options.longitude }); setLocation({ latitude: options.latitude, longitude: options.longitude });
} }
const requestLocation = () => { const requestLocation = useCallback(() => {
setRequesting(true); setRequesting(true);
if (typeof window !== "undefined") { if (typeof window !== "undefined") {
navigator.geolocation.getCurrentPosition( 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) { if (!location) {
return ( return (

View File

@@ -1,5 +1,5 @@
import { useTranslation } from "next-i18next"; import { useTranslation } from "next-i18next";
import { useState } from "react"; import { useCallback, useEffect, useState } from "react";
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md"; import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
import { WiCloudDown } from "react-icons/wi"; import { WiCloudDown } from "react-icons/wi";
import useSWR from "swr"; import useSWR from "swr";
@@ -59,7 +59,7 @@ export default function OpenWeatherMap({ options }) {
setLocation({ latitude: options.latitude, longitude: options.longitude }); setLocation({ latitude: options.latitude, longitude: options.longitude });
} }
const requestLocation = () => { const requestLocation = useCallback(() => {
setRequesting(true); setRequesting(true);
if (typeof window !== "undefined") { if (typeof window !== "undefined") {
navigator.geolocation.getCurrentPosition( 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) { if (!location) {
return ( return (

View File

@@ -1,4 +1,4 @@
export default function QueueEntry({ title, activity, timeLeft, progress }) { export default function QueueEntry({ title, activity, timeLeft, progress, size }) {
return ( return (
<div className="text-theme-700 dark:text-theme-200 relative h-5 rounded-md bg-theme-200/50 dark:bg-theme-900/20 m-1 px-1 flex"> <div className="text-theme-700 dark:text-theme-200 relative h-5 rounded-md bg-theme-200/50 dark:bg-theme-900/20 m-1 px-1 flex">
<div <div
@@ -11,6 +11,7 @@ export default function QueueEntry({ title, activity, timeLeft, progress }) {
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden text-left">{title}</div> <div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden text-left">{title}</div>
</div> </div>
<div className="self-center text-xs flex justify-end mr-1.5 pl-1 z-10 text-ellipsis overflow-hidden whitespace-nowrap"> <div className="self-center text-xs flex justify-end mr-1.5 pl-1 z-10 text-ellipsis overflow-hidden whitespace-nowrap">
{size && `${size} - `}
{timeLeft ? `${activity} - ${timeLeft}` : activity} {timeLeft ? `${activity} - ${timeLeft}` : activity}
</div> </div>
</div> </div>

View File

@@ -1,5 +1,5 @@
import { useTranslation } from "next-i18next"; import { useTranslation } from "next-i18next";
import { useState } from "react"; import { useCallback, useEffect, useState } from "react";
import { MdLocationDisabled, MdLocationSearching } from "react-icons/md"; import { MdLocationDisabled, MdLocationSearching } from "react-icons/md";
import { WiCloudDown } from "react-icons/wi"; import { WiCloudDown } from "react-icons/wi";
import useSWR from "swr"; import useSWR from "swr";
@@ -63,7 +63,7 @@ export default function WeatherApi({ options }) {
setLocation({ latitude: options.latitude, longitude: options.longitude }); setLocation({ latitude: options.latitude, longitude: options.longitude });
} }
const requestLocation = () => { const requestLocation = useCallback(() => {
setRequesting(true); setRequesting(true);
if (typeof window !== "undefined") { if (typeof window !== "undefined") {
navigator.geolocation.getCurrentPosition( 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) { if (!location) {
return ( return (

View File

@@ -24,9 +24,28 @@ export default async function handler(req, res) {
}); });
} }
const baseUrl = `${proxmoxConfig.url}/api2/json`; // Prefer per-node config (new format), fall back to legacy flat creds.
const nodeConfig =
(node && proxmoxConfig && proxmoxConfig[node]) ||
(proxmoxConfig && proxmoxConfig.url && proxmoxConfig.token && proxmoxConfig.secret
? {
url: proxmoxConfig.url,
token: proxmoxConfig.token,
secret: proxmoxConfig.secret,
}
: null);
if (!nodeConfig) {
return res.status(400).json({
error:
"Proxmox config not found for the specified node and no legacy credentials detected. " +
"Add a node block in proxmox.yaml (e.g., 'pve: { url, token, secret }') or restore legacy top-level url/token/secret.",
});
}
const baseUrl = `${nodeConfig.url}/api2/json`;
const headers = { const headers = {
Authorization: `PVEAPIToken=${proxmoxConfig.token}=${proxmoxConfig.secret}`, Authorization: `PVEAPIToken=${nodeConfig.token}=${nodeConfig.secret}`,
}; };
const statusUrl = `${baseUrl}/nodes/${node}/${vmType}/${vmid}/status/current`; const statusUrl = `${baseUrl}/nodes/${node}/${vmType}/${vmid}/status/current`;

View File

@@ -1,5 +1,3 @@
import { existsSync } from "fs";
import createLogger from "utils/logger"; import createLogger from "utils/logger";
const logger = createLogger("resources"); const logger = createLogger("resources");
@@ -20,17 +18,20 @@ export default async function handler(req, res) {
} }
if (type === "disk") { if (type === "disk") {
if (!existsSync(target)) { const requested = typeof target === "string" && target ? target : "/";
return res.status(404).json({
error: "Target not found",
});
}
const fsSize = await si.fsSize(); const fsSize = await si.fsSize();
logger.debug("fsSize:", JSON.stringify(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") { if (type === "memory") {

View File

@@ -432,7 +432,7 @@ function Home({ initialSettings }) {
searchString={searchString} searchString={searchString}
setSearchString={setSearchString} setSearchString={setSearchString}
isOpen={searching} isOpen={searching}
close={setSearching} setSearching={setSearching}
/> />
<div <div
id="information-widgets" id="information-widgets"
@@ -499,6 +499,7 @@ function Home({ initialSettings }) {
export default function Wrapper({ initialSettings, fallback }) { export default function Wrapper({ initialSettings, fallback }) {
const { theme } = useContext(ThemeContext); const { theme } = useContext(ThemeContext);
const { color } = useContext(ColorContext);
let backgroundImage = ""; let backgroundImage = "";
let opacity = initialSettings?.backgroundOpacity ?? 0; let opacity = initialSettings?.backgroundOpacity ?? 0;
let backgroundBlur = false; let backgroundBlur = false;
@@ -509,7 +510,7 @@ export default function Wrapper({ initialSettings, fallback }) {
if (typeof bg === "object") { if (typeof bg === "object") {
backgroundImage = bg.image || ""; backgroundImage = bg.image || "";
if (bg.opacity !== undefined) { if (bg.opacity !== undefined) {
opacity = bg.opacity / 100; opacity = 1 - bg.opacity / 100;
} }
backgroundBlur = bg.blur !== undefined; backgroundBlur = bg.blur !== undefined;
backgroundSaturate = bg.saturate !== undefined; backgroundSaturate = bg.saturate !== undefined;
@@ -524,17 +525,25 @@ export default function Wrapper({ initialSettings, fallback }) {
const body = document.body; const body = document.body;
html.classList.remove("dark", "scheme-dark", "scheme-light"); 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.add(theme === "dark" ? "scheme-dark" : "scheme-light");
html.classList.remove(...Array.from(html.classList).filter((cls) => cls.startsWith("theme-"))); const desiredThemeClass = `theme-${color || initialSettings.color || "slate"}`;
html.classList.add(`theme-${initialSettings.color || "slate"}`); const themeClassesToRemove = Array.from(html.classList).filter(
(cls) => cls.startsWith("theme-") && cls !== desiredThemeClass,
);
if (themeClassesToRemove.length) {
html.classList.remove(...themeClassesToRemove);
}
if (!html.classList.contains(desiredThemeClass)) {
html.classList.add(desiredThemeClass);
}
// Remove any previously applied inline styles // Remove any previously applied inline styles
body.style.backgroundImage = ""; body.style.backgroundImage = "";
body.style.backgroundColor = ""; body.style.backgroundColor = "";
body.style.backgroundAttachment = ""; body.style.backgroundAttachment = "";
}, [backgroundImage, opacity, theme, initialSettings.color]); }, [backgroundImage, opacity, theme, color, initialSettings.color]);
return ( return (
<> <>

View File

@@ -1,4 +1,5 @@
--- ---
# url: https://proxmox.host.or.ip:8006 # pve:
# token: username@pam!Token ID # url: https://proxmox.host.or.ip:8006
# secret: secret # token: username@pam!Token ID
# secret: secret

View File

@@ -30,12 +30,13 @@ body,
height: 100%; height: 100%;
margin: 0; margin: 0;
padding: 0; padding: 0;
background-color: rgb(var(--bg-color));
} }
#background { #background {
position: fixed; position: fixed;
inset: 0; inset: 0;
z-index: -1; z-index: 0;
background-size: cover; background-size: cover;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;

View File

@@ -284,6 +284,7 @@ export function cleanServiceGroups(groups) {
// deluge, qbittorrent // deluge, qbittorrent
enableLeechProgress, enableLeechProgress,
enableLeechSize,
// diskstation // diskstation
volume, volume,
@@ -308,7 +309,7 @@ export function cleanServiceGroups(groups) {
// gamedig // gamedig
gameToken, gameToken,
// beszel, glances, immich, komga, mealie, pihole, pfsense, speedtest // authentik, beszel, glances, immich, komga, mealie, pihole, pfsense, speedtest
version, version,
// glances // glances
@@ -396,12 +397,21 @@ export function cleanServiceGroups(groups) {
// unifi // unifi
site, site,
// unraid
pool1,
pool2,
pool3,
pool4,
// vikunja // vikunja
enableTaskList, enableTaskList,
// wgeasy // wgeasy
threshold, threshold,
// yourspotify
interval,
// technitium // technitium
range, range,
@@ -484,6 +494,7 @@ export function cleanServiceGroups(groups) {
} }
if (["deluge", "qbittorrent"].includes(type)) { if (["deluge", "qbittorrent"].includes(type)) {
if (enableLeechProgress !== undefined) widget.enableLeechProgress = JSON.parse(enableLeechProgress); if (enableLeechProgress !== undefined) widget.enableLeechProgress = JSON.parse(enableLeechProgress);
if (enableLeechSize !== undefined) widget.enableLeechSize = JSON.parse(enableLeechSize);
} }
if (["opnsense", "pfsense"].includes(type)) { if (["opnsense", "pfsense"].includes(type)) {
if (wan) widget.wan = wan; if (wan) widget.wan = wan;
@@ -518,6 +529,7 @@ export function cleanServiceGroups(groups) {
} }
if ( if (
[ [
"authentik",
"beszel", "beszel",
"glances", "glances",
"immich", "immich",
@@ -610,6 +622,17 @@ export function cleanServiceGroups(groups) {
if (type === "grafana") { if (type === "grafana") {
if (alerts) widget.alerts = alerts; 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;
}
if (type === "yourspotify") {
if (interval !== undefined) {
widget.interval = interval;
}
}
return widget; return widget;
}); });
return cleanedService; return cleanedService;

View File

@@ -8,6 +8,10 @@ import widgets from "widgets/widgets";
const logger = createLogger("credentialedProxyHandler"); const logger = createLogger("credentialedProxyHandler");
function basicAuthHeader(widget) {
return `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
}
export default async function credentialedProxyHandler(req, res, map) { export default async function credentialedProxyHandler(req, res, map) {
const { group, service, endpoint, index } = req.query; const { group, service, endpoint, index } = req.query;
@@ -61,7 +65,7 @@ export default async function credentialedProxyHandler(req, res, map) {
if (widget.key) { if (widget.key) {
headers.Authorization = `Bearer ${widget.key}`; headers.Authorization = `Bearer ${widget.key}`;
} else { } else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} }
} else if (widget.type === "proxmox") { } else if (widget.type === "proxmox") {
headers.Authorization = `PVEAPIToken=${widget.username}=${widget.password}`; headers.Authorization = `PVEAPIToken=${widget.username}=${widget.password}`;
@@ -78,31 +82,31 @@ export default async function credentialedProxyHandler(req, res, map) {
if (widget.key) { if (widget.key) {
headers["NC-Token"] = `${widget.key}`; headers["NC-Token"] = `${widget.key}`;
} else { } else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} }
} else if (widget.type === "paperlessngx") { } else if (widget.type === "paperlessngx") {
if (widget.key) { if (widget.key) {
headers.Authorization = `Token ${widget.key}`; headers.Authorization = `Token ${widget.key}`;
} else { } else {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} }
} else if (widget.type === "azuredevops") { } else if (widget.type === "azuredevops") {
headers.Authorization = `Basic ${Buffer.from(`$:${widget.key}`).toString("base64")}`; headers.Authorization = `Basic ${Buffer.from(`$:${widget.key}`).toString("base64")}`;
} else if (widget.type === "glances") { } else if (widget.type === "glances") {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} else if (widget.type === "plantit") { } else if (widget.type === "plantit") {
headers.Key = `${widget.key}`; headers.Key = `${widget.key}`;
} else if (widget.type === "myspeed") { } else if (widget.type === "myspeed") {
headers.Password = `${widget.password}`; headers.Password = `${widget.password}`;
} else if (widget.type === "esphome") { } else if (widget.type === "esphome") {
if (widget.username && widget.password) { if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} else if (widget.key) { } else if (widget.key) {
headers.Cookie = `authenticated=${widget.key}`; headers.Cookie = `authenticated=${widget.key}`;
} }
} else if (widget.type === "wgeasy") { } else if (widget.type === "wgeasy") {
if (widget.username && widget.password) { if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`; headers.Authorization = basicAuthHeader(widget);
} else { } else {
headers.Authorization = widget.password; headers.Authorization = widget.password;
} }

View File

@@ -10,8 +10,12 @@ export default function Component({ service }) {
const { widget } = service; const { widget } = service;
const { data: usersData, error: usersError } = useWidgetAPI(widget, "users"); 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) { if (usersError || loginsError || failedLoginsError) {
const finalError = 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); let loginsLast24H;
const loginsLast24H = loginsData.reduce( let failedLoginsLast24H;
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total), switch (widget.version) {
0, case 1:
); const yesterday = new Date(Date.now()).setHours(-24);
const failedLoginsLast24H = failedLoginsData.reduce( loginsLast24H = loginsData.reduce(
(total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total), (total, current) => (current.x_cord >= yesterday ? total + current.y_cord : total),
0, 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 ( return (
<Container service={service}> <Container service={service}>

View File

@@ -11,9 +11,15 @@ const widget = {
login: { login: {
endpoint: "events/events/per_month/?action=login", endpoint: "events/events/per_month/?action=login",
}, },
loginv2: {
endpoint: "events/events/volume/?action=login&&history_days=1",
},
login_failed: { login_failed: {
endpoint: "events/events/per_month/?action=login_failed", endpoint: "events/events/per_month/?action=login_failed",
}, },
login_failedv2: {
endpoint: "events/events/volume/?action=login_failed&&history_days=1",
},
}, },
}; };

View File

@@ -0,0 +1,50 @@
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 BACKREST_DEFAULT_FIELDS = ["num_success_latest", "num_failure_latest", "num_failure_30", "bytes_added_30"];
const MAX_ALLOWED_FIELDS = 4;
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
const { data, error } = useWidgetAPI(widget, "summary");
if (error) {
return <Container service={service} error={error} />;
}
if (!widget.fields?.length) {
widget.fields = BACKREST_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="backrest.num_plans" />
<Block label="backrest.num_success_latest" />
<Block label="backrest.num_failure_latest" />
<Block label="backrest.num_success_30" />
<Block label="backrest.num_failure_30" />
<Block label="backrest.bytes_added_30" />
</Container>
);
}
return (
<Container service={service}>
<Block label="backrest.num_plans" value={t("common.number", { value: data.numPlans })} />
<Block label="backrest.num_success_latest" value={t("common.number", { value: data.numSuccessLatest })} />
<Block label="backrest.num_failure_latest" value={t("common.number", { value: data.numFailureLatest })} />
<Block label="backrest.num_success_30" value={t("common.number", { value: data.numSuccess30Days })} />
<Block label="backrest.num_failure_30" value={t("common.number", { value: data.numFailure30Days })} />
<Block label="backrest.bytes_added_30" value={t("common.bytes", { value: data.bytesAdded30Days })} />
</Container>
);
}

View File

@@ -0,0 +1,96 @@
import getServiceWidget from "utils/config/service-helpers";
import createLogger from "utils/logger";
import { asJson, formatApiCall } from "utils/proxy/api-helpers";
import { httpProxy } from "utils/proxy/http";
import widgets from "widgets/widgets";
const proxyName = "backrestProxyHandler";
const logger = createLogger(proxyName);
function sumField(plans, field) {
return plans.reduce((sum, plan) => {
const num = Number(plan[field]);
return sum + (Number.isNaN(num) ? 0 : num);
}, 0);
}
function buildResponse(plans) {
const numSuccess30Days = sumField(plans, "backupsSuccessLast30days");
const numFailure30Days = sumField(plans, "backupsFailed30days");
const bytesAdded30Days = sumField(plans, "bytesAddedLast30days");
var numSuccessLatest = 0;
var numFailureLatest = 0;
plans.forEach((plan) => {
const statuses = plan?.recentBackups?.status;
if (Array.isArray(statuses) && statuses.length > 0) {
if (statuses[0] === "STATUS_SUCCESS") {
numSuccessLatest++;
} else {
numFailureLatest++;
}
}
});
return {
numPlans: plans.length,
numSuccess30Days,
numFailure30Days,
numSuccessLatest,
numFailureLatest,
bytesAdded30Days,
};
}
export default async function backrestProxyHandler(req, res) {
const { group, service, endpoint, 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 headers = {
"content-type": "application/json",
};
if (widget.username && widget.password) {
headers.Authorization = `Basic ${Buffer.from(`${widget.username}:${widget.password}`).toString("base64")}`;
}
const { api } = widgets[widget.type];
const url = new URL(formatApiCall(api, { endpoint, ...widget }));
try {
const [status, contentType, data] = await httpProxy(url, {
method: "POST",
body: JSON.stringify({}),
headers,
});
if (status !== 200) {
logger.error("Error getting data from Backrest: %d. Data: %s", status, data);
return res.status(500).send({ error: { message: "Error getting data from Backrest", url, data } });
}
if (contentType) res.setHeader("Content-Type", "application/json");
const plans = asJson(data).planSummaries;
if (!Array.isArray(plans)) {
logger.error("Invalid plans data: %s", JSON.stringify(plans));
return res.status(500).send({ error: { message: "Invalid plans data", url, data } });
}
const response = buildResponse(plans);
return res.status(status).send(response);
} catch (error) {
logger.error("Exception calling Backrest API: %s", error.message);
return res.status(500).json({ error: "Backrest API Error", message: error.message });
}
}

View File

@@ -0,0 +1,14 @@
import backrestProxyHandler from "./proxy";
const widget = {
api: "{url}/v1.Backrest/{endpoint}",
proxyHandler: backrestProxyHandler,
mappings: {
summary: {
endpoint: "GetSummaryDashboard",
},
},
};
export default widget;

View File

@@ -9,6 +9,7 @@ const components = {
authentik: dynamic(() => import("./authentik/component")), authentik: dynamic(() => import("./authentik/component")),
autobrr: dynamic(() => import("./autobrr/component")), autobrr: dynamic(() => import("./autobrr/component")),
azuredevops: dynamic(() => import("./azuredevops/component")), azuredevops: dynamic(() => import("./azuredevops/component")),
backrest: dynamic(() => import("./backrest/component")),
bazarr: dynamic(() => import("./bazarr/component")), bazarr: dynamic(() => import("./bazarr/component")),
beszel: dynamic(() => import("./beszel/component")), beszel: dynamic(() => import("./beszel/component")),
caddy: dynamic(() => import("./caddy/component")), caddy: dynamic(() => import("./caddy/component")),
@@ -139,6 +140,7 @@ const components = {
truenas: dynamic(() => import("./truenas/component")), truenas: dynamic(() => import("./truenas/component")),
unifi: dynamic(() => import("./unifi/component")), unifi: dynamic(() => import("./unifi/component")),
unmanic: dynamic(() => import("./unmanic/component")), unmanic: dynamic(() => import("./unmanic/component")),
unraid: dynamic(() => import("./unraid/component")),
uptimekuma: dynamic(() => import("./uptimekuma/component")), uptimekuma: dynamic(() => import("./uptimekuma/component")),
uptimerobot: dynamic(() => import("./uptimerobot/component")), uptimerobot: dynamic(() => import("./uptimerobot/component")),
urbackup: dynamic(() => import("./urbackup/component")), urbackup: dynamic(() => import("./urbackup/component")),
@@ -148,6 +150,7 @@ const components = {
wgeasy: dynamic(() => import("./wgeasy/component")), wgeasy: dynamic(() => import("./wgeasy/component")),
whatsupdocker: dynamic(() => import("./whatsupdocker/component")), whatsupdocker: dynamic(() => import("./whatsupdocker/component")),
xteve: dynamic(() => import("./xteve/component")), xteve: dynamic(() => import("./xteve/component")),
yourspotify: dynamic(() => import("./yourspotify/component")),
zabbix: dynamic(() => import("./zabbix/component")), zabbix: dynamic(() => import("./zabbix/component")),
}; };

View File

@@ -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 // 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 ( return (
<Container service={service}> <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.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.home_power" value={`${toKilowatts(t, data.homePower)} ${t("evcc.kilowatt")}`} />
<Block <Block label="evcc.charge_power" value={`${toKilowatts(t, totalChargePower)} ${t("evcc.kilowatt")}`} />
label="evcc.charge_power"
value={`${toKilowatts(t, stateData.result.loadpoints[0].chargePower)} ${t("evcc.kilowatt")}`}
/>
</Container> </Container>
); );
} }

View File

@@ -24,7 +24,7 @@ export default function Component({ service }) {
<Container service={service}> <Container service={service}>
<div <div
className={classNames( 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", "service-block",
)} )}
> >

View File

@@ -3,21 +3,27 @@ import Container from "components/services/widget/container";
import useWidgetAPI from "utils/proxy/use-widget-api"; import useWidgetAPI from "utils/proxy/use-widget-api";
export const jellyseerrDefaultFields = ["pending", "approved", "available"];
export default function Component({ service }) { export default function Component({ service }) {
const { widget } = service; const { widget } = service;
const { data: statsData, error: statsError } = useWidgetAPI(widget, "request/count"); widget.fields = widget?.fields?.length ? widget.fields : jellyseerrDefaultFields;
const isIssueEnabled = widget.fields.includes("issues");
if (statsError) { const { data: statsData, error: statsError } = useWidgetAPI(widget, "request/count");
return <Container service={service} error={statsError} />; const { data: issueData, error: issueError } = useWidgetAPI(widget, isIssueEnabled ? "issue/count" : "");
if (statsError || (isIssueEnabled && issueError)) {
return <Container service={service} error={statsError ? statsError : issueError} />;
} }
if (!statsData) { if (!statsData || (isIssueEnabled && !issueData)) {
return ( return (
<Container service={service}> <Container service={service}>
<Block label="jellyseerr.pending" /> <Block label="jellyseerr.pending" />
<Block label="jellyseerr.approved" /> <Block label="jellyseerr.approved" />
<Block label="jellyseerr.available" /> <Block label="jellyseerr.available" />
<Block label="jellyseerr.issues" />
</Container> </Container>
); );
} }
@@ -27,6 +33,7 @@ export default function Component({ service }) {
<Block label="jellyseerr.pending" value={statsData.pending} /> <Block label="jellyseerr.pending" value={statsData.pending} />
<Block label="jellyseerr.approved" value={statsData.approved} /> <Block label="jellyseerr.approved" value={statsData.approved} />
<Block label="jellyseerr.available" value={statsData.available} /> <Block label="jellyseerr.available" value={statsData.available} />
<Block label="jellyseerr.issues" value={`${issueData?.open} / ${issueData?.total}`} />
</Container> </Container>
); );
} }

View File

@@ -9,6 +9,10 @@ const widget = {
endpoint: "request/count", endpoint: "request/count",
validate: ["pending", "approved", "available"], validate: ["pending", "approved", "available"],
}, },
"issue/count": {
endpoint: "issue/count",
validate: ["open", "total"],
},
}, },
}; };

View File

@@ -80,6 +80,11 @@ export default function Component({ service }) {
timeLeft={t("common.duration", { value: queueEntry.eta })} timeLeft={t("common.duration", { value: queueEntry.eta })}
title={queueEntry.name} title={queueEntry.name}
activity={queueEntry.state} activity={queueEntry.state}
size={
widget?.enableLeechSize
? t("common.bbytes", { value: queueEntry.size, maximumFractionDigits: 1 })
: undefined
}
key={`${queueEntry.name}-${queueEntry.amount_left}`} key={`${queueEntry.name}-${queueEntry.amount_left}`}
/> />
))} ))}

View File

@@ -23,10 +23,13 @@ export default function Component({ service }) {
</Container> </Container>
); );
} }
const space = spaceData.results ? spaceData.results[0] : spaceData[0];
return ( return (
<Container service={service}> <Container service={service}>
<Block label="tandoor.users" value={spaceData[0]?.user_count} /> <Block label="tandoor.users" value={space?.user_count} />
<Block label="tandoor.recipes" value={spaceData[0]?.recipe_count} /> <Block label="tandoor.recipes" value={space?.recipe_count} />
<Block label="tandoor.keywords" value={keywordData.count} /> <Block label="tandoor.keywords" value={keywordData.count} />
</Container> </Container>
); );

View 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
View 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);
}

View File

@@ -0,0 +1,7 @@
import unraidProxyHandler from "./proxy";
const widget = {
proxyHandler: unraidProxyHandler,
};
export default widget;

View File

@@ -31,6 +31,10 @@ export default function Component({ service }) {
); );
} }
if (uptimerobotData.error) {
return <Container service={service} error={uptimerobotData.error} />;
}
// multiple monitors // multiple monitors
if (uptimerobotData.pagination?.total > 1) { if (uptimerobotData.pagination?.total > 1) {
const sitesUp = uptimerobotData.monitors.filter((m) => m.status === 2).length; const sitesUp = uptimerobotData.monitors.filter((m) => m.status === 2).length;

View File

@@ -6,6 +6,7 @@ import audiobookshelf from "./audiobookshelf/widget";
import authentik from "./authentik/widget"; import authentik from "./authentik/widget";
import autobrr from "./autobrr/widget"; import autobrr from "./autobrr/widget";
import azuredevops from "./azuredevops/widget"; import azuredevops from "./azuredevops/widget";
import backrest from "./backrest/widget";
import bazarr from "./bazarr/widget"; import bazarr from "./bazarr/widget";
import beszel from "./beszel/widget"; import beszel from "./beszel/widget";
import caddy from "./caddy/widget"; import caddy from "./caddy/widget";
@@ -130,6 +131,7 @@ import truenas from "./truenas/widget";
import tubearchivist from "./tubearchivist/widget"; import tubearchivist from "./tubearchivist/widget";
import unifi from "./unifi/widget"; import unifi from "./unifi/widget";
import unmanic from "./unmanic/widget"; import unmanic from "./unmanic/widget";
import unraid from "./unraid/widget";
import uptimekuma from "./uptimekuma/widget"; import uptimekuma from "./uptimekuma/widget";
import uptimerobot from "./uptimerobot/widget"; import uptimerobot from "./uptimerobot/widget";
import urbackup from "./urbackup/widget"; import urbackup from "./urbackup/widget";
@@ -139,6 +141,7 @@ import watchtower from "./watchtower/widget";
import wgeasy from "./wgeasy/widget"; import wgeasy from "./wgeasy/widget";
import whatsupdocker from "./whatsupdocker/widget"; import whatsupdocker from "./whatsupdocker/widget";
import xteve from "./xteve/widget"; import xteve from "./xteve/widget";
import yourspotify from "./yourspotify/widget";
import zabbix from "./zabbix/widget"; import zabbix from "./zabbix/widget";
const widgets = { const widgets = {
@@ -150,6 +153,7 @@ const widgets = {
authentik, authentik,
autobrr, autobrr,
azuredevops, azuredevops,
backrest,
bazarr, bazarr,
beszel, beszel,
caddy, caddy,
@@ -278,6 +282,7 @@ const widgets = {
unifi, unifi,
unifi_console: unifi, unifi_console: unifi,
unmanic, unmanic,
unraid,
uptimekuma, uptimekuma,
uptimerobot, uptimerobot,
urbackup, urbackup,
@@ -287,6 +292,7 @@ const widgets = {
wgeasy, wgeasy,
whatsupdocker, whatsupdocker,
xteve, xteve,
yourspotify,
zabbix, zabbix,
}; };

View File

@@ -0,0 +1,76 @@
import Block from "components/services/widget/block";
import Container from "components/services/widget/container";
import { useTranslation } from "next-i18next";
import { useMemo } from "react";
import useWidgetAPI from "utils/proxy/use-widget-api";
function getStartDate(interval) {
const d = new Date();
switch (interval) {
case "day":
d.setDate(d.getDate() - 1);
break;
case "week":
d.setDate(d.getDate() - 7);
break;
case "month":
d.setMonth(d.getMonth() - 1);
break;
case "year":
d.setFullYear(d.getFullYear() - 1);
break;
}
return d.toISOString();
}
export default function Component({ service }) {
const { t } = useTranslation();
const { widget } = service;
const interval = widget?.interval || "week";
const date = useMemo(() => {
return interval === "all" ? "2006-04-23T00:00:00.000Z" : getStartDate(interval);
}, [interval]);
const params = {
timeSplit: "all",
start: date,
};
const { data: songsListened, error: songsError } = useWidgetAPI(widget, "songs", params);
const { data: timeListened, error: timeError } = useWidgetAPI(widget, "time", params);
const { data: artistsListened, error: artistsError } = useWidgetAPI(widget, "artists", params);
if (songsError || timeError || artistsError) {
return <Container service={service} error={songsError ?? timeError ?? artistsError} />;
}
if (isNaN(songsListened) || isNaN(timeListened) || isNaN(artistsListened)) {
return (
<Container service={service}>
<Block label="yourspotify.songs" />
<Block label="yourspotify.time" />
<Block label="yourspotify.artists" />
</Container>
);
}
return (
<Container service={service}>
<Block label="yourspotify.songs" value={t("common.number", { value: songsListened })} />
<Block
label="yourspotify.time"
value={t(
timeListened > 0 ? "common.duration" : "common.number", // Display 0 if duration is 0
{
value: timeListened / 1000,
},
)}
/>
<Block label="yourspotify.artists" value={t("common.number", { value: artistsListened })} />
</Container>
);
}

View File

@@ -0,0 +1,27 @@
import { asJson } from "utils/proxy/api-helpers";
import genericProxyHandler from "utils/proxy/handlers/generic";
const widget = {
api: "{url}/spotify/{endpoint}?token={key}",
proxyHandler: genericProxyHandler,
mappings: {
songs: {
endpoint: "songs_per",
params: ["start", "timeSplit"],
map: (data) => asJson(data)[0]?.count || 0,
},
time: {
endpoint: "time_per",
params: ["start", "timeSplit"],
map: (data) => asJson(data)[0]?.count || 0,
},
artists: {
endpoint: "different_artists_per",
params: ["start", "timeSplit"],
map: (data) => asJson(data)[0]?.artists?.length || 0,
},
},
};
export default widget;