mirror of
https://github.com/gethomepage/homepage.git
synced 2026-01-04 14:32:15 +08:00
Compare commits
41 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
19c3ac0d7e | ||
|
|
67a9f4983c | ||
|
|
ec79f3042a | ||
|
|
f13144ceb8 | ||
|
|
d42271acf6 | ||
|
|
fb58a66f3b | ||
|
|
c96e6703d3 | ||
|
|
8a4c808ee2 | ||
|
|
52cce0ee21 | ||
|
|
8823b04291 | ||
|
|
bb2da35d09 | ||
|
|
fa633a705d | ||
|
|
48170fe899 | ||
|
|
a53b042fec | ||
|
|
c267eeabf8 | ||
|
|
c6770d233c | ||
|
|
0a75c831a6 | ||
|
|
4d76443846 | ||
|
|
97d7ae21e4 | ||
|
|
6ab6d6fd3a | ||
|
|
1144f4dfa0 | ||
|
|
a9ad2a2146 | ||
|
|
43ebd6d0c5 | ||
|
|
d20ab844d6 | ||
|
|
857ac1f7dc | ||
|
|
986a18170c | ||
|
|
198835a697 | ||
|
|
5efed2e740 | ||
|
|
43e258a58d | ||
|
|
8ca7f422da | ||
|
|
4fc70eb1ff | ||
|
|
d90bf8079a | ||
|
|
ea63716b61 | ||
|
|
daa51f9740 | ||
|
|
340424391f | ||
|
|
312e97d18b | ||
|
|
f4fc30cd9f | ||
|
|
595049f7fc | ||
|
|
79e3eb9c90 | ||
|
|
c95837f54e | ||
|
|
068e664f16 |
2
.github/workflows/crowdin.yml
vendored
2
.github/workflows/crowdin.yml
vendored
@@ -19,7 +19,7 @@ jobs:
|
|||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: crowdin action
|
- name: crowdin action
|
||||||
uses: crowdin/github-action@v1
|
uses: crowdin/github-action@v2
|
||||||
with:
|
with:
|
||||||
upload_translations: false
|
upload_translations: false
|
||||||
download_translations: true
|
download_translations: true
|
||||||
|
|||||||
@@ -25,6 +25,13 @@
|
|||||||
<a href="https://paypal.me/phelpsben" title="Donate"><img alt="GitHub Sponsors" src="https://img.shields.io/github/sponsors/benphelps"></a>
|
<a href="https://paypal.me/phelpsben" title="Donate"><img alt="GitHub Sponsors" src="https://img.shields.io/github/sponsors/benphelps"></a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://www.digitalocean.com/?refcode=df14bcb7c016&utm_campaign=Referral_Invite&utm_medium=Referral_Program&utm_source=badge"><img src="https://web-platforms.sfo2.cdn.digitaloceanspaces.com/WWW/Badge%201.svg" alt="DigitalOcean Referral Badge" /></a>
|
||||||
|
</p>
|
||||||
|
<p align="center">
|
||||||
|
<em>Homepage builds are kindly powered by DigitalOcean.</em>
|
||||||
|
</p>
|
||||||
|
|
||||||
# Features
|
# Features
|
||||||
|
|
||||||
With features like quick search, bookmarks, weather support, a wide range of integrations and widgets, an elegant and modern design, and a focus on performance, Homepage is your ideal start to the day and a handy companion throughout it.
|
With features like quick search, bookmarks, weather support, a wide range of integrations and widgets, an elegant and modern design, and a focus on performance, Homepage is your ideal start to the day and a handy companion throughout it.
|
||||||
|
|||||||
@@ -235,4 +235,4 @@ You can show the docker stats by clicking the status indicator but this can also
|
|||||||
showStats: true
|
showStats: true
|
||||||
```
|
```
|
||||||
|
|
||||||
Also see the settings for [show docker stats](docker.md#show-docker-stats).
|
Also see the settings for [show docker stats](settings.md#show-docker-stats).
|
||||||
|
|||||||
@@ -363,7 +363,7 @@ providers:
|
|||||||
You can then pass `provider` instead of `apiKey` in your widget configuration.
|
You can then pass `provider` instead of `apiKey` in your widget configuration.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- weather:
|
- weatherapi:
|
||||||
latitude: 50.449684
|
latitude: 50.449684
|
||||||
longitude: 30.525026
|
longitude: 30.525026
|
||||||
provider: weatherapi
|
provider: weatherapi
|
||||||
@@ -377,9 +377,10 @@ You can use the 'Quick Launch' feature to search services, perform a web search
|
|||||||
|
|
||||||
There are a few optional settings for the Quick Launch feature:
|
There are a few optional settings for the Quick Launch feature:
|
||||||
|
|
||||||
- `searchDescriptions`: which lets you control whether item descriptions are included in searches. This is off by default. When enabled, results that match the item name will be placed above those that only match the description.
|
- `searchDescriptions`: which lets you control whether item descriptions are included in searches. This is false by default. When enabled, results that match the item name will be placed above those that only match the description.
|
||||||
- `hideInternetSearch`: disable automatically including the currently-selected web search (e.g. from the widget) as a Quick Launch option. This is false by default, enabling the feature.
|
- `hideInternetSearch`: disable automatically including the currently-selected web search (e.g. from the widget) as a Quick Launch option. This is false by default, enabling the feature.
|
||||||
- `showSearchSuggestions`: shows search suggestions for the internet search. This value will be inherited from the search widget if it is not specified. If it is not specified there either, it will default to false.
|
- `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.
|
||||||
- `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.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@@ -388,6 +389,17 @@ quicklaunch:
|
|||||||
hideInternetSearch: true
|
hideInternetSearch: true
|
||||||
showSearchSuggestions: true
|
showSearchSuggestions: true
|
||||||
hideVisitURL: true
|
hideVisitURL: true
|
||||||
|
provider: google # google, duckduckgo, bing, baidu, brave or custom
|
||||||
|
```
|
||||||
|
|
||||||
|
or for a custom search:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
quicklaunch:
|
||||||
|
provider: custom
|
||||||
|
url: https://www.ecosia.org/search?q=
|
||||||
|
target: _blank
|
||||||
|
suggestionUrl: https://ac.ecosia.org/autocomplete?type=list&q=
|
||||||
```
|
```
|
||||||
|
|
||||||
## Homepage Version
|
## Homepage Version
|
||||||
|
|||||||
@@ -17,3 +17,10 @@ hide:
|
|||||||
A modern, <em>fully static, fast</em>, secure <em>fully proxied</em>, highly customizable application dashboard with integrations for over 100 services and translations into multiple languages. Easily configured via YAML files or through docker label discovery.
|
A modern, <em>fully static, fast</em>, secure <em>fully proxied</em>, highly customizable application dashboard with integrations for over 100 services and translations into multiple languages. Easily configured via YAML files or through docker label discovery.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
|
<p align="center">
|
||||||
|
<a href="https://www.digitalocean.com/?refcode=df14bcb7c016&utm_campaign=Referral_Invite&utm_medium=Referral_Program&utm_source=badge"><img src="https://web-platforms.sfo2.cdn.digitaloceanspaces.com/WWW/Badge%203.svg" alt="DigitalOcean Referral Badge" /></a>
|
||||||
|
</p>
|
||||||
|
<p align="center">
|
||||||
|
<em>Homepage builds are kindly powered by DigitalOcean.</em>
|
||||||
|
</p>
|
||||||
|
|||||||
@@ -19,6 +19,8 @@ _Note: unfortunately, the package used for getting CPU temp ([systeminformation]
|
|||||||
memory: true
|
memory: true
|
||||||
disk: /disk/mount/path
|
disk: /disk/mount/path
|
||||||
cputemp: true
|
cputemp: true
|
||||||
|
tempmin: 0 # optional, minimum cpu temp
|
||||||
|
tempmax: 100 # optional, maximum cpu temp
|
||||||
uptime: true
|
uptime: true
|
||||||
units: imperial # only used by cpu temp
|
units: imperial # only used by cpu temp
|
||||||
refresh: 3000 # optional, in ms
|
refresh: 3000 # optional, in ms
|
||||||
|
|||||||
@@ -12,10 +12,8 @@ Make sure to set Intent to "API Token".
|
|||||||
|
|
||||||
The account you made the API token for also needs the following **Assigned global permissions** in Authentik:
|
The account you made the API token for also needs the following **Assigned global permissions** in Authentik:
|
||||||
|
|
||||||
- authentik Core
|
- authentik Core -> Can view User (Model: User)
|
||||||
- User
|
- authentik Events -> Can view Event (Model: Event)
|
||||||
- authentik Events
|
|
||||||
- Event
|
|
||||||
|
|
||||||
Allowed fields: `["users", "loginsLast24H", "failedLoginsLast24H"]`.
|
Allowed fields: `["users", "loginsLast24H", "failedLoginsLast24H"]`.
|
||||||
|
|
||||||
|
|||||||
@@ -8,5 +8,5 @@ Learn more about [Channels DVR Server](https://getchannels.com/dvr-server/).
|
|||||||
```yaml
|
```yaml
|
||||||
widget:
|
widget:
|
||||||
type: channelsdvrserver
|
type: channelsdvrserver
|
||||||
url: http://192.168.1.55:8089
|
url: http://server.host.or.ip:port
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -17,4 +17,6 @@ widget:
|
|||||||
enableBlocks: true # optional, defaults to false
|
enableBlocks: true # optional, defaults to false
|
||||||
enableNowPlaying: true # optional, defaults to true
|
enableNowPlaying: true # optional, defaults to true
|
||||||
enableUser: true # optional, defaults to false
|
enableUser: true # optional, defaults to false
|
||||||
|
showEpisodeNumber: true # optional, defaults to false
|
||||||
|
expandOneStreamToTwoRows: false # optional, defaults to true
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -16,4 +16,7 @@ widget:
|
|||||||
key: apikeyapikeyapikeyapikeyapikey
|
key: apikeyapikeyapikeyapikeyapikey
|
||||||
enableBlocks: true # optional, defaults to false
|
enableBlocks: true # optional, defaults to false
|
||||||
enableNowPlaying: true # optional, defaults to true
|
enableNowPlaying: true # optional, defaults to true
|
||||||
|
enableUser: true # optional, defaults to false
|
||||||
|
showEpisodeNumber: true # optional, defaults to false
|
||||||
|
expandOneStreamToTwoRows: false # optional, defaults to true
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ title: Medusa
|
|||||||
description: Medusa Widget Configuration
|
description: Medusa Widget Configuration
|
||||||
---
|
---
|
||||||
|
|
||||||
Learn more about [Medusa](https://github.com/medusajs/medusa).
|
Learn more about [Medusa](https://github.com/pymedusa/Medusa).
|
||||||
|
|
||||||
Allowed fields: `["wanted", "queued", "series"]`.
|
Allowed fields: `["wanted", "queued", "series"]`.
|
||||||
|
|
||||||
|
|||||||
@@ -15,4 +15,6 @@ widget:
|
|||||||
url: http://tautulli.host.or.ip
|
url: http://tautulli.host.or.ip
|
||||||
key: apikeyapikeyapikeyapikeyapikey
|
key: apikeyapikeyapikeyapikeyapikey
|
||||||
enableUser: true # optional, defaults to false
|
enableUser: true # optional, defaults to false
|
||||||
|
showEpisodeNumber: true # optional, defaults to false
|
||||||
|
expandOneStreamToTwoRows: false # optional, defaults to true
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -16,4 +16,5 @@ Allowed fields: `["download", "upload", "ping"]`.
|
|||||||
widget:
|
widget:
|
||||||
type: speedtest
|
type: speedtest
|
||||||
url: http://speedtest.host.or.ip
|
url: http://speedtest.host.or.ip
|
||||||
|
bitratePrecision: 3 # optional, default is 0
|
||||||
```
|
```
|
||||||
|
|||||||
14
docs/widgets/services/swagdashboard.md
Normal file
14
docs/widgets/services/swagdashboard.md
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
---
|
||||||
|
title: SWAG Dashboard
|
||||||
|
description: SWAG Dashboard Widget Configuration
|
||||||
|
---
|
||||||
|
|
||||||
|
Learn more about [SWAG Dashboard](https://github.com/linuxserver/docker-mods/tree/swag-dashboard).
|
||||||
|
|
||||||
|
Allowed fields: `["proxied", "auth", "outdated", "banned"]`.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
widget:
|
||||||
|
type: swagdashboard
|
||||||
|
url: http://swagdashboard.host.or.ip:adminport # default port is 81
|
||||||
|
```
|
||||||
@@ -5,7 +5,7 @@ description: Uptime Kuma Widget Configuration
|
|||||||
|
|
||||||
Learn more about [Uptime Kuma](https://github.com/louislam/uptime-kuma).
|
Learn more about [Uptime Kuma](https://github.com/louislam/uptime-kuma).
|
||||||
|
|
||||||
As Uptime Kuma does not yet have a full API the widget uses data from a single "status page". As such you will need a status page setup with a group of monitored sites, which is where you get the slug (without the `/status/` portion).
|
As Uptime Kuma does not yet have a full API the widget uses data from a single "status page". As such you will need a status page setup with a group of monitored sites, which is where you get the slug (the url without the `/status/` portion). E.g. if your status page is URL http://uptimekuma.host/status/statuspageslug, insert `slug: statuspageslug`.
|
||||||
|
|
||||||
Allowed fields: `["up", "down", "uptime", "incident"]`.
|
Allowed fields: `["up", "down", "uptime", "incident"]`.
|
||||||
|
|
||||||
|
|||||||
20
docs/widgets/services/wgeasy.md
Normal file
20
docs/widgets/services/wgeasy.md
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
---
|
||||||
|
title: Wg-Easy
|
||||||
|
description: Wg-Easy Widget Configuration
|
||||||
|
---
|
||||||
|
|
||||||
|
Learn more about [Wg-Easy](https://github.com/wg-easy/wg-easy).
|
||||||
|
|
||||||
|
Allowed fields: `["connected", "enabled", "disabled", "total"]`.
|
||||||
|
|
||||||
|
Note: by default `["connected", "enabled", "total"]` are displayed.
|
||||||
|
|
||||||
|
To detect if a device is connected the time since the last handshake is queried. `threshold` is the time to wait in minutes since the last handshake to consider a device connected. Default is 2 minutes.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
widget:
|
||||||
|
type: wgeasy
|
||||||
|
url: http://wg.easy.or.ip
|
||||||
|
password: yourwgeasypassword
|
||||||
|
threshold: 2 # optional
|
||||||
|
```
|
||||||
@@ -129,6 +129,7 @@ nav:
|
|||||||
- widgets/services/sonarr.md
|
- widgets/services/sonarr.md
|
||||||
- widgets/services/speedtest-tracker.md
|
- widgets/services/speedtest-tracker.md
|
||||||
- widgets/services/stash.md
|
- widgets/services/stash.md
|
||||||
|
- widgets/services/swagdashboard.md
|
||||||
- widgets/services/syncthing-relay-server.md
|
- widgets/services/syncthing-relay-server.md
|
||||||
- widgets/services/tailscale.md
|
- widgets/services/tailscale.md
|
||||||
- widgets/services/tandoor.md
|
- widgets/services/tandoor.md
|
||||||
|
|||||||
363
package-lock.json
generated
363
package-lock.json
generated
@@ -27,14 +27,14 @@
|
|||||||
"ping": "^0.4.4",
|
"ping": "^0.4.4",
|
||||||
"pretty-bytes": "^6.1.1",
|
"pretty-bytes": "^6.1.1",
|
||||||
"raw-body": "^2.5.2",
|
"raw-body": "^2.5.2",
|
||||||
"react": "^18.2.0",
|
"react": "^18.3.1",
|
||||||
"react-dom": "^18.2.0",
|
"react-dom": "^18.2.0",
|
||||||
"react-i18next": "^11.18.6",
|
"react-i18next": "^11.18.6",
|
||||||
"react-icons": "^4.12.0",
|
"react-icons": "^4.12.0",
|
||||||
"recharts": "^2.12.3",
|
"recharts": "^2.12.6",
|
||||||
"rrule": "^2.8.1",
|
"rrule": "^2.8.1",
|
||||||
"swr": "^1.3.0",
|
"swr": "^1.3.0",
|
||||||
"systeminformation": "^5.22.0",
|
"systeminformation": "^5.22.7",
|
||||||
"tough-cookie": "^4.1.3",
|
"tough-cookie": "^4.1.3",
|
||||||
"urbackup-server-api": "^0.8.9",
|
"urbackup-server-api": "^0.8.9",
|
||||||
"winston": "^3.11.0",
|
"winston": "^3.11.0",
|
||||||
@@ -45,18 +45,18 @@
|
|||||||
"autoprefixer": "^10.4.17",
|
"autoprefixer": "^10.4.17",
|
||||||
"eslint": "^8.57.0",
|
"eslint": "^8.57.0",
|
||||||
"eslint-config-airbnb": "^19.0.4",
|
"eslint-config-airbnb": "^19.0.4",
|
||||||
"eslint-config-next": "^12.3.4",
|
"eslint-config-next": "^14.2.3",
|
||||||
"eslint-config-prettier": "^9.1.0",
|
"eslint-config-prettier": "^9.1.0",
|
||||||
"eslint-plugin-import": "^2.29.1",
|
"eslint-plugin-import": "^2.29.1",
|
||||||
"eslint-plugin-jsx-a11y": "^6.8.0",
|
"eslint-plugin-jsx-a11y": "^6.8.0",
|
||||||
"eslint-plugin-prettier": "^4.2.1",
|
"eslint-plugin-prettier": "^4.2.1",
|
||||||
"eslint-plugin-react": "^7.34.1",
|
"eslint-plugin-react": "^7.34.2",
|
||||||
"eslint-plugin-react-hooks": "^4.6.0",
|
"eslint-plugin-react-hooks": "^4.6.2",
|
||||||
"postcss": "^8.4.38",
|
"postcss": "^8.4.38",
|
||||||
"prettier": "^3.2.5",
|
"prettier": "^3.2.5",
|
||||||
"tailwind-scrollbar": "^3.0.5",
|
"tailwind-scrollbar": "^3.0.5",
|
||||||
"tailwindcss": "^3.4.3",
|
"tailwindcss": "^3.4.3",
|
||||||
"typescript": "^4.9.5"
|
"typescript": "^5.4.5"
|
||||||
},
|
},
|
||||||
"optionalDependencies": {
|
"optionalDependencies": {
|
||||||
"osx-temperature-sensor": "^1.0.8"
|
"osx-temperature-sensor": "^1.0.8"
|
||||||
@@ -344,12 +344,58 @@
|
|||||||
"integrity": "sha512-H/69Lc5Q02dq3o+dxxy5O/oNxFsZpdL6WREtOOtOM1B/weonIwDXkekr1KV5DPVPr12IHFPrMrcJQ6bgPMfn7A=="
|
"integrity": "sha512-H/69Lc5Q02dq3o+dxxy5O/oNxFsZpdL6WREtOOtOM1B/weonIwDXkekr1KV5DPVPr12IHFPrMrcJQ6bgPMfn7A=="
|
||||||
},
|
},
|
||||||
"node_modules/@next/eslint-plugin-next": {
|
"node_modules/@next/eslint-plugin-next": {
|
||||||
"version": "12.3.4",
|
"version": "14.2.3",
|
||||||
"resolved": "https://registry.npmjs.org/@next/eslint-plugin-next/-/eslint-plugin-next-12.3.4.tgz",
|
"resolved": "https://registry.npmjs.org/@next/eslint-plugin-next/-/eslint-plugin-next-14.2.3.tgz",
|
||||||
"integrity": "sha512-BFwj8ykJY+zc1/jWANsDprDIu2MgwPOIKxNVnrKvPs+f5TPegrVnem8uScND+1veT4B7F6VeqgaNLFW1Hzl9Og==",
|
"integrity": "sha512-L3oDricIIjgj1AVnRdRor21gI7mShlSwU/1ZGHmqM3LzHhXXhdkrfeNY5zif25Bi5Dd7fiJHsbhoZCHfXYvlAw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"glob": "7.1.7"
|
"glob": "10.3.10"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@next/eslint-plugin-next/node_modules/brace-expansion": {
|
||||||
|
"version": "2.0.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
|
||||||
|
"integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"balanced-match": "^1.0.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@next/eslint-plugin-next/node_modules/glob": {
|
||||||
|
"version": "10.3.10",
|
||||||
|
"resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz",
|
||||||
|
"integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"foreground-child": "^3.1.0",
|
||||||
|
"jackspeak": "^2.3.5",
|
||||||
|
"minimatch": "^9.0.1",
|
||||||
|
"minipass": "^5.0.0 || ^6.0.2 || ^7.0.0",
|
||||||
|
"path-scurry": "^1.10.1"
|
||||||
|
},
|
||||||
|
"bin": {
|
||||||
|
"glob": "dist/esm/bin.mjs"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=16 || 14 >=14.17"
|
||||||
|
},
|
||||||
|
"funding": {
|
||||||
|
"url": "https://github.com/sponsors/isaacs"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"node_modules/@next/eslint-plugin-next/node_modules/minimatch": {
|
||||||
|
"version": "9.0.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz",
|
||||||
|
"integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"brace-expansion": "^2.0.1"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=16 || 14 >=14.17"
|
||||||
|
},
|
||||||
|
"funding": {
|
||||||
|
"url": "https://github.com/sponsors/isaacs"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/@next/swc-android-arm-eabi": {
|
"node_modules/@next/swc-android-arm-eabi": {
|
||||||
@@ -1006,15 +1052,16 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/array-includes": {
|
"node_modules/array-includes": {
|
||||||
"version": "3.1.7",
|
"version": "3.1.8",
|
||||||
"resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz",
|
"resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz",
|
||||||
"integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==",
|
"integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.2",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1",
|
"es-abstract": "^1.23.2",
|
||||||
"get-intrinsic": "^1.2.1",
|
"es-object-atoms": "^1.0.0",
|
||||||
|
"get-intrinsic": "^1.2.4",
|
||||||
"is-string": "^1.0.7"
|
"is-string": "^1.0.7"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
@@ -2318,6 +2365,19 @@
|
|||||||
"once": "^1.4.0"
|
"once": "^1.4.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/enhanced-resolve": {
|
||||||
|
"version": "5.16.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.16.0.tgz",
|
||||||
|
"integrity": "sha512-O+QWCviPNSSLAD9Ucn8Awv+poAkqn3T1XY5/N7kR7rQO9yfSGWkYZDwpJ+iKF7B8rxaQKWngSqACpgzeapSyoA==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"graceful-fs": "^4.2.4",
|
||||||
|
"tapable": "^2.2.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">=10.13.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/entities": {
|
"node_modules/entities": {
|
||||||
"version": "4.5.0",
|
"version": "4.5.0",
|
||||||
"resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
|
"resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz",
|
||||||
@@ -2411,14 +2471,14 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/es-iterator-helpers": {
|
"node_modules/es-iterator-helpers": {
|
||||||
"version": "1.0.18",
|
"version": "1.0.19",
|
||||||
"resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.18.tgz",
|
"resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz",
|
||||||
"integrity": "sha512-scxAJaewsahbqTYrGKJihhViaM6DDZDDoucfvzNbK0pOren1g/daDQ3IAhzn+1G14rBG7w+i5N+qul60++zlKA==",
|
"integrity": "sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.7",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.1",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.23.0",
|
"es-abstract": "^1.23.3",
|
||||||
"es-errors": "^1.3.0",
|
"es-errors": "^1.3.0",
|
||||||
"es-set-tostringtag": "^2.0.3",
|
"es-set-tostringtag": "^2.0.3",
|
||||||
"function-bind": "^1.1.2",
|
"function-bind": "^1.1.2",
|
||||||
@@ -2604,20 +2664,20 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint-config-next": {
|
"node_modules/eslint-config-next": {
|
||||||
"version": "12.3.4",
|
"version": "14.2.3",
|
||||||
"resolved": "https://registry.npmjs.org/eslint-config-next/-/eslint-config-next-12.3.4.tgz",
|
"resolved": "https://registry.npmjs.org/eslint-config-next/-/eslint-config-next-14.2.3.tgz",
|
||||||
"integrity": "sha512-WuT3gvgi7Bwz00AOmKGhOeqnyA5P29Cdyr0iVjLyfDbk+FANQKcOjFUTZIdyYfe5Tq1x4TGcmoe4CwctGvFjHQ==",
|
"integrity": "sha512-ZkNztm3Q7hjqvB1rRlOX8P9E/cXRL9ajRcs8jufEtwMfTVYRqnmtnaSu57QqHyBlovMuiB8LEzfLBkh5RYV6Fg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@next/eslint-plugin-next": "12.3.4",
|
"@next/eslint-plugin-next": "14.2.3",
|
||||||
"@rushstack/eslint-patch": "^1.1.3",
|
"@rushstack/eslint-patch": "^1.3.3",
|
||||||
"@typescript-eslint/parser": "^5.21.0",
|
"@typescript-eslint/parser": "^5.4.2 || ^6.0.0 || 7.0.0 - 7.2.0",
|
||||||
"eslint-import-resolver-node": "^0.3.6",
|
"eslint-import-resolver-node": "^0.3.6",
|
||||||
"eslint-import-resolver-typescript": "^2.7.1",
|
"eslint-import-resolver-typescript": "^3.5.2",
|
||||||
"eslint-plugin-import": "^2.26.0",
|
"eslint-plugin-import": "^2.28.1",
|
||||||
"eslint-plugin-jsx-a11y": "^6.5.1",
|
"eslint-plugin-jsx-a11y": "^6.7.1",
|
||||||
"eslint-plugin-react": "^7.31.7",
|
"eslint-plugin-react": "^7.33.2",
|
||||||
"eslint-plugin-react-hooks": "^4.5.0"
|
"eslint-plugin-react-hooks": "^4.5.0 || 5.0.0-canary-7118f5dd7-20230705"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"eslint": "^7.23.0 || ^8.0.0",
|
"eslint": "^7.23.0 || ^8.0.0",
|
||||||
@@ -2662,45 +2722,30 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint-import-resolver-typescript": {
|
"node_modules/eslint-import-resolver-typescript": {
|
||||||
"version": "2.7.1",
|
"version": "3.6.1",
|
||||||
"resolved": "https://registry.npmjs.org/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-2.7.1.tgz",
|
"resolved": "https://registry.npmjs.org/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-3.6.1.tgz",
|
||||||
"integrity": "sha512-00UbgGwV8bSgUv34igBDbTOtKhqoRMy9bFjNehT40bXg6585PNIct8HhXZ0SybqB9rWtXj9crcku8ndDn/gIqQ==",
|
"integrity": "sha512-xgdptdoi5W3niYeuQxKmzVDTATvLYqhpwmykwsh7f6HIOStGWEIL9iqZgQDF9u9OEzrRwR8no5q2VT+bjAujTg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"debug": "^4.3.4",
|
"debug": "^4.3.4",
|
||||||
"glob": "^7.2.0",
|
"enhanced-resolve": "^5.12.0",
|
||||||
"is-glob": "^4.0.3",
|
"eslint-module-utils": "^2.7.4",
|
||||||
"resolve": "^1.22.0",
|
"fast-glob": "^3.3.1",
|
||||||
"tsconfig-paths": "^3.14.1"
|
"get-tsconfig": "^4.5.0",
|
||||||
|
"is-core-module": "^2.11.0",
|
||||||
|
"is-glob": "^4.0.3"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=4"
|
"node": "^14.18.0 || >=16.0.0"
|
||||||
|
},
|
||||||
|
"funding": {
|
||||||
|
"url": "https://opencollective.com/unts/projects/eslint-import-resolver-ts"
|
||||||
},
|
},
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"eslint": "*",
|
"eslint": "*",
|
||||||
"eslint-plugin-import": "*"
|
"eslint-plugin-import": "*"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint-import-resolver-typescript/node_modules/glob": {
|
|
||||||
"version": "7.2.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz",
|
|
||||||
"integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==",
|
|
||||||
"dev": true,
|
|
||||||
"dependencies": {
|
|
||||||
"fs.realpath": "^1.0.0",
|
|
||||||
"inflight": "^1.0.4",
|
|
||||||
"inherits": "2",
|
|
||||||
"minimatch": "^3.1.1",
|
|
||||||
"once": "^1.3.0",
|
|
||||||
"path-is-absolute": "^1.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": "*"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/isaacs"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/eslint-module-utils": {
|
"node_modules/eslint-module-utils": {
|
||||||
"version": "2.8.0",
|
"version": "2.8.0",
|
||||||
"resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz",
|
"resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz",
|
||||||
@@ -2831,29 +2876,29 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint-plugin-react": {
|
"node_modules/eslint-plugin-react": {
|
||||||
"version": "7.34.1",
|
"version": "7.34.2",
|
||||||
"resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.34.1.tgz",
|
"resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.34.2.tgz",
|
||||||
"integrity": "sha512-N97CxlouPT1AHt8Jn0mhhN2RrADlUAsk1/atcT2KyA/l9Q/E6ll7OIGwNumFmWfZ9skV3XXccYS19h80rHtgkw==",
|
"integrity": "sha512-2HCmrU+/JNigDN6tg55cRDKCQWicYAPB38JGSFDQt95jDm8rrvSUo7YPkOIm5l6ts1j1zCvysNcasvfTMQzUOw==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"array-includes": "^3.1.7",
|
"array-includes": "^3.1.8",
|
||||||
"array.prototype.findlast": "^1.2.4",
|
"array.prototype.findlast": "^1.2.5",
|
||||||
"array.prototype.flatmap": "^1.3.2",
|
"array.prototype.flatmap": "^1.3.2",
|
||||||
"array.prototype.toreversed": "^1.1.2",
|
"array.prototype.toreversed": "^1.1.2",
|
||||||
"array.prototype.tosorted": "^1.1.3",
|
"array.prototype.tosorted": "^1.1.3",
|
||||||
"doctrine": "^2.1.0",
|
"doctrine": "^2.1.0",
|
||||||
"es-iterator-helpers": "^1.0.17",
|
"es-iterator-helpers": "^1.0.19",
|
||||||
"estraverse": "^5.3.0",
|
"estraverse": "^5.3.0",
|
||||||
"jsx-ast-utils": "^2.4.1 || ^3.0.0",
|
"jsx-ast-utils": "^2.4.1 || ^3.0.0",
|
||||||
"minimatch": "^3.1.2",
|
"minimatch": "^3.1.2",
|
||||||
"object.entries": "^1.1.7",
|
"object.entries": "^1.1.8",
|
||||||
"object.fromentries": "^2.0.7",
|
"object.fromentries": "^2.0.8",
|
||||||
"object.hasown": "^1.1.3",
|
"object.hasown": "^1.1.4",
|
||||||
"object.values": "^1.1.7",
|
"object.values": "^1.2.0",
|
||||||
"prop-types": "^15.8.1",
|
"prop-types": "^15.8.1",
|
||||||
"resolve": "^2.0.0-next.5",
|
"resolve": "^2.0.0-next.5",
|
||||||
"semver": "^6.3.1",
|
"semver": "^6.3.1",
|
||||||
"string.prototype.matchall": "^4.0.10"
|
"string.prototype.matchall": "^4.0.11"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=4"
|
"node": ">=4"
|
||||||
@@ -2863,9 +2908,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/eslint-plugin-react-hooks": {
|
"node_modules/eslint-plugin-react-hooks": {
|
||||||
"version": "4.6.0",
|
"version": "4.6.2",
|
||||||
"resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz",
|
"resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.2.tgz",
|
||||||
"integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==",
|
"integrity": "sha512-QzliNJq4GinDBcD8gPB5v0wh6g8q3SUi6EFF0x8N/BL9PoVs0atuGc47ozMRyOWAKdwaZ5OnbOEa3WR+dSGKuQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=10"
|
"node": ">=10"
|
||||||
@@ -3436,6 +3481,18 @@
|
|||||||
"url": "https://github.com/sponsors/ljharb"
|
"url": "https://github.com/sponsors/ljharb"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/get-tsconfig": {
|
||||||
|
"version": "4.7.3",
|
||||||
|
"resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.7.3.tgz",
|
||||||
|
"integrity": "sha512-ZvkrzoUA0PQZM6fy6+/Hce561s+faD1rsNwhnO5FelNjyy7EMGJ3Rz1AQ8GYDWjhRs/7dBLOEJvhK8MiEJOAFg==",
|
||||||
|
"dev": true,
|
||||||
|
"dependencies": {
|
||||||
|
"resolve-pkg-maps": "^1.0.0"
|
||||||
|
},
|
||||||
|
"funding": {
|
||||||
|
"url": "https://github.com/privatenumber/get-tsconfig?sponsor=1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/getpass": {
|
"node_modules/getpass": {
|
||||||
"version": "0.1.7",
|
"version": "0.1.7",
|
||||||
"resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz",
|
"resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz",
|
||||||
@@ -3561,6 +3618,12 @@
|
|||||||
"url": "https://github.com/sindresorhus/got?sponsor=1"
|
"url": "https://github.com/sindresorhus/got?sponsor=1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/graceful-fs": {
|
||||||
|
"version": "4.2.11",
|
||||||
|
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
|
||||||
|
"integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
"node_modules/graphemer": {
|
"node_modules/graphemer": {
|
||||||
"version": "1.4.0",
|
"version": "1.4.0",
|
||||||
"resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
|
"resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz",
|
||||||
@@ -5046,28 +5109,29 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/object.entries": {
|
"node_modules/object.entries": {
|
||||||
"version": "1.1.7",
|
"version": "1.1.8",
|
||||||
"resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.7.tgz",
|
"resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz",
|
||||||
"integrity": "sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA==",
|
"integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.2",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1"
|
"es-object-atoms": "^1.0.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 0.4"
|
"node": ">= 0.4"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/object.fromentries": {
|
"node_modules/object.fromentries": {
|
||||||
"version": "2.0.7",
|
"version": "2.0.8",
|
||||||
"resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz",
|
"resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz",
|
||||||
"integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==",
|
"integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.2",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1"
|
"es-abstract": "^1.23.2",
|
||||||
|
"es-object-atoms": "^1.0.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 0.4"
|
"node": ">= 0.4"
|
||||||
@@ -5089,27 +5153,31 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/object.hasown": {
|
"node_modules/object.hasown": {
|
||||||
"version": "1.1.3",
|
"version": "1.1.4",
|
||||||
"resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.3.tgz",
|
"resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.4.tgz",
|
||||||
"integrity": "sha512-fFI4VcYpRHvSLXxP7yiZOMAd331cPfd2p7PFDVbgUsYOfCT3tICVqXWngbjr4m49OvsBwUBQ6O2uQoJvy3RexA==",
|
"integrity": "sha512-FZ9LZt9/RHzGySlBARE3VF+gE26TxR38SdmqOqliuTnl9wrKulaQs+4dee1V+Io8VfxqzAfHu6YuRgUy8OHoTg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1"
|
"es-abstract": "^1.23.2",
|
||||||
|
"es-object-atoms": "^1.0.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 0.4"
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
"url": "https://github.com/sponsors/ljharb"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/object.values": {
|
"node_modules/object.values": {
|
||||||
"version": "1.1.7",
|
"version": "1.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz",
|
"resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz",
|
||||||
"integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==",
|
"integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.2",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1"
|
"es-object-atoms": "^1.0.0"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 0.4"
|
"node": ">= 0.4"
|
||||||
@@ -5652,9 +5720,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/react": {
|
"node_modules/react": {
|
||||||
"version": "18.2.0",
|
"version": "18.3.1",
|
||||||
"resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz",
|
||||||
"integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==",
|
"integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"loose-envify": "^1.1.0"
|
"loose-envify": "^1.1.0"
|
||||||
},
|
},
|
||||||
@@ -5772,9 +5840,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/recharts": {
|
"node_modules/recharts": {
|
||||||
"version": "2.12.3",
|
"version": "2.12.6",
|
||||||
"resolved": "https://registry.npmjs.org/recharts/-/recharts-2.12.3.tgz",
|
"resolved": "https://registry.npmjs.org/recharts/-/recharts-2.12.6.tgz",
|
||||||
"integrity": "sha512-vE/F7wTlokf5mtCqVDJlVKelCjliLSJ+DJxj79XlMREm7gpV7ljwbrwE3CfeaoDlOaLX+6iwHaVRn9587YkwIg==",
|
"integrity": "sha512-D+7j9WI+D0NHauah3fKHuNNcRK8bOypPW7os1DERinogGBGaHI7i6tQKJ0aUF3JXyBZ63dyfKIW2WTOPJDxJ8w==",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"clsx": "^2.0.0",
|
"clsx": "^2.0.0",
|
||||||
"eventemitter3": "^4.0.1",
|
"eventemitter3": "^4.0.1",
|
||||||
@@ -5933,6 +6001,15 @@
|
|||||||
"node": ">=4"
|
"node": ">=4"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/resolve-pkg-maps": {
|
||||||
|
"version": "1.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz",
|
||||||
|
"integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==",
|
||||||
|
"dev": true,
|
||||||
|
"funding": {
|
||||||
|
"url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/responselike": {
|
"node_modules/responselike": {
|
||||||
"version": "3.0.0",
|
"version": "3.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/responselike/-/responselike-3.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/responselike/-/responselike-3.0.0.tgz",
|
||||||
@@ -6131,14 +6208,15 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/set-function-name": {
|
"node_modules/set-function-name": {
|
||||||
"version": "2.0.1",
|
"version": "2.0.2",
|
||||||
"resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz",
|
||||||
"integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==",
|
"integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"define-data-property": "^1.0.1",
|
"define-data-property": "^1.1.4",
|
||||||
|
"es-errors": "^1.3.0",
|
||||||
"functions-have-names": "^1.2.3",
|
"functions-have-names": "^1.2.3",
|
||||||
"has-property-descriptors": "^1.0.0"
|
"has-property-descriptors": "^1.0.2"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">= 0.4"
|
"node": ">= 0.4"
|
||||||
@@ -6185,14 +6263,18 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/side-channel": {
|
"node_modules/side-channel": {
|
||||||
"version": "1.0.4",
|
"version": "1.0.6",
|
||||||
"resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz",
|
"resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz",
|
||||||
"integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==",
|
"integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.0",
|
"call-bind": "^1.0.7",
|
||||||
"get-intrinsic": "^1.0.2",
|
"es-errors": "^1.3.0",
|
||||||
"object-inspect": "^1.9.0"
|
"get-intrinsic": "^1.2.4",
|
||||||
|
"object-inspect": "^1.13.1"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 0.4"
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
"url": "https://github.com/sponsors/ljharb"
|
||||||
@@ -6413,20 +6495,26 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/string.prototype.matchall": {
|
"node_modules/string.prototype.matchall": {
|
||||||
"version": "4.0.10",
|
"version": "4.0.11",
|
||||||
"resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.10.tgz",
|
"resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz",
|
||||||
"integrity": "sha512-rGXbGmOEosIQi6Qva94HUjgPs9vKW+dkG7Y8Q5O2OYkWL6wFaTRZO8zM4mhP94uX55wgyrXzfS2aGtGzUL7EJQ==",
|
"integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"call-bind": "^1.0.2",
|
"call-bind": "^1.0.7",
|
||||||
"define-properties": "^1.2.0",
|
"define-properties": "^1.2.1",
|
||||||
"es-abstract": "^1.22.1",
|
"es-abstract": "^1.23.2",
|
||||||
"get-intrinsic": "^1.2.1",
|
"es-errors": "^1.3.0",
|
||||||
|
"es-object-atoms": "^1.0.0",
|
||||||
|
"get-intrinsic": "^1.2.4",
|
||||||
|
"gopd": "^1.0.1",
|
||||||
"has-symbols": "^1.0.3",
|
"has-symbols": "^1.0.3",
|
||||||
"internal-slot": "^1.0.5",
|
"internal-slot": "^1.0.7",
|
||||||
"regexp.prototype.flags": "^1.5.0",
|
"regexp.prototype.flags": "^1.5.2",
|
||||||
"set-function-name": "^2.0.0",
|
"set-function-name": "^2.0.2",
|
||||||
"side-channel": "^1.0.4"
|
"side-channel": "^1.0.6"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 0.4"
|
||||||
},
|
},
|
||||||
"funding": {
|
"funding": {
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
"url": "https://github.com/sponsors/ljharb"
|
||||||
@@ -6663,9 +6751,9 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/systeminformation": {
|
"node_modules/systeminformation": {
|
||||||
"version": "5.22.0",
|
"version": "5.22.7",
|
||||||
"resolved": "https://registry.npmjs.org/systeminformation/-/systeminformation-5.22.0.tgz",
|
"resolved": "https://registry.npmjs.org/systeminformation/-/systeminformation-5.22.7.tgz",
|
||||||
"integrity": "sha512-oAP80ymt8ssrAzjX8k3frbL7ys6AotqC35oikG6/SG15wBw+tG9nCk4oPaXIhEaAOAZ8XngxUv3ORq2IuR3r4Q==",
|
"integrity": "sha512-AWxlP05KeHbpGdgvZkcudJpsmChc2Y5Eo/GvxG/iUA/Aws5LZKHAMSeAo+V+nD+nxWZaxrwpWcnx4SH3oxNL3A==",
|
||||||
"os": [
|
"os": [
|
||||||
"darwin",
|
"darwin",
|
||||||
"linux",
|
"linux",
|
||||||
@@ -6789,6 +6877,15 @@
|
|||||||
"node": ">=14"
|
"node": ">=14"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"node_modules/tapable": {
|
||||||
|
"version": "2.2.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz",
|
||||||
|
"integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==",
|
||||||
|
"dev": true,
|
||||||
|
"engines": {
|
||||||
|
"node": ">=6"
|
||||||
|
}
|
||||||
|
},
|
||||||
"node_modules/tar": {
|
"node_modules/tar": {
|
||||||
"version": "6.2.0",
|
"version": "6.2.0",
|
||||||
"resolved": "https://registry.npmjs.org/tar/-/tar-6.2.0.tgz",
|
"resolved": "https://registry.npmjs.org/tar/-/tar-6.2.0.tgz",
|
||||||
@@ -7091,16 +7188,16 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/typescript": {
|
"node_modules/typescript": {
|
||||||
"version": "4.9.5",
|
"version": "5.4.5",
|
||||||
"resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz",
|
"resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz",
|
||||||
"integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==",
|
"integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==",
|
||||||
"dev": true,
|
"dev": true,
|
||||||
"bin": {
|
"bin": {
|
||||||
"tsc": "bin/tsc",
|
"tsc": "bin/tsc",
|
||||||
"tsserver": "bin/tsserver"
|
"tsserver": "bin/tsserver"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=4.2.0"
|
"node": ">=14.17"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/unbox-primitive": {
|
"node_modules/unbox-primitive": {
|
||||||
|
|||||||
14
package.json
14
package.json
@@ -29,14 +29,14 @@
|
|||||||
"ping": "^0.4.4",
|
"ping": "^0.4.4",
|
||||||
"pretty-bytes": "^6.1.1",
|
"pretty-bytes": "^6.1.1",
|
||||||
"raw-body": "^2.5.2",
|
"raw-body": "^2.5.2",
|
||||||
"react": "^18.2.0",
|
"react": "^18.3.1",
|
||||||
"react-dom": "^18.2.0",
|
"react-dom": "^18.2.0",
|
||||||
"react-i18next": "^11.18.6",
|
"react-i18next": "^11.18.6",
|
||||||
"react-icons": "^4.12.0",
|
"react-icons": "^4.12.0",
|
||||||
"recharts": "^2.12.3",
|
"recharts": "^2.12.6",
|
||||||
"rrule": "^2.8.1",
|
"rrule": "^2.8.1",
|
||||||
"swr": "^1.3.0",
|
"swr": "^1.3.0",
|
||||||
"systeminformation": "^5.22.0",
|
"systeminformation": "^5.22.7",
|
||||||
"tough-cookie": "^4.1.3",
|
"tough-cookie": "^4.1.3",
|
||||||
"urbackup-server-api": "^0.8.9",
|
"urbackup-server-api": "^0.8.9",
|
||||||
"winston": "^3.11.0",
|
"winston": "^3.11.0",
|
||||||
@@ -47,18 +47,18 @@
|
|||||||
"autoprefixer": "^10.4.17",
|
"autoprefixer": "^10.4.17",
|
||||||
"eslint": "^8.57.0",
|
"eslint": "^8.57.0",
|
||||||
"eslint-config-airbnb": "^19.0.4",
|
"eslint-config-airbnb": "^19.0.4",
|
||||||
"eslint-config-next": "^12.3.4",
|
"eslint-config-next": "^14.2.3",
|
||||||
"eslint-config-prettier": "^9.1.0",
|
"eslint-config-prettier": "^9.1.0",
|
||||||
"eslint-plugin-import": "^2.29.1",
|
"eslint-plugin-import": "^2.29.1",
|
||||||
"eslint-plugin-jsx-a11y": "^6.8.0",
|
"eslint-plugin-jsx-a11y": "^6.8.0",
|
||||||
"eslint-plugin-prettier": "^4.2.1",
|
"eslint-plugin-prettier": "^4.2.1",
|
||||||
"eslint-plugin-react": "^7.34.1",
|
"eslint-plugin-react": "^7.34.2",
|
||||||
"eslint-plugin-react-hooks": "^4.6.0",
|
"eslint-plugin-react-hooks": "^4.6.2",
|
||||||
"postcss": "^8.4.38",
|
"postcss": "^8.4.38",
|
||||||
"prettier": "^3.2.5",
|
"prettier": "^3.2.5",
|
||||||
"tailwind-scrollbar": "^3.0.5",
|
"tailwind-scrollbar": "^3.0.5",
|
||||||
"tailwindcss": "^3.4.3",
|
"tailwindcss": "^3.4.3",
|
||||||
"typescript": "^4.9.5"
|
"typescript": "^5.4.5"
|
||||||
},
|
},
|
||||||
"optionalDependencies": {
|
"optionalDependencies": {
|
||||||
"osx-temperature-sensor": "^1.0.8"
|
"osx-temperature-sensor": "^1.0.8"
|
||||||
|
|||||||
685
pnpm-lock.yaml
generated
685
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Waarskuwings",
|
"alerts": "Waarskuwings",
|
||||||
"bans": "Verbanne"
|
"bans": "Verbanne"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Gekoppel",
|
||||||
|
"enabled": "Geaktiveer",
|
||||||
|
"disabled": "Onaktief",
|
||||||
|
"total": "Totaal"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "تنبيهات",
|
"alerts": "تنبيهات",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "مفعل",
|
||||||
|
"disabled": "معطل",
|
||||||
|
"total": "المجموع"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Предупреждения",
|
"alerts": "Предупреждения",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Активирано",
|
||||||
|
"disabled": "Деактивирано",
|
||||||
|
"total": "Общо"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alertes",
|
"alerts": "Alertes",
|
||||||
"bans": "Prohibicions"
|
"bans": "Prohibicions"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connectat",
|
||||||
|
"enabled": "Activat",
|
||||||
|
"disabled": "Desactivat",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Upozornění",
|
"alerts": "Upozornění",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Povoleno",
|
||||||
|
"disabled": "Zakázáno",
|
||||||
|
"total": "Celkem"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Advarsler",
|
"alerts": "Advarsler",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Aktiveret",
|
||||||
|
"disabled": "Deaktiveret",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -142,8 +142,8 @@
|
|||||||
"connectionStatusDisconnected": "Getrennt",
|
"connectionStatusDisconnected": "Getrennt",
|
||||||
"connectionStatusConnected": "Verbunden",
|
"connectionStatusConnected": "Verbunden",
|
||||||
"uptime": "Betriebszeit",
|
"uptime": "Betriebszeit",
|
||||||
"maxDown": "Max. Empfang",
|
"maxDown": "Max. Down",
|
||||||
"maxUp": "Max. Senden",
|
"maxUp": "Max. Up",
|
||||||
"down": "Empfangen",
|
"down": "Empfangen",
|
||||||
"up": "Senden",
|
"up": "Senden",
|
||||||
"received": "Empfangen",
|
"received": "Empfangen",
|
||||||
@@ -392,7 +392,7 @@
|
|||||||
"authentik": {
|
"authentik": {
|
||||||
"users": "Benutzer",
|
"users": "Benutzer",
|
||||||
"loginsLast24H": "Anmeldungen (24 h)",
|
"loginsLast24H": "Anmeldungen (24 h)",
|
||||||
"failedLoginsLast24H": "Fehlgeschlagene Anmeldungen (24 h)"
|
"failedLoginsLast24H": "Fehlversuche (24 h)"
|
||||||
},
|
},
|
||||||
"proxmox": {
|
"proxmox": {
|
||||||
"mem": "RAM",
|
"mem": "RAM",
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Warnungen",
|
"alerts": "Warnungen",
|
||||||
"bans": "Banns"
|
"bans": "Banns"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Verbunden",
|
||||||
|
"enabled": "Aktiviert",
|
||||||
|
"disabled": "Deaktiviert",
|
||||||
|
"total": "Gesamt"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "Mit Auth",
|
||||||
|
"outdated": "Veraltet",
|
||||||
|
"banned": "Gebannt"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,14 +40,14 @@
|
|||||||
},
|
},
|
||||||
"resources": {
|
"resources": {
|
||||||
"cpu": "Επεξεργαστής",
|
"cpu": "Επεξεργαστής",
|
||||||
"mem": "MEM",
|
"mem": "Μνήμη",
|
||||||
"total": "Σύνολο",
|
"total": "Σύνολο",
|
||||||
"free": "Δωρεάν",
|
"free": "Δωρεάν",
|
||||||
"used": "χρησιμοποιημένο",
|
"used": "χρησιμοποιημένο",
|
||||||
"load": "Φόρτωση",
|
"load": "Φόρτωση",
|
||||||
"temp": "ΘΕΡΜΟΚΡΑΣΪΑ",
|
"temp": "Θερμοκρασία",
|
||||||
"max": "Μέγιστο",
|
"max": "Μέγιστο",
|
||||||
"uptime": "ΠΑΝΩ"
|
"uptime": "Χρόνος Λειτουργίας"
|
||||||
},
|
},
|
||||||
"unifi": {
|
"unifi": {
|
||||||
"users": "Χρήστες",
|
"users": "Χρήστες",
|
||||||
@@ -61,7 +61,7 @@
|
|||||||
"wlan_devices": "WLAN Συσκευές",
|
"wlan_devices": "WLAN Συσκευές",
|
||||||
"lan_users": "LAN Χρήστες",
|
"lan_users": "LAN Χρήστες",
|
||||||
"wlan_users": "WLAN Χρήστες",
|
"wlan_users": "WLAN Χρήστες",
|
||||||
"up": "ΠΑΝΩ",
|
"up": "Χρόνος Λειτουργίας",
|
||||||
"down": "ΚΑΤΩ",
|
"down": "ΚΑΤΩ",
|
||||||
"wait": "Παρακαλώ περιμένετε",
|
"wait": "Παρακαλώ περιμένετε",
|
||||||
"empty_data": "Άγνωστη κατάσταση υποσυστήματος"
|
"empty_data": "Άγνωστη κατάσταση υποσυστήματος"
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
"docker": {
|
"docker": {
|
||||||
"rx": "RX",
|
"rx": "RX",
|
||||||
"tx": "TX",
|
"tx": "TX",
|
||||||
"mem": "MEM",
|
"mem": "Μνήμη",
|
||||||
"cpu": "Επεξεργαστής",
|
"cpu": "Επεξεργαστής",
|
||||||
"running": "Τρέχων",
|
"running": "Τρέχων",
|
||||||
"offline": "Εκτός σύνδεσης",
|
"offline": "Εκτός σύνδεσης",
|
||||||
@@ -85,16 +85,16 @@
|
|||||||
"ping": {
|
"ping": {
|
||||||
"error": "Σφάλμα",
|
"error": "Σφάλμα",
|
||||||
"ping": "Ping",
|
"ping": "Ping",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"not_available": "Μη διαθέσιμο"
|
"not_available": "Μη διαθέσιμο"
|
||||||
},
|
},
|
||||||
"siteMonitor": {
|
"siteMonitor": {
|
||||||
"http_status": "Κατάσταση HTTP",
|
"http_status": "Κατάσταση HTTP",
|
||||||
"error": "Σφάλμα",
|
"error": "Σφάλμα",
|
||||||
"response": "Απόκριση",
|
"response": "Απόκριση",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"not_available": "Μη διαθέσιμο"
|
"not_available": "Μη διαθέσιμο"
|
||||||
},
|
},
|
||||||
"emby": {
|
"emby": {
|
||||||
@@ -136,19 +136,19 @@
|
|||||||
"connectionStatus": "Κατάσταση",
|
"connectionStatus": "Κατάσταση",
|
||||||
"connectionStatusUnconfigured": "Μη Ρυθμισμένο",
|
"connectionStatusUnconfigured": "Μη Ρυθμισμένο",
|
||||||
"connectionStatusConnecting": "Κατάσταση Σύνδεσης",
|
"connectionStatusConnecting": "Κατάσταση Σύνδεσης",
|
||||||
"connectionStatusAuthenticating": "Authenticating",
|
"connectionStatusAuthenticating": "Ταυτοποίηση",
|
||||||
"connectionStatusPendingDisconnect": "Pending Disconnect",
|
"connectionStatusPendingDisconnect": "Εκκρεμεί Αποσύνδεση",
|
||||||
"connectionStatusDisconnecting": "Disconnecting",
|
"connectionStatusDisconnecting": "Αποσύνδεση",
|
||||||
"connectionStatusDisconnected": "Disconnected",
|
"connectionStatusDisconnected": "Αποσυνδέθηκε",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Συνδέθηκε",
|
||||||
"uptime": "Χρόνος Λειτουργίας",
|
"uptime": "Χρόνος Λειτουργίας",
|
||||||
"maxDown": "Max. Down",
|
"maxDown": "Μέγιστο Download",
|
||||||
"maxUp": "Max. Up",
|
"maxUp": "Μέγιστο Upload",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"received": "Received",
|
"received": "Ληφθέντα",
|
||||||
"sent": "Sent",
|
"sent": "Απεσταλμένα",
|
||||||
"externalIPAddress": "Ext. IP"
|
"externalIPAddress": "Εξωτερική IP"
|
||||||
},
|
},
|
||||||
"caddy": {
|
"caddy": {
|
||||||
"upstreams": "Upstreams",
|
"upstreams": "Upstreams",
|
||||||
@@ -217,7 +217,7 @@
|
|||||||
"memUsage": "Χρήση μνήμης",
|
"memUsage": "Χρήση μνήμης",
|
||||||
"systemTempC": "Θερμοκρασία συστήματος",
|
"systemTempC": "Θερμοκρασία συστήματος",
|
||||||
"poolUsage": "Χρήση πισίνας",
|
"poolUsage": "Χρήση πισίνας",
|
||||||
"volumeUsage": "Volume Usage",
|
"volumeUsage": "Χρήση Όγκου",
|
||||||
"invalid": "Μη έγκυρο"
|
"invalid": "Μη έγκυρο"
|
||||||
},
|
},
|
||||||
"deluge": {
|
"deluge": {
|
||||||
@@ -273,15 +273,15 @@
|
|||||||
},
|
},
|
||||||
"overseerr": {
|
"overseerr": {
|
||||||
"pending": "Σε εκκρεμότητα",
|
"pending": "Σε εκκρεμότητα",
|
||||||
"processing": "Processing",
|
"processing": "Σε επεξεργασία",
|
||||||
"approved": "Εγκρίθηκε",
|
"approved": "Εγκρίθηκε",
|
||||||
"available": "Διαθέσιμο"
|
"available": "Διαθέσιμο"
|
||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Σύνολο",
|
"total": "Σύνολο",
|
||||||
"connected": "Connected",
|
"connected": "Συνδέθηκε",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Νέες συσκευές",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Ειδοποιήσεις offline"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Queries",
|
"queries": "Queries",
|
||||||
@@ -309,26 +309,26 @@
|
|||||||
"address": "Διεύθυνση",
|
"address": "Διεύθυνση",
|
||||||
"expires": "Λήγει",
|
"expires": "Λήγει",
|
||||||
"never": "Ποτέ",
|
"never": "Ποτέ",
|
||||||
"last_seen": "Last Seen",
|
"last_seen": "Τελευταία Σύνδεση",
|
||||||
"now": "Τώρα",
|
"now": "Τώρα",
|
||||||
"years": "{{number}}y",
|
"years": "{{number}}χρόνια",
|
||||||
"weeks": "{{number}}w",
|
"weeks": "{{number}}εβδομάδες",
|
||||||
"days": "{{number}}d",
|
"days": "{{number}}μέρες",
|
||||||
"hours": "{{number}}h",
|
"hours": "{{number}}ώρες",
|
||||||
"minutes": "{{number}}m",
|
"minutes": "{{number}}λεπτά",
|
||||||
"seconds": "{{number}}s",
|
"seconds": "{{number}}δευτερόλεπτα",
|
||||||
"ago": "{{value}} πρίν"
|
"ago": "{{value}} πρίν"
|
||||||
},
|
},
|
||||||
"tdarr": {
|
"tdarr": {
|
||||||
"queue": "Ουρά",
|
"queue": "Ουρά",
|
||||||
"processed": "Processed",
|
"processed": "Σε επεξεργασία",
|
||||||
"errored": "Errored",
|
"errored": "Σφάλματα",
|
||||||
"saved": "Saved"
|
"saved": "Αποθηκεύτηκε"
|
||||||
},
|
},
|
||||||
"traefik": {
|
"traefik": {
|
||||||
"routers": "Routers",
|
"routers": "Δρομολογητές",
|
||||||
"services": "Services",
|
"services": "Υπηρεσίες",
|
||||||
"middleware": "Middleware"
|
"middleware": "Ενδιάμεσο λογισμικό"
|
||||||
},
|
},
|
||||||
"navidrome": {
|
"navidrome": {
|
||||||
"nothing_streaming": "Δεν υπάρχουν ενεργές ροές",
|
"nothing_streaming": "Δεν υπάρχουν ενεργές ροές",
|
||||||
@@ -360,7 +360,7 @@
|
|||||||
},
|
},
|
||||||
"jackett": {
|
"jackett": {
|
||||||
"configured": "Ρυθμισμένο",
|
"configured": "Ρυθμισμένο",
|
||||||
"errored": "Errored"
|
"errored": "Σφάλματα"
|
||||||
},
|
},
|
||||||
"strelaysrv": {
|
"strelaysrv": {
|
||||||
"numActiveSessions": "Συνεδρίες",
|
"numActiveSessions": "Συνεδρίες",
|
||||||
@@ -371,7 +371,7 @@
|
|||||||
"mastodon": {
|
"mastodon": {
|
||||||
"user_count": "Χρήστες",
|
"user_count": "Χρήστες",
|
||||||
"status_count": "Δημοσιεύσεις",
|
"status_count": "Δημοσιεύσεις",
|
||||||
"domain_count": "Domains"
|
"domain_count": "Τομείς"
|
||||||
},
|
},
|
||||||
"medusa": {
|
"medusa": {
|
||||||
"wanted": "Επιθυμούντε",
|
"wanted": "Επιθυμούντε",
|
||||||
@@ -386,7 +386,7 @@
|
|||||||
"down": "Εκτός σύνδεσης"
|
"down": "Εκτός σύνδεσης"
|
||||||
},
|
},
|
||||||
"miniflux": {
|
"miniflux": {
|
||||||
"read": "Read",
|
"read": "Διαβάστηκε",
|
||||||
"unread": "Μη Διαβασμένο"
|
"unread": "Μη Διαβασμένο"
|
||||||
},
|
},
|
||||||
"authentik": {
|
"authentik": {
|
||||||
@@ -395,7 +395,7 @@
|
|||||||
"failedLoginsLast24H": "Αποτυχημένες Συνδέσεις (24h)"
|
"failedLoginsLast24H": "Αποτυχημένες Συνδέσεις (24h)"
|
||||||
},
|
},
|
||||||
"proxmox": {
|
"proxmox": {
|
||||||
"mem": "MEM",
|
"mem": "Μνήμη",
|
||||||
"cpu": "Επεξεργαστής",
|
"cpu": "Επεξεργαστής",
|
||||||
"lxc": "LXC",
|
"lxc": "LXC",
|
||||||
"vms": "VMs"
|
"vms": "VMs"
|
||||||
@@ -404,17 +404,17 @@
|
|||||||
"cpu": "Επεξεργαστής",
|
"cpu": "Επεξεργαστής",
|
||||||
"load": "Φόρτωση",
|
"load": "Φόρτωση",
|
||||||
"wait": "Παρακαλώ περιμένετε",
|
"wait": "Παρακαλώ περιμένετε",
|
||||||
"temp": "ΘΕΡΜΟΚΡΑΣΪΑ",
|
"temp": "Θερμοκρασία",
|
||||||
"_temp": "Temp",
|
"_temp": "Temp",
|
||||||
"warn": "Warn",
|
"warn": "Warn",
|
||||||
"uptime": "ΠΑΝΩ",
|
"uptime": "Χρόνος Λειτουργίας",
|
||||||
"total": "Σύνολο",
|
"total": "Σύνολο",
|
||||||
"free": "Δωρεάν",
|
"free": "Δωρεάν",
|
||||||
"used": "χρησιμοποιημένο",
|
"used": "χρησιμοποιημένο",
|
||||||
"days": "d",
|
"days": "d",
|
||||||
"hours": "h",
|
"hours": "h",
|
||||||
"crit": "Crit",
|
"crit": "Crit",
|
||||||
"read": "Read",
|
"read": "Διαβάστηκε",
|
||||||
"write": "Write",
|
"write": "Write",
|
||||||
"gpu": "GPU",
|
"gpu": "GPU",
|
||||||
"mem": "Μνήμη",
|
"mem": "Μνήμη",
|
||||||
@@ -450,80 +450,80 @@
|
|||||||
"55-night": "Heavy Drizzle",
|
"55-night": "Heavy Drizzle",
|
||||||
"56-day": "Light Freezing Drizzle",
|
"56-day": "Light Freezing Drizzle",
|
||||||
"56-night": "Light Freezing Drizzle",
|
"56-night": "Light Freezing Drizzle",
|
||||||
"57-day": "Freezing Drizzle",
|
"57-day": "Παγωμένο ψιχάλισμα",
|
||||||
"57-night": "Freezing Drizzle",
|
"57-night": "Παγωμένο ψιχάλισμα",
|
||||||
"61-day": "Light Rain",
|
"61-day": "Ψιλόβροχο",
|
||||||
"61-night": "Light Rain",
|
"61-night": "Ψιλόβροχο",
|
||||||
"63-day": "Rain",
|
"63-day": "Βροχή",
|
||||||
"63-night": "Rain",
|
"63-night": "Βροχή",
|
||||||
"65-day": "Heavy Rain",
|
"65-day": "Δυνατή βροχή",
|
||||||
"65-night": "Heavy Rain",
|
"65-night": "Δυνατή βροχή",
|
||||||
"66-day": "Freezing Rain",
|
"66-day": "Παγωμένη βροχή",
|
||||||
"66-night": "Freezing Rain",
|
"66-night": "Παγωμένη βροχή",
|
||||||
"67-day": "Freezing Rain",
|
"67-day": "Παγωμένη βροχή",
|
||||||
"67-night": "Freezing Rain",
|
"67-night": "Παγωμένη βροχή",
|
||||||
"71-day": "Light Snow",
|
"71-day": "Ελαφριά Χιονόπτωση",
|
||||||
"71-night": "Light Snow",
|
"71-night": "Ελαφριά Χιονόπτωση",
|
||||||
"73-day": "Snow",
|
"73-day": "Χιόνι",
|
||||||
"73-night": "Snow",
|
"73-night": "Χιόνι",
|
||||||
"75-day": "Heavy Snow",
|
"75-day": "Ισχυρή χιονόπτωση",
|
||||||
"75-night": "Heavy Snow",
|
"75-night": "Ισχυρή χιονόπτωση",
|
||||||
"77-day": "Snow Grains",
|
"77-day": "Κόκκοι Χιονιού",
|
||||||
"77-night": "Snow Grains",
|
"77-night": "Κόκκοι Χιονιού",
|
||||||
"80-day": "Light Showers",
|
"80-day": "Ασθενείς βροχές",
|
||||||
"80-night": "Light Showers",
|
"80-night": "Ασθενείς βροχές",
|
||||||
"81-day": "Showers",
|
"81-day": "Βροχοπτώσεις",
|
||||||
"81-night": "Showers",
|
"81-night": "Βροχοπτώσεις",
|
||||||
"82-day": "Heavy Showers",
|
"82-day": "Ισχυρές βροχοπτώσεις",
|
||||||
"82-night": "Heavy Showers",
|
"82-night": "Ισχυρές βροχοπτώσεις",
|
||||||
"85-day": "Snow Showers",
|
"85-day": "Χιονοπτώσεις",
|
||||||
"85-night": "Snow Showers",
|
"85-night": "Χιονοπτώσεις",
|
||||||
"86-day": "Snow Showers",
|
"86-day": "Χιονοπτώσεις",
|
||||||
"86-night": "Snow Showers",
|
"86-night": "Χιονοπτώσεις",
|
||||||
"95-day": "Thunderstorm",
|
"95-day": "Καταιγίδα",
|
||||||
"95-night": "Thunderstorm",
|
"95-night": "Καταιγίδα",
|
||||||
"96-day": "Thunderstorm With Hail",
|
"96-day": "Καταιγίδα Με Χαλάζι",
|
||||||
"96-night": "Thunderstorm With Hail",
|
"96-night": "Καταιγίδα Με Χαλάζι",
|
||||||
"99-day": "Thunderstorm With Hail",
|
"99-day": "Καταιγίδα Με Χαλάζι",
|
||||||
"99-night": "Thunderstorm With Hail"
|
"99-night": "Καταιγίδα Με Χαλάζι"
|
||||||
},
|
},
|
||||||
"homebridge": {
|
"homebridge": {
|
||||||
"available_update": "System",
|
"available_update": "Σύστημα",
|
||||||
"updates": "Updates",
|
"updates": "Ενημερώσεις",
|
||||||
"update_available": "Update Available",
|
"update_available": "Διαθέσιμη ενημέρωση",
|
||||||
"up_to_date": "Up to Date",
|
"up_to_date": "Ενημερωμένο",
|
||||||
"child_bridges": "Child Bridges",
|
"child_bridges": "Child Bridges",
|
||||||
"child_bridges_status": "{{ok}}/{{total}}",
|
"child_bridges_status": "{{ok}}/{{total}}",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"pending": "Σε εκκρεμότητα",
|
"pending": "Σε εκκρεμότητα",
|
||||||
"down": "Down"
|
"down": "Ping down"
|
||||||
},
|
},
|
||||||
"healthchecks": {
|
"healthchecks": {
|
||||||
"new": "New",
|
"new": "New",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"grace": "In Grace Period",
|
"grace": "In Grace Period",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"paused": "Paused",
|
"paused": "Paused",
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"last_ping": "Last Ping",
|
"last_ping": "Τελευταίο Ping",
|
||||||
"never": "No pings yet"
|
"never": "Δεν υπάρχουν ping ακόμα"
|
||||||
},
|
},
|
||||||
"watchtower": {
|
"watchtower": {
|
||||||
"containers_scanned": "Scanned",
|
"containers_scanned": "Σκαναρισμένο",
|
||||||
"containers_updated": "Updated",
|
"containers_updated": "Ενημερώθηκε",
|
||||||
"containers_failed": "Failed"
|
"containers_failed": "Απέτυχε"
|
||||||
},
|
},
|
||||||
"autobrr": {
|
"autobrr": {
|
||||||
"approvedPushes": "Εγκρίθηκε",
|
"approvedPushes": "Εγκρίθηκε",
|
||||||
"rejectedPushes": "Rejected",
|
"rejectedPushes": "Απορρίφθηκε",
|
||||||
"filters": "Filters",
|
"filters": "Φίλτρα",
|
||||||
"indexers": "Ευρετήρια"
|
"indexers": "Ευρετήρια"
|
||||||
},
|
},
|
||||||
"tubearchivist": {
|
"tubearchivist": {
|
||||||
"downloads": "Ουρά",
|
"downloads": "Ουρά",
|
||||||
"videos": "Videos",
|
"videos": "Βίντεο",
|
||||||
"channels": "Channels",
|
"channels": "Κανάλια",
|
||||||
"playlists": "Playlists"
|
"playlists": "Λίστες αναπαραγωγής"
|
||||||
},
|
},
|
||||||
"truenas": {
|
"truenas": {
|
||||||
"load": "Φόρτος Συστήματος",
|
"load": "Φόρτος Συστήματος",
|
||||||
@@ -542,24 +542,24 @@
|
|||||||
"country": "Χώρα"
|
"country": "Χώρα"
|
||||||
},
|
},
|
||||||
"hdhomerun": {
|
"hdhomerun": {
|
||||||
"channels": "Channels",
|
"channels": "Κανάλια",
|
||||||
"hd": "HD",
|
"hd": "HD",
|
||||||
"tunerCount": "Tuners",
|
"tunerCount": "Δέκτες",
|
||||||
"channelNumber": "Channel",
|
"channelNumber": "Κανάλι",
|
||||||
"channelNetwork": "Network",
|
"channelNetwork": "Δίκτυο",
|
||||||
"signalStrength": "Strength",
|
"signalStrength": "Ισχύς σήματος",
|
||||||
"signalQuality": "Quality",
|
"signalQuality": "Ποιότητα",
|
||||||
"symbolQuality": "Quality",
|
"symbolQuality": "Ποιότητα",
|
||||||
"networkRate": "Ρυθμός bit",
|
"networkRate": "Ρυθμός bit",
|
||||||
"clientIP": "Client"
|
"clientIP": "Πελάτης"
|
||||||
},
|
},
|
||||||
"scrutiny": {
|
"scrutiny": {
|
||||||
"passed": "Passed",
|
"passed": "Passed",
|
||||||
"failed": "Failed",
|
"failed": "Απέτυχε",
|
||||||
"unknown": "Άγνωστο"
|
"unknown": "Άγνωστο"
|
||||||
},
|
},
|
||||||
"paperlessngx": {
|
"paperlessngx": {
|
||||||
"inbox": "Inbox",
|
"inbox": "Εισερχόμενα",
|
||||||
"total": "Σύνολο"
|
"total": "Σύνολο"
|
||||||
},
|
},
|
||||||
"peanut": {
|
"peanut": {
|
||||||
@@ -567,8 +567,8 @@
|
|||||||
"ups_load": "UPS Load",
|
"ups_load": "UPS Load",
|
||||||
"ups_status": "UPS Status",
|
"ups_status": "UPS Status",
|
||||||
"online": "Συνδεδεμένοι",
|
"online": "Συνδεδεμένοι",
|
||||||
"on_battery": "On Battery",
|
"on_battery": "Σε μπαταρία",
|
||||||
"low_battery": "Low Battery"
|
"low_battery": "Χαμηλή μπαταρία"
|
||||||
},
|
},
|
||||||
"nextdns": {
|
"nextdns": {
|
||||||
"wait": "Παρακαλώ περιμένετε",
|
"wait": "Παρακαλώ περιμένετε",
|
||||||
@@ -617,10 +617,10 @@
|
|||||||
"load": "Load Avg",
|
"load": "Load Avg",
|
||||||
"memory": "Mem Usage",
|
"memory": "Mem Usage",
|
||||||
"wanStatus": "WAN Status",
|
"wanStatus": "WAN Status",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"temp": "Temp",
|
"temp": "Temp",
|
||||||
"disk": "Disk Usage",
|
"disk": "Χρήση δίσκου",
|
||||||
"wanIP": "WAN IP"
|
"wanIP": "WAN IP"
|
||||||
},
|
},
|
||||||
"proxmoxbackupserver": {
|
"proxmoxbackupserver": {
|
||||||
@@ -631,22 +631,22 @@
|
|||||||
},
|
},
|
||||||
"immich": {
|
"immich": {
|
||||||
"users": "Χρήστες",
|
"users": "Χρήστες",
|
||||||
"photos": "Photos",
|
"photos": "Φωτογραφίες",
|
||||||
"videos": "Videos",
|
"videos": "Βίντεο",
|
||||||
"storage": "Storage"
|
"storage": "Αποθηκευτικός χώρος"
|
||||||
},
|
},
|
||||||
"uptimekuma": {
|
"uptimekuma": {
|
||||||
"up": "Sites Up",
|
"up": "Online τοποθεσίες",
|
||||||
"down": "Sites Down",
|
"down": "Offline τοποθεσίες",
|
||||||
"uptime": "Χρόνος Λειτουργίας",
|
"uptime": "Χρόνος Λειτουργίας",
|
||||||
"incident": "Incident",
|
"incident": "Περιστατικό",
|
||||||
"m": "m"
|
"m": "m"
|
||||||
},
|
},
|
||||||
"atsumeru": {
|
"atsumeru": {
|
||||||
"series": "Σειρές",
|
"series": "Σειρές",
|
||||||
"archives": "Archives",
|
"archives": "Archives",
|
||||||
"chapters": "Chapters",
|
"chapters": "Chapters",
|
||||||
"categories": "Categories"
|
"categories": "Κατηγορίες"
|
||||||
},
|
},
|
||||||
"komga": {
|
"komga": {
|
||||||
"libraries": "Libraries",
|
"libraries": "Libraries",
|
||||||
@@ -665,101 +665,101 @@
|
|||||||
},
|
},
|
||||||
"photoprism": {
|
"photoprism": {
|
||||||
"albums": "Άλμπουμ",
|
"albums": "Άλμπουμ",
|
||||||
"photos": "Photos",
|
"photos": "Φωτογραφίες",
|
||||||
"videos": "Videos",
|
"videos": "Βίντεο",
|
||||||
"people": "People"
|
"people": "Άνθρωποι"
|
||||||
},
|
},
|
||||||
"fileflows": {
|
"fileflows": {
|
||||||
"queue": "Ουρά",
|
"queue": "Ουρά",
|
||||||
"processing": "Processing",
|
"processing": "Σε επεξεργασία",
|
||||||
"processed": "Processed",
|
"processed": "Σε επεξεργασία",
|
||||||
"time": "Time"
|
"time": "Ώρα"
|
||||||
},
|
},
|
||||||
"grafana": {
|
"grafana": {
|
||||||
"dashboards": "Dashboards",
|
"dashboards": "Πίνακας Ελέγχου",
|
||||||
"datasources": "Data Sources",
|
"datasources": "Πηγές Δεδομένων",
|
||||||
"totalalerts": "Total Alerts",
|
"totalalerts": "Σύνολο Ειδοποιήσεων",
|
||||||
"alertstriggered": "Alerts Triggered"
|
"alertstriggered": "Ενεργοποιημένες Ειδοποιήσεις"
|
||||||
},
|
},
|
||||||
"nextcloud": {
|
"nextcloud": {
|
||||||
"cpuload": "Cpu Load",
|
"cpuload": "Φόρτος CPU",
|
||||||
"memoryusage": "Memory Usage",
|
"memoryusage": "Χρήση Mνήμης",
|
||||||
"freespace": "Free Space",
|
"freespace": "Ελεύθερος χώρος",
|
||||||
"activeusers": "Active Users",
|
"activeusers": "Ενεργοί χρήστες",
|
||||||
"numfiles": "Files",
|
"numfiles": "Αρχεία",
|
||||||
"numshares": "Shared Items"
|
"numshares": "Κοινόχρηστα στοιχεία"
|
||||||
},
|
},
|
||||||
"kopia": {
|
"kopia": {
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"size": "Size",
|
"size": "Μέγεθος",
|
||||||
"lastrun": "Last Run",
|
"lastrun": "Τελευταία εκτέλεση",
|
||||||
"nextrun": "Next Run",
|
"nextrun": "Επόμενη εκτέλεση",
|
||||||
"failed": "Failed"
|
"failed": "Απέτυχε"
|
||||||
},
|
},
|
||||||
"unmanic": {
|
"unmanic": {
|
||||||
"active_workers": "Active Workers",
|
"active_workers": "Ενεργοί χρήστες",
|
||||||
"total_workers": "Total Workers",
|
"total_workers": "Total Workers",
|
||||||
"records_total": "Queue Length"
|
"records_total": "Μήκος Ουράς"
|
||||||
},
|
},
|
||||||
"pterodactyl": {
|
"pterodactyl": {
|
||||||
"servers": "Διακομιστές",
|
"servers": "Διακομιστές",
|
||||||
"nodes": "Nodes"
|
"nodes": "Κόμβοι [Nodes]"
|
||||||
},
|
},
|
||||||
"prometheus": {
|
"prometheus": {
|
||||||
"targets_up": "Targets Up",
|
"targets_up": "Στόχοι Πάνω",
|
||||||
"targets_down": "Targets Down",
|
"targets_down": "Στόχοι Κάτω",
|
||||||
"targets_total": "Total Targets"
|
"targets_total": "Συνολικοί Στόχοι"
|
||||||
},
|
},
|
||||||
"gatus": {
|
"gatus": {
|
||||||
"up": "Sites Up",
|
"up": "Online τοποθεσίες",
|
||||||
"down": "Sites Down",
|
"down": "Offline τοποθεσίες",
|
||||||
"uptime": "Χρόνος Λειτουργίας"
|
"uptime": "Χρόνος Λειτουργίας"
|
||||||
},
|
},
|
||||||
"ghostfolio": {
|
"ghostfolio": {
|
||||||
"gross_percent_today": "Σήμερα",
|
"gross_percent_today": "Σήμερα",
|
||||||
"gross_percent_1y": "One year",
|
"gross_percent_1y": "Ένας χρόνος",
|
||||||
"gross_percent_max": "All time"
|
"gross_percent_max": "Διαχρονικά"
|
||||||
},
|
},
|
||||||
"audiobookshelf": {
|
"audiobookshelf": {
|
||||||
"podcasts": "Podcasts",
|
"podcasts": "Podcasts",
|
||||||
"books": "Βιβλία",
|
"books": "Βιβλία",
|
||||||
"podcastsDuration": "Duration",
|
"podcastsDuration": "Διάρκεια",
|
||||||
"booksDuration": "Duration"
|
"booksDuration": "Διάρκεια"
|
||||||
},
|
},
|
||||||
"homeassistant": {
|
"homeassistant": {
|
||||||
"people_home": "People Home",
|
"people_home": "Σύνολο ανθρώπων στο σπίτι",
|
||||||
"lights_on": "Lights On",
|
"lights_on": "Αναμμένα φώτα",
|
||||||
"switches_on": "Switches On"
|
"switches_on": "Ανοιχτοί διακόπτες"
|
||||||
},
|
},
|
||||||
"whatsupdocker": {
|
"whatsupdocker": {
|
||||||
"monitoring": "Monitoring",
|
"monitoring": "Παρακολούθηση",
|
||||||
"updates": "Updates"
|
"updates": "Ενημερώσεις"
|
||||||
},
|
},
|
||||||
"calibreweb": {
|
"calibreweb": {
|
||||||
"books": "Βιβλία",
|
"books": "Βιβλία",
|
||||||
"authors": "Authors",
|
"authors": "Συντάκτες",
|
||||||
"categories": "Categories",
|
"categories": "Κατηγορίες",
|
||||||
"series": "Σειρές"
|
"series": "Σειρές"
|
||||||
},
|
},
|
||||||
"jdownloader": {
|
"jdownloader": {
|
||||||
"downloadCount": "Ουρά",
|
"downloadCount": "Ουρά",
|
||||||
"downloadBytesRemaining": "Υπόλοιπο",
|
"downloadBytesRemaining": "Υπόλοιπο",
|
||||||
"downloadTotalBytes": "Size",
|
"downloadTotalBytes": "Μέγεθος",
|
||||||
"downloadSpeed": "Ταχύτητα"
|
"downloadSpeed": "Ταχύτητα"
|
||||||
},
|
},
|
||||||
"kavita": {
|
"kavita": {
|
||||||
"seriesCount": "Σειρές",
|
"seriesCount": "Σειρές",
|
||||||
"totalFiles": "Files"
|
"totalFiles": "Αρχεία"
|
||||||
},
|
},
|
||||||
"azuredevops": {
|
"azuredevops": {
|
||||||
"result": "Result",
|
"result": "Αποτέλεσμα",
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"buildId": "Build ID",
|
"buildId": "Build ID",
|
||||||
"succeeded": "Succeeded",
|
"succeeded": "Πέτυχε",
|
||||||
"notStarted": "Not Started",
|
"notStarted": "Δεν ξεκίνησε",
|
||||||
"failed": "Failed",
|
"failed": "Απέτυχε",
|
||||||
"canceled": "Canceled",
|
"canceled": "Ακυρώθηκε",
|
||||||
"inProgress": "In Progress",
|
"inProgress": "Σε εξέλιξη",
|
||||||
"totalPrs": "Total PRs",
|
"totalPrs": "Total PRs",
|
||||||
"myPrs": "My PRs",
|
"myPrs": "My PRs",
|
||||||
"approved": "Εγκρίθηκε"
|
"approved": "Εγκρίθηκε"
|
||||||
@@ -768,8 +768,8 @@
|
|||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"online": "Συνδεδεμένοι",
|
"online": "Συνδεδεμένοι",
|
||||||
"offline": "Εκτός σύνδεσης",
|
"offline": "Εκτός σύνδεσης",
|
||||||
"name": "Name",
|
"name": "Όνομα",
|
||||||
"map": "Map",
|
"map": "Χάρτης",
|
||||||
"currentPlayers": "Current players",
|
"currentPlayers": "Current players",
|
||||||
"players": "Παίκτες",
|
"players": "Παίκτες",
|
||||||
"maxPlayers": "Max players",
|
"maxPlayers": "Max players",
|
||||||
@@ -777,45 +777,45 @@
|
|||||||
"ping": "Ping"
|
"ping": "Ping"
|
||||||
},
|
},
|
||||||
"urbackup": {
|
"urbackup": {
|
||||||
"ok": "Ok",
|
"ok": "Οκ",
|
||||||
"errored": "Errors",
|
"errored": "Σφάλματα",
|
||||||
"noRecent": "Out of Date",
|
"noRecent": "Απαρχαιωμένη έκδοση",
|
||||||
"totalUsed": "Used Storage"
|
"totalUsed": "Χώρος αποθήκευσης σε χρήση"
|
||||||
},
|
},
|
||||||
"mealie": {
|
"mealie": {
|
||||||
"recipes": "Recipes",
|
"recipes": "Συνταγές",
|
||||||
"users": "Χρήστες",
|
"users": "Χρήστες",
|
||||||
"categories": "Categories",
|
"categories": "Κατηγορίες",
|
||||||
"tags": "Tags"
|
"tags": "Ετικέτες"
|
||||||
},
|
},
|
||||||
"openmediavault": {
|
"openmediavault": {
|
||||||
"downloading": "Downloading",
|
"downloading": "Γίνεται λήψη",
|
||||||
"total": "Σύνολο",
|
"total": "Σύνολο",
|
||||||
"running": "Τρέχων",
|
"running": "Τρέχων",
|
||||||
"stopped": "Σταματημένο",
|
"stopped": "Σταματημένο",
|
||||||
"passed": "Passed",
|
"passed": "Passed",
|
||||||
"failed": "Failed"
|
"failed": "Απέτυχε"
|
||||||
},
|
},
|
||||||
"openwrt": {
|
"openwrt": {
|
||||||
"uptime": "Χρόνος Λειτουργίας",
|
"uptime": "Χρόνος Λειτουργίας",
|
||||||
"cpuLoad": "CPU Load Avg (5m)",
|
"cpuLoad": "CPU Load Avg (5m)",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"bytesTx": "Transmitted",
|
"bytesTx": "Transmitted",
|
||||||
"bytesRx": "Received"
|
"bytesRx": "Ληφθέντα"
|
||||||
},
|
},
|
||||||
"uptimerobot": {
|
"uptimerobot": {
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"uptime": "Χρόνος Λειτουργίας",
|
"uptime": "Χρόνος Λειτουργίας",
|
||||||
"lastDown": "Last Downtime",
|
"lastDown": "Last Downtime",
|
||||||
"downDuration": "Downtime Duration",
|
"downDuration": "Downtime Duration",
|
||||||
"sitesUp": "Sites Up",
|
"sitesUp": "Online τοποθεσίες",
|
||||||
"sitesDown": "Sites Down",
|
"sitesDown": "Offline τοποθεσίες",
|
||||||
"paused": "Paused",
|
"paused": "Paused",
|
||||||
"notyetchecked": "Not Yet Checked",
|
"notyetchecked": "Not Yet Checked",
|
||||||
"up": "Up",
|
"up": "Ping up",
|
||||||
"seemsdown": "Seems Down",
|
"seemsdown": "Seems Down",
|
||||||
"down": "Down",
|
"down": "Ping down",
|
||||||
"unknown": "Άγνωστο"
|
"unknown": "Άγνωστο"
|
||||||
},
|
},
|
||||||
"calendar": {
|
"calendar": {
|
||||||
@@ -836,7 +836,7 @@
|
|||||||
"plantit": {
|
"plantit": {
|
||||||
"events": "Events",
|
"events": "Events",
|
||||||
"plants": "Plants",
|
"plants": "Plants",
|
||||||
"photos": "Photos",
|
"photos": "Φωτογραφίες",
|
||||||
"species": "Species"
|
"species": "Species"
|
||||||
},
|
},
|
||||||
"gitea": {
|
"gitea": {
|
||||||
@@ -857,12 +857,12 @@
|
|||||||
"performers": "Performers",
|
"performers": "Performers",
|
||||||
"studios": "Studios",
|
"studios": "Studios",
|
||||||
"movies": "Ταινίες",
|
"movies": "Ταινίες",
|
||||||
"tags": "Tags",
|
"tags": "Ετικέτες",
|
||||||
"oCount": "O Count"
|
"oCount": "O Count"
|
||||||
},
|
},
|
||||||
"tandoor": {
|
"tandoor": {
|
||||||
"users": "Χρήστες",
|
"users": "Χρήστες",
|
||||||
"recipes": "Recipes",
|
"recipes": "Συνταγές",
|
||||||
"keywords": "Keywords"
|
"keywords": "Keywords"
|
||||||
},
|
},
|
||||||
"homebox": {
|
"homebox": {
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Ειδοποιήσεις",
|
"alerts": "Ειδοποιήσεις",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Συνδέθηκε",
|
||||||
|
"enabled": "Ενεργοποιημένο",
|
||||||
|
"disabled": "Απενεργοποιημένο",
|
||||||
|
"total": "Σύνολο"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Totalo"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alertas",
|
"alerts": "Alertas",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Activado",
|
||||||
|
"disabled": "Desactivado",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Guztira"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Käytössä",
|
||||||
|
"disabled": "Poissa käytöstä",
|
||||||
|
"total": "Yhteensä"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,13 +15,13 @@
|
|||||||
"relativeDate": "{{value, relativeDate}}",
|
"relativeDate": "{{value, relativeDate}}",
|
||||||
"uptime": "{{value, uptime}}",
|
"uptime": "{{value, uptime}}",
|
||||||
"months": "mo",
|
"months": "mo",
|
||||||
"days": "d",
|
"days": "j",
|
||||||
"hours": "h",
|
"hours": "h",
|
||||||
"minutes": "m",
|
"minutes": "m",
|
||||||
"seconds": "s"
|
"seconds": "s"
|
||||||
},
|
},
|
||||||
"widget": {
|
"widget": {
|
||||||
"missing_type": "Widget manquant: {{type}}",
|
"missing_type": "Type de widget manquant: {{type}}",
|
||||||
"api_error": "Erreur API",
|
"api_error": "Erreur API",
|
||||||
"information": "Informations",
|
"information": "Informations",
|
||||||
"status": "Statut",
|
"status": "Statut",
|
||||||
@@ -40,7 +40,7 @@
|
|||||||
},
|
},
|
||||||
"resources": {
|
"resources": {
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"mem": "Mém",
|
"mem": "MÉM",
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"free": "Libre",
|
"free": "Libre",
|
||||||
"used": "Utilisé",
|
"used": "Utilisé",
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
"docker": {
|
"docker": {
|
||||||
"rx": "Rx",
|
"rx": "Rx",
|
||||||
"tx": "Tx",
|
"tx": "Tx",
|
||||||
"mem": "Mém",
|
"mem": "MÉM",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"running": "Démarré",
|
"running": "Démarré",
|
||||||
"offline": "Hors ligne",
|
"offline": "Hors ligne",
|
||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Déconnexion en attente",
|
"connectionStatusPendingDisconnect": "Déconnexion en attente",
|
||||||
"connectionStatusDisconnecting": "Déconnexion en cours",
|
"connectionStatusDisconnecting": "Déconnexion en cours",
|
||||||
"connectionStatusDisconnected": "Déconnecté",
|
"connectionStatusDisconnected": "Déconnecté",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Connecté",
|
||||||
"uptime": "Démarré depuis",
|
"uptime": "Démarré depuis",
|
||||||
"maxDown": "Max. Bas",
|
"maxDown": "Max. Bas",
|
||||||
"maxUp": "Max. Haut",
|
"maxUp": "Max. Haut",
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"connected": "Connected",
|
"connected": "Connecté",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Nouveaux appareils",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Alertes d'arrêt"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Requêtes",
|
"queries": "Requêtes",
|
||||||
@@ -395,7 +395,7 @@
|
|||||||
"failedLoginsLast24H": "Cnx. échouées (24h)"
|
"failedLoginsLast24H": "Cnx. échouées (24h)"
|
||||||
},
|
},
|
||||||
"proxmox": {
|
"proxmox": {
|
||||||
"mem": "Mém",
|
"mem": "MÉM",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"lxc": "LxC",
|
"lxc": "LxC",
|
||||||
"vms": "VMs"
|
"vms": "VMs"
|
||||||
@@ -411,7 +411,7 @@
|
|||||||
"total": "Total",
|
"total": "Total",
|
||||||
"free": "Libre",
|
"free": "Libre",
|
||||||
"used": "Utilisé",
|
"used": "Utilisé",
|
||||||
"days": "d",
|
"days": "j",
|
||||||
"hours": "h",
|
"hours": "h",
|
||||||
"crit": "Crit.",
|
"crit": "Crit.",
|
||||||
"read": "Lu",
|
"read": "Lu",
|
||||||
@@ -847,18 +847,18 @@
|
|||||||
"stash": {
|
"stash": {
|
||||||
"scenes": "Scènes",
|
"scenes": "Scènes",
|
||||||
"scenesPlayed": "Scènes jouées",
|
"scenesPlayed": "Scènes jouées",
|
||||||
"playCount": "Total Plays",
|
"playCount": "Lectures Totales",
|
||||||
"playDuration": "Time Watched",
|
"playDuration": "Temps regardé",
|
||||||
"sceneSize": "Scenes Size",
|
"sceneSize": "Taille des scènes",
|
||||||
"sceneDuration": "Scenes Duration",
|
"sceneDuration": "Durée des scènes",
|
||||||
"images": "Images",
|
"images": "Images",
|
||||||
"imageSize": "Taille des images",
|
"imageSize": "Taille des images",
|
||||||
"galleries": "Galeries",
|
"galleries": "Galeries",
|
||||||
"performers": "Performers",
|
"performers": "Acteurs",
|
||||||
"studios": "Studios",
|
"studios": "Studios",
|
||||||
"movies": "Films",
|
"movies": "Films",
|
||||||
"tags": "Étiquettes",
|
"tags": "Étiquettes",
|
||||||
"oCount": "O Count"
|
"oCount": "0 Compte"
|
||||||
},
|
},
|
||||||
"tandoor": {
|
"tandoor": {
|
||||||
"users": "Utilisateurs",
|
"users": "Utilisateurs",
|
||||||
@@ -871,10 +871,22 @@
|
|||||||
"locations": "Emplacements",
|
"locations": "Emplacements",
|
||||||
"labels": "Étiquettes",
|
"labels": "Étiquettes",
|
||||||
"users": "Utilisateurs",
|
"users": "Utilisateurs",
|
||||||
"totalValue": "Total Value"
|
"totalValue": "Valeur Totale"
|
||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alertes",
|
"alerts": "Alertes",
|
||||||
"bans": "Bans"
|
"bans": "Exclusions"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connecté",
|
||||||
|
"enabled": "Activé",
|
||||||
|
"disabled": "Désactivé",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "מופעל",
|
||||||
|
"disabled": "מבוטל",
|
||||||
|
"total": "סה\"כ"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Odspajanje u tijeku",
|
"connectionStatusPendingDisconnect": "Odspajanje u tijeku",
|
||||||
"connectionStatusDisconnecting": "Odspajanje",
|
"connectionStatusDisconnecting": "Odspajanje",
|
||||||
"connectionStatusDisconnected": "Odspojeno",
|
"connectionStatusDisconnected": "Odspojeno",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Povezano",
|
||||||
"uptime": "Vrijeme rada",
|
"uptime": "Vrijeme rada",
|
||||||
"maxDown": "Maksimum preuzimanja",
|
"maxDown": "Maksimum preuzimanja",
|
||||||
"maxUp": "Maksimum prijenosa",
|
"maxUp": "Maksimum prijenosa",
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Ukupno",
|
"total": "Ukupno",
|
||||||
"connected": "Connected",
|
"connected": "Povezano",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Novi uređaji",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Obavijesti o nedostupnosti"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Upiti",
|
"queries": "Upiti",
|
||||||
@@ -834,47 +834,59 @@
|
|||||||
"criticals": "Kritično"
|
"criticals": "Kritično"
|
||||||
},
|
},
|
||||||
"plantit": {
|
"plantit": {
|
||||||
"events": "Events",
|
"events": "Događaji",
|
||||||
"plants": "Plants",
|
"plants": "Biljke",
|
||||||
"photos": "Fotografije",
|
"photos": "Fotografije",
|
||||||
"species": "Species"
|
"species": "Vrste"
|
||||||
},
|
},
|
||||||
"gitea": {
|
"gitea": {
|
||||||
"notifications": "Notifications",
|
"notifications": "Obavijesti",
|
||||||
"issues": "Problemi",
|
"issues": "Problemi",
|
||||||
"pulls": "Pull Requests"
|
"pulls": "Zahtjevi za povlačenje"
|
||||||
},
|
},
|
||||||
"stash": {
|
"stash": {
|
||||||
"scenes": "Scenes",
|
"scenes": "Scene",
|
||||||
"scenesPlayed": "Scenes Played",
|
"scenesPlayed": "Reproducirane scene",
|
||||||
"playCount": "Total Plays",
|
"playCount": "Ukupni broj reprodukcija",
|
||||||
"playDuration": "Time Watched",
|
"playDuration": "Vrijeme gledanja",
|
||||||
"sceneSize": "Scenes Size",
|
"sceneSize": "Veličina scene",
|
||||||
"sceneDuration": "Scenes Duration",
|
"sceneDuration": "Trajanje scene",
|
||||||
"images": "Images",
|
"images": "Slike",
|
||||||
"imageSize": "Images Size",
|
"imageSize": "Veličina slike",
|
||||||
"galleries": "Galleries",
|
"galleries": "Galerije",
|
||||||
"performers": "Performers",
|
"performers": "Glumci",
|
||||||
"studios": "Studios",
|
"studios": "Studiji",
|
||||||
"movies": "Filmovi",
|
"movies": "Filmovi",
|
||||||
"tags": "Oznake",
|
"tags": "Oznake",
|
||||||
"oCount": "O Count"
|
"oCount": "O zbroj"
|
||||||
},
|
},
|
||||||
"tandoor": {
|
"tandoor": {
|
||||||
"users": "Korisnici",
|
"users": "Korisnici",
|
||||||
"recipes": "Recepti",
|
"recipes": "Recepti",
|
||||||
"keywords": "Keywords"
|
"keywords": "Ključne riječi"
|
||||||
},
|
},
|
||||||
"homebox": {
|
"homebox": {
|
||||||
"items": "Items",
|
"items": "Stavke",
|
||||||
"totalWithWarranty": "With Warranty",
|
"totalWithWarranty": "S garancijom",
|
||||||
"locations": "Locations",
|
"locations": "Lokacije",
|
||||||
"labels": "Labels",
|
"labels": "Oznake",
|
||||||
"users": "Korisnici",
|
"users": "Korisnici",
|
||||||
"totalValue": "Total Value"
|
"totalValue": "Svukupno"
|
||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Upozorenja",
|
"alerts": "Upozorenja",
|
||||||
"bans": "Bans"
|
"bans": "Zabrane"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Povezano",
|
||||||
|
"enabled": "Aktivirano",
|
||||||
|
"disabled": "Deaktivirano",
|
||||||
|
"total": "Ukupno"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Posredovano",
|
||||||
|
"auth": "S autentifikacijom",
|
||||||
|
"outdated": "Zastarjelo",
|
||||||
|
"banned": "Zabranjen pristup"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -45,7 +45,7 @@
|
|||||||
"free": "Szabad",
|
"free": "Szabad",
|
||||||
"used": "Használt",
|
"used": "Használt",
|
||||||
"load": "Terhelés",
|
"load": "Terhelés",
|
||||||
"temp": "HŐ",
|
"temp": "HŐM",
|
||||||
"max": "Max",
|
"max": "Max",
|
||||||
"uptime": "FUT"
|
"uptime": "FUT"
|
||||||
},
|
},
|
||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Szétkapcsolás függőben",
|
"connectionStatusPendingDisconnect": "Szétkapcsolás függőben",
|
||||||
"connectionStatusDisconnecting": "Kapcsolat bontása",
|
"connectionStatusDisconnecting": "Kapcsolat bontása",
|
||||||
"connectionStatusDisconnected": "Kapcsolat bontva",
|
"connectionStatusDisconnected": "Kapcsolat bontva",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Csatlakozva",
|
||||||
"uptime": "Üzemidő",
|
"uptime": "Üzemidő",
|
||||||
"maxDown": "Max let.",
|
"maxDown": "Max let.",
|
||||||
"maxUp": "Max felt.",
|
"maxUp": "Max felt.",
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Összes",
|
"total": "Összes",
|
||||||
"connected": "Connected",
|
"connected": "Csatlakozva",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Új eszközök",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Leállási riasztások"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Lekérdezések",
|
"queries": "Lekérdezések",
|
||||||
@@ -404,7 +404,7 @@
|
|||||||
"cpu": "Processzor",
|
"cpu": "Processzor",
|
||||||
"load": "Terhelés",
|
"load": "Terhelés",
|
||||||
"wait": "Kérjük várjon",
|
"wait": "Kérjük várjon",
|
||||||
"temp": "HŐ",
|
"temp": "HŐM",
|
||||||
"_temp": "Hőmérséklet",
|
"_temp": "Hőmérséklet",
|
||||||
"warn": "Figyelmeztet",
|
"warn": "Figyelmeztet",
|
||||||
"uptime": "FUT",
|
"uptime": "FUT",
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Riasztások",
|
"alerts": "Riasztások",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Csatlakozva",
|
||||||
|
"enabled": "Bekapcsolva",
|
||||||
|
"disabled": "Kikapcsolva",
|
||||||
|
"total": "Összes"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Peringatan",
|
"alerts": "Peringatan",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Aktif",
|
||||||
|
"disabled": "Nonaktif",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Allarmi",
|
"alerts": "Allarmi",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connesso",
|
||||||
|
"enabled": "Abilitato",
|
||||||
|
"disabled": "Disabilitati",
|
||||||
|
"total": "Totale"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -47,7 +47,7 @@
|
|||||||
"load": "ロード",
|
"load": "ロード",
|
||||||
"temp": "温度",
|
"temp": "温度",
|
||||||
"max": "最大",
|
"max": "最大",
|
||||||
"uptime": "上へ"
|
"uptime": "UP"
|
||||||
},
|
},
|
||||||
"unifi": {
|
"unifi": {
|
||||||
"users": "ユーザ",
|
"users": "ユーザ",
|
||||||
@@ -61,7 +61,7 @@
|
|||||||
"wlan_devices": "WLAN デバイス",
|
"wlan_devices": "WLAN デバイス",
|
||||||
"lan_users": "LAN ユーザ",
|
"lan_users": "LAN ユーザ",
|
||||||
"wlan_users": "WLAN ユーザ",
|
"wlan_users": "WLAN ユーザ",
|
||||||
"up": "上へ",
|
"up": "UP",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"wait": "お待ちください",
|
"wait": "お待ちください",
|
||||||
"empty_data": "サブシステムの状態は不明"
|
"empty_data": "サブシステムの状態は不明"
|
||||||
@@ -86,7 +86,7 @@
|
|||||||
"error": "エラー",
|
"error": "エラー",
|
||||||
"ping": "Ping",
|
"ping": "Ping",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"not_available": "利用できません。"
|
"not_available": "利用できません。"
|
||||||
},
|
},
|
||||||
"siteMonitor": {
|
"siteMonitor": {
|
||||||
@@ -94,7 +94,7 @@
|
|||||||
"error": "エラー",
|
"error": "エラー",
|
||||||
"response": "応答",
|
"response": "応答",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"not_available": "利用できません。"
|
"not_available": "利用できません。"
|
||||||
},
|
},
|
||||||
"emby": {
|
"emby": {
|
||||||
@@ -140,12 +140,12 @@
|
|||||||
"connectionStatusPendingDisconnect": "接続を切断する",
|
"connectionStatusPendingDisconnect": "接続を切断する",
|
||||||
"connectionStatusDisconnecting": "接続を切断中",
|
"connectionStatusDisconnecting": "接続を切断中",
|
||||||
"connectionStatusDisconnected": "切断されました",
|
"connectionStatusDisconnected": "切断されました",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "接続済",
|
||||||
"uptime": "稼働時間",
|
"uptime": "稼働時間",
|
||||||
"maxDown": "最大ダウン",
|
"maxDown": "最大ダウン",
|
||||||
"maxUp": "最大アップ",
|
"maxUp": "最大アップ",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"received": "受信済み",
|
"received": "受信済み",
|
||||||
"sent": "送信済み",
|
"sent": "送信済み",
|
||||||
"externalIPAddress": "退出ID"
|
"externalIPAddress": "退出ID"
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "合計",
|
"total": "合計",
|
||||||
"connected": "Connected",
|
"connected": "接続済",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "新規デバイス",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "ダウンアラート"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "クエリ",
|
"queries": "クエリ",
|
||||||
@@ -407,7 +407,7 @@
|
|||||||
"temp": "温度",
|
"temp": "温度",
|
||||||
"_temp": "温度",
|
"_temp": "温度",
|
||||||
"warn": "警告",
|
"warn": "警告",
|
||||||
"uptime": "上へ",
|
"uptime": "UP",
|
||||||
"total": "合計",
|
"total": "合計",
|
||||||
"free": "空き",
|
"free": "空き",
|
||||||
"used": "使用",
|
"used": "使用",
|
||||||
@@ -494,13 +494,13 @@
|
|||||||
"up_to_date": "最新",
|
"up_to_date": "最新",
|
||||||
"child_bridges": "子ブリッジ",
|
"child_bridges": "子ブリッジ",
|
||||||
"child_bridges_status": "{{ok}}/{{total}}",
|
"child_bridges_status": "{{ok}}/{{total}}",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"pending": "保留中",
|
"pending": "保留中",
|
||||||
"down": "下へ"
|
"down": "下へ"
|
||||||
},
|
},
|
||||||
"healthchecks": {
|
"healthchecks": {
|
||||||
"new": "新着",
|
"new": "新着",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"grace": "猶予期間中",
|
"grace": "猶予期間中",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"paused": "一時停止中",
|
"paused": "一時停止中",
|
||||||
@@ -617,7 +617,7 @@
|
|||||||
"load": "読み込み平均",
|
"load": "読み込み平均",
|
||||||
"memory": "メモリ使用量",
|
"memory": "メモリ使用量",
|
||||||
"wanStatus": "WANステータス",
|
"wanStatus": "WANステータス",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"temp": "温度",
|
"temp": "温度",
|
||||||
"disk": "ディスク使用量",
|
"disk": "ディスク使用量",
|
||||||
@@ -799,7 +799,7 @@
|
|||||||
"openwrt": {
|
"openwrt": {
|
||||||
"uptime": "稼働時間",
|
"uptime": "稼働時間",
|
||||||
"cpuLoad": "CPU 平均負荷(5 分)",
|
"cpuLoad": "CPU 平均負荷(5 分)",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"bytesTx": "送信済み",
|
"bytesTx": "送信済み",
|
||||||
"bytesRx": "受信済み"
|
"bytesRx": "受信済み"
|
||||||
@@ -813,7 +813,7 @@
|
|||||||
"sitesDown": "サイトDown",
|
"sitesDown": "サイトDown",
|
||||||
"paused": "一時停止中",
|
"paused": "一時停止中",
|
||||||
"notyetchecked": "チェックされていません",
|
"notyetchecked": "チェックされていません",
|
||||||
"up": "上へ",
|
"up": "稼働",
|
||||||
"seemsdown": "ダウンしているようです",
|
"seemsdown": "ダウンしているようです",
|
||||||
"down": "下へ",
|
"down": "下へ",
|
||||||
"unknown": "不明"
|
"unknown": "不明"
|
||||||
@@ -875,6 +875,18 @@
|
|||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "アラート",
|
"alerts": "アラート",
|
||||||
"bans": "Bans"
|
"bans": "禁止"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "接続済",
|
||||||
|
"enabled": "有効",
|
||||||
|
"disabled": "無効",
|
||||||
|
"total": "合計"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "경고",
|
"alerts": "경고",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "활성",
|
||||||
|
"disabled": "비활성",
|
||||||
|
"total": "총합"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Paziņojumi",
|
"alerts": "Paziņojumi",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Kopā"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Didayakan",
|
||||||
|
"disabled": "Dinyahdayakan",
|
||||||
|
"total": "Jumlah"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Meldingen",
|
"alerts": "Meldingen",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Verbonden",
|
||||||
|
"enabled": "Ingeschakeld",
|
||||||
|
"disabled": "Uitgeschakeld",
|
||||||
|
"total": "Totaal"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -80,22 +80,22 @@
|
|||||||
"unhealthy": "Usunn",
|
"unhealthy": "Usunn",
|
||||||
"not_found": "Not Found",
|
"not_found": "Not Found",
|
||||||
"exited": "Exited",
|
"exited": "Exited",
|
||||||
"partial": "Partial"
|
"partial": "Delvis"
|
||||||
},
|
},
|
||||||
"ping": {
|
"ping": {
|
||||||
"error": "Feil",
|
"error": "Feil",
|
||||||
"ping": "Ping",
|
"ping": "Responstid",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"not_available": "Not Available"
|
"not_available": "Ikke tilgjengelig"
|
||||||
},
|
},
|
||||||
"siteMonitor": {
|
"siteMonitor": {
|
||||||
"http_status": "HTTP status",
|
"http_status": "HTTP status",
|
||||||
"error": "Feil",
|
"error": "Feil",
|
||||||
"response": "Svar",
|
"response": "Svar",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"not_available": "Not Available"
|
"not_available": "Ikke tilgjengelig"
|
||||||
},
|
},
|
||||||
"emby": {
|
"emby": {
|
||||||
"playing": "Spiller",
|
"playing": "Spiller",
|
||||||
@@ -110,7 +110,7 @@
|
|||||||
"esphome": {
|
"esphome": {
|
||||||
"offline": "Frakoblet",
|
"offline": "Frakoblet",
|
||||||
"offline_alt": "Frakoblet",
|
"offline_alt": "Frakoblet",
|
||||||
"online": "Online",
|
"online": "På nett",
|
||||||
"total": "Totalt",
|
"total": "Totalt",
|
||||||
"unknown": "Ukjent"
|
"unknown": "Ukjent"
|
||||||
},
|
},
|
||||||
@@ -140,12 +140,12 @@
|
|||||||
"connectionStatusPendingDisconnect": "Venter på frakobling",
|
"connectionStatusPendingDisconnect": "Venter på frakobling",
|
||||||
"connectionStatusDisconnecting": "Kobler fra",
|
"connectionStatusDisconnecting": "Kobler fra",
|
||||||
"connectionStatusDisconnected": "Frakoblet",
|
"connectionStatusDisconnected": "Frakoblet",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Tilkoblet",
|
||||||
"uptime": "Oppetid",
|
"uptime": "Oppetid",
|
||||||
"maxDown": "Maks. Ned",
|
"maxDown": "Maks. Ned",
|
||||||
"maxUp": "Max. Opp",
|
"maxUp": "Max. Opp",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"received": "Mottatt",
|
"received": "Mottatt",
|
||||||
"sent": "Sendt",
|
"sent": "Sendt",
|
||||||
"externalIPAddress": "Ekstern IP"
|
"externalIPAddress": "Ekstern IP"
|
||||||
@@ -279,8 +279,8 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Totalt",
|
"total": "Totalt",
|
||||||
"connected": "Connected",
|
"connected": "Tilkoblet",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Nye enheter",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Down Alerts"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
@@ -298,7 +298,7 @@
|
|||||||
"speedtest": {
|
"speedtest": {
|
||||||
"upload": "Opplastning",
|
"upload": "Opplastning",
|
||||||
"download": "Last ned",
|
"download": "Last ned",
|
||||||
"ping": "Ping"
|
"ping": "Responstid"
|
||||||
},
|
},
|
||||||
"portainer": {
|
"portainer": {
|
||||||
"running": "Kjører",
|
"running": "Kjører",
|
||||||
@@ -321,57 +321,57 @@
|
|||||||
},
|
},
|
||||||
"tdarr": {
|
"tdarr": {
|
||||||
"queue": "Kø",
|
"queue": "Kø",
|
||||||
"processed": "Processed",
|
"processed": "Behandlet",
|
||||||
"errored": "Errored",
|
"errored": "Feilet",
|
||||||
"saved": "Saved"
|
"saved": "Lagret"
|
||||||
},
|
},
|
||||||
"traefik": {
|
"traefik": {
|
||||||
"routers": "Routers",
|
"routers": "Rutere",
|
||||||
"services": "Services",
|
"services": "Tjenester",
|
||||||
"middleware": "Middleware"
|
"middleware": "Mellomvare"
|
||||||
},
|
},
|
||||||
"navidrome": {
|
"navidrome": {
|
||||||
"nothing_streaming": "Ingen aktive strømminger",
|
"nothing_streaming": "Ingen aktive strømminger",
|
||||||
"please_wait": "Please Wait"
|
"please_wait": "Vennligst vent"
|
||||||
},
|
},
|
||||||
"npm": {
|
"npm": {
|
||||||
"enabled": "Enabled",
|
"enabled": "Aktivert",
|
||||||
"disabled": "Disabled",
|
"disabled": "Deaktivert",
|
||||||
"total": "Totalt"
|
"total": "Totalt"
|
||||||
},
|
},
|
||||||
"coinmarketcap": {
|
"coinmarketcap": {
|
||||||
"configure": "Configure one or more crypto currencies to track",
|
"configure": "Konfigurer én eller flere krypteringsvalutaer som skal spores",
|
||||||
"1hour": "1 Hour",
|
"1hour": "Én time",
|
||||||
"1day": "1 Day",
|
"1day": "Én dag",
|
||||||
"7days": "7 Days",
|
"7days": "7 dager",
|
||||||
"30days": "30 Days"
|
"30days": "30 dager"
|
||||||
},
|
},
|
||||||
"gotify": {
|
"gotify": {
|
||||||
"apps": "Applications",
|
"apps": "Applikasjoner",
|
||||||
"clients": "Clients",
|
"clients": "Klienter",
|
||||||
"messages": "Messages"
|
"messages": "Meldinger"
|
||||||
},
|
},
|
||||||
"prowlarr": {
|
"prowlarr": {
|
||||||
"enableIndexers": "Indexers",
|
"enableIndexers": "Indeksere",
|
||||||
"numberOfGrabs": "Grabs",
|
"numberOfGrabs": "Tatt",
|
||||||
"numberOfQueries": "Spørringer",
|
"numberOfQueries": "Spørringer",
|
||||||
"numberOfFailGrabs": "Fail Grabs",
|
"numberOfFailGrabs": "Feil ved henting",
|
||||||
"numberOfFailQueries": "Fail Queries"
|
"numberOfFailQueries": "Spørring mislyktes"
|
||||||
},
|
},
|
||||||
"jackett": {
|
"jackett": {
|
||||||
"configured": "Configured",
|
"configured": "Konfigurert",
|
||||||
"errored": "Errored"
|
"errored": "Feilet"
|
||||||
},
|
},
|
||||||
"strelaysrv": {
|
"strelaysrv": {
|
||||||
"numActiveSessions": "Sessions",
|
"numActiveSessions": "Sesjoner",
|
||||||
"numConnections": "Connections",
|
"numConnections": "Tilkoblinger",
|
||||||
"dataRelayed": "Relayed",
|
"dataRelayed": "Videresendt",
|
||||||
"transferRate": "Ranger"
|
"transferRate": "Ranger"
|
||||||
},
|
},
|
||||||
"mastodon": {
|
"mastodon": {
|
||||||
"user_count": "Brukere",
|
"user_count": "Brukere",
|
||||||
"status_count": "Posts",
|
"status_count": "Innlegg",
|
||||||
"domain_count": "Domains"
|
"domain_count": "Domener"
|
||||||
},
|
},
|
||||||
"medusa": {
|
"medusa": {
|
||||||
"wanted": "Ønsket",
|
"wanted": "Ønsket",
|
||||||
@@ -379,10 +379,10 @@
|
|||||||
"series": "Serie"
|
"series": "Serie"
|
||||||
},
|
},
|
||||||
"minecraft": {
|
"minecraft": {
|
||||||
"players": "Players",
|
"players": "Spillere",
|
||||||
"version": "Versjon",
|
"version": "Versjon",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"up": "Online",
|
"up": "På nett",
|
||||||
"down": "Frakoblet"
|
"down": "Frakoblet"
|
||||||
},
|
},
|
||||||
"miniflux": {
|
"miniflux": {
|
||||||
@@ -494,15 +494,15 @@
|
|||||||
"up_to_date": "Oppdatert",
|
"up_to_date": "Oppdatert",
|
||||||
"child_bridges": "Child Bridges",
|
"child_bridges": "Child Bridges",
|
||||||
"child_bridges_status": "{{ok}}/{{total}}",
|
"child_bridges_status": "{{ok}}/{{total}}",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"pending": "Ventende",
|
"pending": "Ventende",
|
||||||
"down": "Down"
|
"down": "Nede"
|
||||||
},
|
},
|
||||||
"healthchecks": {
|
"healthchecks": {
|
||||||
"new": "Ny",
|
"new": "Ny",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"grace": "I rammeperiode",
|
"grace": "I rammeperiode",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"paused": "Pauset",
|
"paused": "Pauset",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"last_ping": "Siste Ping",
|
"last_ping": "Siste Ping",
|
||||||
@@ -517,7 +517,7 @@
|
|||||||
"approvedPushes": "Godkjent",
|
"approvedPushes": "Godkjent",
|
||||||
"rejectedPushes": "Avvist",
|
"rejectedPushes": "Avvist",
|
||||||
"filters": "Filtre",
|
"filters": "Filtre",
|
||||||
"indexers": "Indexers"
|
"indexers": "Indeksere"
|
||||||
},
|
},
|
||||||
"tubearchivist": {
|
"tubearchivist": {
|
||||||
"downloads": "Kø",
|
"downloads": "Kø",
|
||||||
@@ -566,12 +566,12 @@
|
|||||||
"battery_charge": "Batteriladning",
|
"battery_charge": "Batteriladning",
|
||||||
"ups_load": "UPS last",
|
"ups_load": "UPS last",
|
||||||
"ups_status": "UPS status",
|
"ups_status": "UPS status",
|
||||||
"online": "Online",
|
"online": "På nett",
|
||||||
"on_battery": "På batteri",
|
"on_battery": "På batteri",
|
||||||
"low_battery": "Lavt batterinivå"
|
"low_battery": "Lavt batterinivå"
|
||||||
},
|
},
|
||||||
"nextdns": {
|
"nextdns": {
|
||||||
"wait": "Please Wait",
|
"wait": "Vennligst vent",
|
||||||
"no_devices": "Ingen enhetsdata mottatt"
|
"no_devices": "Ingen enhetsdata mottatt"
|
||||||
},
|
},
|
||||||
"mikrotik": {
|
"mikrotik": {
|
||||||
@@ -617,8 +617,8 @@
|
|||||||
"load": "Load Avg",
|
"load": "Load Avg",
|
||||||
"memory": "Mem Usage",
|
"memory": "Mem Usage",
|
||||||
"wanStatus": "WAN Status",
|
"wanStatus": "WAN Status",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"temp": "Temp",
|
"temp": "Temp",
|
||||||
"disk": "Disk Usage",
|
"disk": "Disk Usage",
|
||||||
"wanIP": "WAN IP"
|
"wanIP": "WAN IP"
|
||||||
@@ -672,7 +672,7 @@
|
|||||||
"fileflows": {
|
"fileflows": {
|
||||||
"queue": "Kø",
|
"queue": "Kø",
|
||||||
"processing": "Behandler",
|
"processing": "Behandler",
|
||||||
"processed": "Processed",
|
"processed": "Behandlet",
|
||||||
"time": "Time"
|
"time": "Time"
|
||||||
},
|
},
|
||||||
"grafana": {
|
"grafana": {
|
||||||
@@ -698,17 +698,17 @@
|
|||||||
},
|
},
|
||||||
"unmanic": {
|
"unmanic": {
|
||||||
"active_workers": "Active Workers",
|
"active_workers": "Active Workers",
|
||||||
"total_workers": "Total Workers",
|
"total_workers": "Totalt antall Arbeidere",
|
||||||
"records_total": "Queue Length"
|
"records_total": "Kø lengde"
|
||||||
},
|
},
|
||||||
"pterodactyl": {
|
"pterodactyl": {
|
||||||
"servers": "Servers",
|
"servers": "Servere",
|
||||||
"nodes": "Nodes"
|
"nodes": "Noder"
|
||||||
},
|
},
|
||||||
"prometheus": {
|
"prometheus": {
|
||||||
"targets_up": "Targets Up",
|
"targets_up": "Mål oppe",
|
||||||
"targets_down": "Targets Down",
|
"targets_down": "Mål nede",
|
||||||
"targets_total": "Total Targets"
|
"targets_total": "Totalt antall mål"
|
||||||
},
|
},
|
||||||
"gatus": {
|
"gatus": {
|
||||||
"up": "Nettsteder opp",
|
"up": "Nettsteder opp",
|
||||||
@@ -717,27 +717,27 @@
|
|||||||
},
|
},
|
||||||
"ghostfolio": {
|
"ghostfolio": {
|
||||||
"gross_percent_today": "Idag",
|
"gross_percent_today": "Idag",
|
||||||
"gross_percent_1y": "One year",
|
"gross_percent_1y": "Ett år",
|
||||||
"gross_percent_max": "All time"
|
"gross_percent_max": "Gjennom tidene"
|
||||||
},
|
},
|
||||||
"audiobookshelf": {
|
"audiobookshelf": {
|
||||||
"podcasts": "Podcasts",
|
"podcasts": "Podkaster",
|
||||||
"books": "Bøker",
|
"books": "Bøker",
|
||||||
"podcastsDuration": "Duration",
|
"podcastsDuration": "Varighet",
|
||||||
"booksDuration": "Duration"
|
"booksDuration": "Varighet"
|
||||||
},
|
},
|
||||||
"homeassistant": {
|
"homeassistant": {
|
||||||
"people_home": "People Home",
|
"people_home": "Personer hjemme",
|
||||||
"lights_on": "Lights On",
|
"lights_on": "Lys på",
|
||||||
"switches_on": "Switches On"
|
"switches_on": "Slår På"
|
||||||
},
|
},
|
||||||
"whatsupdocker": {
|
"whatsupdocker": {
|
||||||
"monitoring": "Monitoring",
|
"monitoring": "Overvåker",
|
||||||
"updates": "Oppdateringer"
|
"updates": "Oppdateringer"
|
||||||
},
|
},
|
||||||
"calibreweb": {
|
"calibreweb": {
|
||||||
"books": "Bøker",
|
"books": "Bøker",
|
||||||
"authors": "Authors",
|
"authors": "Forfattere",
|
||||||
"categories": "Categories",
|
"categories": "Categories",
|
||||||
"series": "Serie"
|
"series": "Serie"
|
||||||
},
|
},
|
||||||
@@ -766,15 +766,15 @@
|
|||||||
},
|
},
|
||||||
"gamedig": {
|
"gamedig": {
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"online": "Online",
|
"online": "På nett",
|
||||||
"offline": "Frakoblet",
|
"offline": "Frakoblet",
|
||||||
"name": "Navn",
|
"name": "Navn",
|
||||||
"map": "Kart",
|
"map": "Kart",
|
||||||
"currentPlayers": "Aktuelle spillere",
|
"currentPlayers": "Aktuelle spillere",
|
||||||
"players": "Players",
|
"players": "Spillere",
|
||||||
"maxPlayers": "Maks spillere",
|
"maxPlayers": "Maks spillere",
|
||||||
"bots": "Bots",
|
"bots": "Bots",
|
||||||
"ping": "Ping"
|
"ping": "Responstid"
|
||||||
},
|
},
|
||||||
"urbackup": {
|
"urbackup": {
|
||||||
"ok": "Ok",
|
"ok": "Ok",
|
||||||
@@ -799,8 +799,8 @@
|
|||||||
"openwrt": {
|
"openwrt": {
|
||||||
"uptime": "Oppetid",
|
"uptime": "Oppetid",
|
||||||
"cpuLoad": "CPU-belastning snitt (5m)",
|
"cpuLoad": "CPU-belastning snitt (5m)",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"bytesTx": "Sendt",
|
"bytesTx": "Sendt",
|
||||||
"bytesRx": "Mottatt"
|
"bytesRx": "Mottatt"
|
||||||
},
|
},
|
||||||
@@ -813,9 +813,9 @@
|
|||||||
"sitesDown": "Sites Down",
|
"sitesDown": "Sites Down",
|
||||||
"paused": "Pauset",
|
"paused": "Pauset",
|
||||||
"notyetchecked": "Ikke sjekket enda",
|
"notyetchecked": "Ikke sjekket enda",
|
||||||
"up": "Up",
|
"up": "Oppe",
|
||||||
"seemsdown": "Virker nede",
|
"seemsdown": "Virker nede",
|
||||||
"down": "Down",
|
"down": "Nede",
|
||||||
"unknown": "Ukjent"
|
"unknown": "Ukjent"
|
||||||
},
|
},
|
||||||
"calendar": {
|
"calendar": {
|
||||||
@@ -842,7 +842,7 @@
|
|||||||
"gitea": {
|
"gitea": {
|
||||||
"notifications": "Varslinger",
|
"notifications": "Varslinger",
|
||||||
"issues": "Issues",
|
"issues": "Issues",
|
||||||
"pulls": "Pull Requests"
|
"pulls": "Forespørsel"
|
||||||
},
|
},
|
||||||
"stash": {
|
"stash": {
|
||||||
"scenes": "Scener",
|
"scenes": "Scener",
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Varsler",
|
"alerts": "Varsler",
|
||||||
"bans": "Utestengelse"
|
"bans": "Utestengelse"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Tilkoblet",
|
||||||
|
"enabled": "Aktivert",
|
||||||
|
"disabled": "Deaktivert",
|
||||||
|
"total": "Totalt"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alarmy",
|
"alerts": "Alarmy",
|
||||||
"bans": "Bany"
|
"bans": "Bany"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Włączone",
|
||||||
|
"disabled": "Wyłączone",
|
||||||
|
"total": "Całkowite"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alertas",
|
"alerts": "Alertas",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Ativo",
|
||||||
|
"disabled": "Desabilitado",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,11 +22,11 @@
|
|||||||
},
|
},
|
||||||
"widget": {
|
"widget": {
|
||||||
"missing_type": "Tipo de Widget ausente: {{type}}",
|
"missing_type": "Tipo de Widget ausente: {{type}}",
|
||||||
"api_error": "Erro da API",
|
"api_error": "Erros de API",
|
||||||
"information": "Informação",
|
"information": "Informação",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"url": "Endereço URL",
|
"url": "Endereço URL",
|
||||||
"raw_error": "Erro",
|
"raw_error": "Erro Raw",
|
||||||
"response_data": "Dados da Resposta"
|
"response_data": "Dados da Resposta"
|
||||||
},
|
},
|
||||||
"weather": {
|
"weather": {
|
||||||
@@ -101,7 +101,7 @@
|
|||||||
"playing": "A reproduzir",
|
"playing": "A reproduzir",
|
||||||
"transcoding": "Transcodificação",
|
"transcoding": "Transcodificação",
|
||||||
"bitrate": "Taxa de bits",
|
"bitrate": "Taxa de bits",
|
||||||
"no_active": "Sem streams ativas",
|
"no_active": "Sem Streams Ativos",
|
||||||
"movies": "Filmes",
|
"movies": "Filmes",
|
||||||
"series": "Séries",
|
"series": "Séries",
|
||||||
"episodes": "Episódios",
|
"episodes": "Episódios",
|
||||||
@@ -110,7 +110,7 @@
|
|||||||
"esphome": {
|
"esphome": {
|
||||||
"offline": "Desligado",
|
"offline": "Desligado",
|
||||||
"offline_alt": "Desligado",
|
"offline_alt": "Desligado",
|
||||||
"online": "Online",
|
"online": "Disponível",
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"unknown": "Desconhecido"
|
"unknown": "Desconhecido"
|
||||||
},
|
},
|
||||||
@@ -140,10 +140,10 @@
|
|||||||
"connectionStatusPendingDisconnect": "Desconexão Pendente",
|
"connectionStatusPendingDisconnect": "Desconexão Pendente",
|
||||||
"connectionStatusDisconnecting": "Desconectando",
|
"connectionStatusDisconnecting": "Desconectando",
|
||||||
"connectionStatusDisconnected": "Desconectado",
|
"connectionStatusDisconnected": "Desconectado",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Conectado",
|
||||||
"uptime": "Ligado",
|
"uptime": "Ligado",
|
||||||
"maxDown": "Max. Down",
|
"maxDown": "Max. Down",
|
||||||
"maxUp": "Max. Up",
|
"maxUp": "Máx. Acima",
|
||||||
"down": "Inativo",
|
"down": "Inativo",
|
||||||
"up": "Ativo",
|
"up": "Ativo",
|
||||||
"received": "Recebido",
|
"received": "Recebido",
|
||||||
@@ -151,7 +151,7 @@
|
|||||||
"externalIPAddress": "IP Externo"
|
"externalIPAddress": "IP Externo"
|
||||||
},
|
},
|
||||||
"caddy": {
|
"caddy": {
|
||||||
"upstreams": "Upstreams",
|
"upstreams": "Streams de Envio",
|
||||||
"requests": "Solicitações atuais",
|
"requests": "Solicitações atuais",
|
||||||
"requests_failed": "Solicitações com falha"
|
"requests_failed": "Solicitações com falha"
|
||||||
},
|
},
|
||||||
@@ -169,15 +169,15 @@
|
|||||||
"playing": "A reproduzir",
|
"playing": "A reproduzir",
|
||||||
"transcoding": "Transcodificação",
|
"transcoding": "Transcodificação",
|
||||||
"bitrate": "Taxa de bits",
|
"bitrate": "Taxa de bits",
|
||||||
"no_active": "Sem streams ativas",
|
"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": {
|
||||||
"connectedAp": "APs Ligados",
|
"connectedAp": "APs Ligados",
|
||||||
"activeUser": "Dispositivos activos",
|
"activeUser": "Dispositivos ativos",
|
||||||
"alerts": "Alertas",
|
"alerts": "Alertas",
|
||||||
"connectedGateway": "Gateways ligados",
|
"connectedGateway": "Gateways conectados",
|
||||||
"connectedSwitches": "Switches ligados"
|
"connectedSwitches": "Switches conectados"
|
||||||
},
|
},
|
||||||
"nzbget": {
|
"nzbget": {
|
||||||
"rate": "Taxa",
|
"rate": "Taxa",
|
||||||
@@ -217,8 +217,8 @@
|
|||||||
"memUsage": "Uso de Memória",
|
"memUsage": "Uso de Memória",
|
||||||
"systemTempC": "Temp. do Sistema",
|
"systemTempC": "Temp. do Sistema",
|
||||||
"poolUsage": "Pool Usage",
|
"poolUsage": "Pool Usage",
|
||||||
"volumeUsage": "Volume Usage",
|
"volumeUsage": "Uso do volume",
|
||||||
"invalid": "Invalid"
|
"invalid": "Inválido"
|
||||||
},
|
},
|
||||||
"deluge": {
|
"deluge": {
|
||||||
"download": "Descarregar",
|
"download": "Descarregar",
|
||||||
@@ -250,7 +250,7 @@
|
|||||||
"lidarr": {
|
"lidarr": {
|
||||||
"wanted": "Desejada",
|
"wanted": "Desejada",
|
||||||
"queued": "Em fila",
|
"queued": "Em fila",
|
||||||
"artists": "Artists"
|
"artists": "Artistas"
|
||||||
},
|
},
|
||||||
"readarr": {
|
"readarr": {
|
||||||
"wanted": "Desejada",
|
"wanted": "Desejada",
|
||||||
@@ -279,14 +279,14 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"connected": "Connected",
|
"connected": "Conectado",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Novos dispositivos",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Alertas de Inatividade"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Consultas",
|
"queries": "Consultas",
|
||||||
"blocked": "Bloqueado",
|
"blocked": "Bloqueado",
|
||||||
"blocked_percent": "Blocked %",
|
"blocked_percent": "Bloqueado %",
|
||||||
"gravity": "Gravidade"
|
"gravity": "Gravidade"
|
||||||
},
|
},
|
||||||
"adguard": {
|
"adguard": {
|
||||||
@@ -306,11 +306,11 @@
|
|||||||
"total": "Total"
|
"total": "Total"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Address",
|
"address": "Endereço",
|
||||||
"expires": "Expires",
|
"expires": "Expira em",
|
||||||
"never": "Never",
|
"never": "Nunca",
|
||||||
"last_seen": "Last Seen",
|
"last_seen": "Visto por último",
|
||||||
"now": "Now",
|
"now": "Agora",
|
||||||
"years": "{{number}}y",
|
"years": "{{number}}y",
|
||||||
"weeks": "{{number}}w",
|
"weeks": "{{number}}w",
|
||||||
"days": "{{number}}d",
|
"days": "{{number}}d",
|
||||||
@@ -331,8 +331,8 @@
|
|||||||
"middleware": "Middleware"
|
"middleware": "Middleware"
|
||||||
},
|
},
|
||||||
"navidrome": {
|
"navidrome": {
|
||||||
"nothing_streaming": "Sem streams ativas",
|
"nothing_streaming": "Sem Streams Ativos",
|
||||||
"please_wait": "Por favor aguarde"
|
"please_wait": "Por favor, aguarde"
|
||||||
},
|
},
|
||||||
"npm": {
|
"npm": {
|
||||||
"enabled": "Ativo",
|
"enabled": "Ativo",
|
||||||
@@ -382,7 +382,7 @@
|
|||||||
"players": "Reprodutores",
|
"players": "Reprodutores",
|
||||||
"version": "Versão",
|
"version": "Versão",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"up": "Online",
|
"up": "Disponível",
|
||||||
"down": "Desligado"
|
"down": "Desligado"
|
||||||
},
|
},
|
||||||
"miniflux": {
|
"miniflux": {
|
||||||
@@ -405,20 +405,20 @@
|
|||||||
"load": "Carga",
|
"load": "Carga",
|
||||||
"wait": "Por favor aguarde",
|
"wait": "Por favor aguarde",
|
||||||
"temp": "TEMP",
|
"temp": "TEMP",
|
||||||
"_temp": "Temp",
|
"_temp": "Temperatura",
|
||||||
"warn": "Warn",
|
"warn": "Aviso",
|
||||||
"uptime": "CIMA",
|
"uptime": "CIMA",
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"free": "Livre",
|
"free": "Livre",
|
||||||
"used": "Utilizado",
|
"used": "Utilizado",
|
||||||
"days": "d",
|
"days": "d",
|
||||||
"hours": "h",
|
"hours": "h",
|
||||||
"crit": "Crit",
|
"crit": "Crítico",
|
||||||
"read": "Lido",
|
"read": "Lido",
|
||||||
"write": "Write",
|
"write": "Escrita",
|
||||||
"gpu": "GPU",
|
"gpu": "GPU",
|
||||||
"mem": "Mem",
|
"mem": "Memória",
|
||||||
"swap": "Swap"
|
"swap": "Temporário"
|
||||||
},
|
},
|
||||||
"quicklaunch": {
|
"quicklaunch": {
|
||||||
"bookmark": "Marcador",
|
"bookmark": "Marcador",
|
||||||
@@ -427,7 +427,7 @@
|
|||||||
"custom": "Personalizado",
|
"custom": "Personalizado",
|
||||||
"visit": "Visitar",
|
"visit": "Visitar",
|
||||||
"url": "Endereço URL",
|
"url": "Endereço URL",
|
||||||
"searchsuggestion": "Suggestion"
|
"searchsuggestion": "Sugestão"
|
||||||
},
|
},
|
||||||
"wmo": {
|
"wmo": {
|
||||||
"0-day": "Solarengo",
|
"0-day": "Solarengo",
|
||||||
@@ -544,14 +544,14 @@
|
|||||||
"hdhomerun": {
|
"hdhomerun": {
|
||||||
"channels": "Canais",
|
"channels": "Canais",
|
||||||
"hd": "HD",
|
"hd": "HD",
|
||||||
"tunerCount": "Tuners",
|
"tunerCount": "Sintonizadores",
|
||||||
"channelNumber": "Channel",
|
"channelNumber": "Canal",
|
||||||
"channelNetwork": "Network",
|
"channelNetwork": "Rede",
|
||||||
"signalStrength": "Strength",
|
"signalStrength": "Potência",
|
||||||
"signalQuality": "Quality",
|
"signalQuality": "Qualidade",
|
||||||
"symbolQuality": "Quality",
|
"symbolQuality": "Qualidade",
|
||||||
"networkRate": "Taxa de bits",
|
"networkRate": "Taxa de bits",
|
||||||
"clientIP": "Client"
|
"clientIP": "Cliente"
|
||||||
},
|
},
|
||||||
"scrutiny": {
|
"scrutiny": {
|
||||||
"passed": "Aprovado",
|
"passed": "Aprovado",
|
||||||
@@ -563,15 +563,15 @@
|
|||||||
"total": "Total"
|
"total": "Total"
|
||||||
},
|
},
|
||||||
"peanut": {
|
"peanut": {
|
||||||
"battery_charge": "Battery Charge",
|
"battery_charge": "Carga da bateria",
|
||||||
"ups_load": "UPS Load",
|
"ups_load": "Carga do UPS",
|
||||||
"ups_status": "UPS Status",
|
"ups_status": "Estado UPS",
|
||||||
"online": "Online",
|
"online": "Disponível",
|
||||||
"on_battery": "On Battery",
|
"on_battery": "Na bateria",
|
||||||
"low_battery": "Low Battery"
|
"low_battery": "Bateria Fraca"
|
||||||
},
|
},
|
||||||
"nextdns": {
|
"nextdns": {
|
||||||
"wait": "Por favor aguarde",
|
"wait": "Por favor, aguarde",
|
||||||
"no_devices": "Nenhum dado do dispositivo recebido"
|
"no_devices": "Nenhum dado do dispositivo recebido"
|
||||||
},
|
},
|
||||||
"mikrotik": {
|
"mikrotik": {
|
||||||
@@ -586,10 +586,10 @@
|
|||||||
"streams_xepg": "Canais XEPG"
|
"streams_xepg": "Canais XEPG"
|
||||||
},
|
},
|
||||||
"opendtu": {
|
"opendtu": {
|
||||||
"yieldDay": "Today",
|
"yieldDay": "Hoje",
|
||||||
"absolutePower": "Power",
|
"absolutePower": "Energia",
|
||||||
"relativePower": "Power %",
|
"relativePower": "Energia %",
|
||||||
"limit": "Limit"
|
"limit": "Limite"
|
||||||
},
|
},
|
||||||
"opnsense": {
|
"opnsense": {
|
||||||
"cpu": "Carga do CPU",
|
"cpu": "Carga do CPU",
|
||||||
@@ -614,14 +614,14 @@
|
|||||||
"status": "Estado"
|
"status": "Estado"
|
||||||
},
|
},
|
||||||
"pfsense": {
|
"pfsense": {
|
||||||
"load": "Load Avg",
|
"load": "Carga Média",
|
||||||
"memory": "Mem Usage",
|
"memory": "Uso de memória",
|
||||||
"wanStatus": "WAN Status",
|
"wanStatus": "Estado WAN",
|
||||||
"up": "Ativo",
|
"up": "Ativo",
|
||||||
"down": "Inativo",
|
"down": "Inativo",
|
||||||
"temp": "Temp",
|
"temp": "Temperatura",
|
||||||
"disk": "Disk Usage",
|
"disk": "Uso do disco",
|
||||||
"wanIP": "WAN IP"
|
"wanIP": "IP WAN"
|
||||||
},
|
},
|
||||||
"proxmoxbackupserver": {
|
"proxmoxbackupserver": {
|
||||||
"datastore_usage": "Armaz. de Dados",
|
"datastore_usage": "Armaz. de Dados",
|
||||||
@@ -644,9 +644,9 @@
|
|||||||
},
|
},
|
||||||
"atsumeru": {
|
"atsumeru": {
|
||||||
"series": "Séries",
|
"series": "Séries",
|
||||||
"archives": "Archives",
|
"archives": "Arquivos",
|
||||||
"chapters": "Chapters",
|
"chapters": "Capítulos",
|
||||||
"categories": "Categories"
|
"categories": "Categorias"
|
||||||
},
|
},
|
||||||
"komga": {
|
"komga": {
|
||||||
"libraries": "Bibliotecas",
|
"libraries": "Bibliotecas",
|
||||||
@@ -686,8 +686,8 @@
|
|||||||
"memoryusage": "Memória Utilizada",
|
"memoryusage": "Memória Utilizada",
|
||||||
"freespace": "Espaço Livre",
|
"freespace": "Espaço Livre",
|
||||||
"activeusers": "Utilizadores Ativos",
|
"activeusers": "Utilizadores Ativos",
|
||||||
"numfiles": "Files",
|
"numfiles": "Arquivos",
|
||||||
"numshares": "Shared Items"
|
"numshares": "Itens compartilhados"
|
||||||
},
|
},
|
||||||
"kopia": {
|
"kopia": {
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
@@ -698,7 +698,7 @@
|
|||||||
},
|
},
|
||||||
"unmanic": {
|
"unmanic": {
|
||||||
"active_workers": "Workers Ativos",
|
"active_workers": "Workers Ativos",
|
||||||
"total_workers": "Total Workers",
|
"total_workers": "Total de trabalhadores",
|
||||||
"records_total": "Comprimento da Fila"
|
"records_total": "Comprimento da Fila"
|
||||||
},
|
},
|
||||||
"pterodactyl": {
|
"pterodactyl": {
|
||||||
@@ -716,7 +716,7 @@
|
|||||||
"uptime": "Ligado"
|
"uptime": "Ligado"
|
||||||
},
|
},
|
||||||
"ghostfolio": {
|
"ghostfolio": {
|
||||||
"gross_percent_today": "Today",
|
"gross_percent_today": "Hoje",
|
||||||
"gross_percent_1y": "Um ano",
|
"gross_percent_1y": "Um ano",
|
||||||
"gross_percent_max": "Todo o tempo"
|
"gross_percent_max": "Todo o tempo"
|
||||||
},
|
},
|
||||||
@@ -732,13 +732,13 @@
|
|||||||
"switches_on": "Interruptores Ligados"
|
"switches_on": "Interruptores Ligados"
|
||||||
},
|
},
|
||||||
"whatsupdocker": {
|
"whatsupdocker": {
|
||||||
"monitoring": "Monitoring",
|
"monitoring": "Monitorando",
|
||||||
"updates": "Atualizações"
|
"updates": "Atualizações"
|
||||||
},
|
},
|
||||||
"calibreweb": {
|
"calibreweb": {
|
||||||
"books": "Livros",
|
"books": "Livros",
|
||||||
"authors": "Authors",
|
"authors": "Autores",
|
||||||
"categories": "Categories",
|
"categories": "Categorias",
|
||||||
"series": "Séries"
|
"series": "Séries"
|
||||||
},
|
},
|
||||||
"jdownloader": {
|
"jdownloader": {
|
||||||
@@ -749,47 +749,47 @@
|
|||||||
},
|
},
|
||||||
"kavita": {
|
"kavita": {
|
||||||
"seriesCount": "Séries",
|
"seriesCount": "Séries",
|
||||||
"totalFiles": "Files"
|
"totalFiles": "Arquivos"
|
||||||
},
|
},
|
||||||
"azuredevops": {
|
"azuredevops": {
|
||||||
"result": "Result",
|
"result": "Resultado",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"buildId": "Build ID",
|
"buildId": "ID Compilação",
|
||||||
"succeeded": "Succeeded",
|
"succeeded": "Bem-sucedido",
|
||||||
"notStarted": "Not Started",
|
"notStarted": "Não iniciado",
|
||||||
"failed": "Falhou",
|
"failed": "Falhou",
|
||||||
"canceled": "Canceled",
|
"canceled": "Cancelado",
|
||||||
"inProgress": "In Progress",
|
"inProgress": "Em Progresso",
|
||||||
"totalPrs": "Total PRs",
|
"totalPrs": "Total de PRs",
|
||||||
"myPrs": "My PRs",
|
"myPrs": "Minhas PRs",
|
||||||
"approved": "Aprovada"
|
"approved": "Aprovada"
|
||||||
},
|
},
|
||||||
"gamedig": {
|
"gamedig": {
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"online": "Online",
|
"online": "Disponível",
|
||||||
"offline": "Desligado",
|
"offline": "Desligado",
|
||||||
"name": "Name",
|
"name": "Nome",
|
||||||
"map": "Map",
|
"map": "Mapa",
|
||||||
"currentPlayers": "Current players",
|
"currentPlayers": "Jogadores atuais",
|
||||||
"players": "Reprodutores",
|
"players": "Reprodutores",
|
||||||
"maxPlayers": "Max players",
|
"maxPlayers": "Número Máximo de Jogadores",
|
||||||
"bots": "Bots",
|
"bots": "Robôs",
|
||||||
"ping": "Tempo de resposta"
|
"ping": "Tempo de resposta"
|
||||||
},
|
},
|
||||||
"urbackup": {
|
"urbackup": {
|
||||||
"ok": "Ok",
|
"ok": "Ok",
|
||||||
"errored": "Errors",
|
"errored": "Erros",
|
||||||
"noRecent": "Out of Date",
|
"noRecent": "Desatualizado",
|
||||||
"totalUsed": "Used Storage"
|
"totalUsed": "Armazanamento Utilizado"
|
||||||
},
|
},
|
||||||
"mealie": {
|
"mealie": {
|
||||||
"recipes": "Recipes",
|
"recipes": "Receitas",
|
||||||
"users": "Utilizadores",
|
"users": "Utilizadores",
|
||||||
"categories": "Categories",
|
"categories": "Categorias",
|
||||||
"tags": "Tags"
|
"tags": "Marcadores"
|
||||||
},
|
},
|
||||||
"openmediavault": {
|
"openmediavault": {
|
||||||
"downloading": "Downloading",
|
"downloading": "Baixando",
|
||||||
"total": "Total",
|
"total": "Total",
|
||||||
"running": "A correr",
|
"running": "A correr",
|
||||||
"stopped": "Parado",
|
"stopped": "Parado",
|
||||||
@@ -798,83 +798,95 @@
|
|||||||
},
|
},
|
||||||
"openwrt": {
|
"openwrt": {
|
||||||
"uptime": "Ligado",
|
"uptime": "Ligado",
|
||||||
"cpuLoad": "CPU Load Avg (5m)",
|
"cpuLoad": "Carga da CPU média (5m)",
|
||||||
"up": "Ativo",
|
"up": "Ativo",
|
||||||
"down": "Inativo",
|
"down": "Inativo",
|
||||||
"bytesTx": "Transmitted",
|
"bytesTx": "Transmitido",
|
||||||
"bytesRx": "Recebido"
|
"bytesRx": "Recebido"
|
||||||
},
|
},
|
||||||
"uptimerobot": {
|
"uptimerobot": {
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"uptime": "Ligado",
|
"uptime": "Ligado",
|
||||||
"lastDown": "Last Downtime",
|
"lastDown": "Última inatividade",
|
||||||
"downDuration": "Downtime Duration",
|
"downDuration": "Duração de inatividade",
|
||||||
"sitesUp": "Sites no Ar",
|
"sitesUp": "Sites no Ar",
|
||||||
"sitesDown": "Sites Fora do Ar",
|
"sitesDown": "Sites Fora do Ar",
|
||||||
"paused": "Pausado",
|
"paused": "Pausado",
|
||||||
"notyetchecked": "Not Yet Checked",
|
"notyetchecked": "Não conferidos ainda",
|
||||||
"up": "Ativo",
|
"up": "Ativo",
|
||||||
"seemsdown": "Seems Down",
|
"seemsdown": "Parece Desconectado",
|
||||||
"down": "Inativo",
|
"down": "Inativo",
|
||||||
"unknown": "Desconhecido"
|
"unknown": "Desconhecido"
|
||||||
},
|
},
|
||||||
"calendar": {
|
"calendar": {
|
||||||
"inCinemas": "In cinemas",
|
"inCinemas": "Nos cinemas",
|
||||||
"physicalRelease": "Physical release",
|
"physicalRelease": "Versão física",
|
||||||
"digitalRelease": "Digital release",
|
"digitalRelease": "Versão digital",
|
||||||
"noEventsToday": "No events for today!",
|
"noEventsToday": "Nenhum evento para hoje!",
|
||||||
"noEventsFound": "No events found"
|
"noEventsFound": "Nenhum evento encontrado"
|
||||||
},
|
},
|
||||||
"romm": {
|
"romm": {
|
||||||
"platforms": "Platforms",
|
"platforms": "Plataformas",
|
||||||
"totalRoms": "Total ROMs"
|
"totalRoms": "Total de ROMs"
|
||||||
},
|
},
|
||||||
"netdata": {
|
"netdata": {
|
||||||
"warnings": "Warnings",
|
"warnings": "Alertas",
|
||||||
"criticals": "Criticals"
|
"criticals": "Críticos"
|
||||||
},
|
},
|
||||||
"plantit": {
|
"plantit": {
|
||||||
"events": "Events",
|
"events": "Eventos",
|
||||||
"plants": "Plants",
|
"plants": "Plantas",
|
||||||
"photos": "Fotos",
|
"photos": "Fotos",
|
||||||
"species": "Species"
|
"species": "Espécies"
|
||||||
},
|
},
|
||||||
"gitea": {
|
"gitea": {
|
||||||
"notifications": "Notifications",
|
"notifications": "Notificações",
|
||||||
"issues": "Problemas",
|
"issues": "Problemas",
|
||||||
"pulls": "Pull Requests"
|
"pulls": "Solicitações de Envio"
|
||||||
},
|
},
|
||||||
"stash": {
|
"stash": {
|
||||||
"scenes": "Scenes",
|
"scenes": "Cenas",
|
||||||
"scenesPlayed": "Scenes Played",
|
"scenesPlayed": "Cenas Reproduzidas",
|
||||||
"playCount": "Total Plays",
|
"playCount": "Total de Reproduções",
|
||||||
"playDuration": "Time Watched",
|
"playDuration": "Tempo Assistido",
|
||||||
"sceneSize": "Scenes Size",
|
"sceneSize": "Tamanho das cenas",
|
||||||
"sceneDuration": "Scenes Duration",
|
"sceneDuration": "Duração das cenas",
|
||||||
"images": "Images",
|
"images": "Imagens",
|
||||||
"imageSize": "Images Size",
|
"imageSize": "Tamanho da Imagem",
|
||||||
"galleries": "Galleries",
|
"galleries": "Galerias",
|
||||||
"performers": "Performers",
|
"performers": "Atores",
|
||||||
"studios": "Studios",
|
"studios": "Estúdios",
|
||||||
"movies": "Filmes",
|
"movies": "Filmes",
|
||||||
"tags": "Tags",
|
"tags": "Marcadores",
|
||||||
"oCount": "O Count"
|
"oCount": "Contagem 0"
|
||||||
},
|
},
|
||||||
"tandoor": {
|
"tandoor": {
|
||||||
"users": "Utilizadores",
|
"users": "Utilizadores",
|
||||||
"recipes": "Recipes",
|
"recipes": "Receitas",
|
||||||
"keywords": "Keywords"
|
"keywords": "Palavras-chave"
|
||||||
},
|
},
|
||||||
"homebox": {
|
"homebox": {
|
||||||
"items": "Items",
|
"items": "Itens",
|
||||||
"totalWithWarranty": "With Warranty",
|
"totalWithWarranty": "Com Garantia",
|
||||||
"locations": "Locations",
|
"locations": "Localização",
|
||||||
"labels": "Labels",
|
"labels": "Rótulos",
|
||||||
"users": "Utilizadores",
|
"users": "Utilizadores",
|
||||||
"totalValue": "Total Value"
|
"totalValue": "Valor Total"
|
||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alertas",
|
"alerts": "Alertas",
|
||||||
"bans": "Bans"
|
"bans": "Banimentos"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Conectado",
|
||||||
|
"enabled": "Ativo",
|
||||||
|
"disabled": "Desabilitado",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Activat",
|
||||||
|
"disabled": "Dezactivat",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Ожидает отключения",
|
"connectionStatusPendingDisconnect": "Ожидает отключения",
|
||||||
"connectionStatusDisconnecting": "Отключение",
|
"connectionStatusDisconnecting": "Отключение",
|
||||||
"connectionStatusDisconnected": "Отключено",
|
"connectionStatusDisconnected": "Отключено",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Подключено",
|
||||||
"uptime": "Время работы",
|
"uptime": "Время работы",
|
||||||
"maxDown": "Макс. Загрузка",
|
"maxDown": "Макс. Загрузка",
|
||||||
"maxUp": "Макс. Отдача",
|
"maxUp": "Макс. Отдача",
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Всего",
|
"total": "Всего",
|
||||||
"connected": "Connected",
|
"connected": "Подключено",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Новое устройство",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Оповещение о недоступности"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Запросы",
|
"queries": "Запросы",
|
||||||
@@ -875,6 +875,18 @@
|
|||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Предупреждения",
|
"alerts": "Предупреждения",
|
||||||
"bans": "Bans"
|
"bans": "Запреты"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Подключено",
|
||||||
|
"enabled": "Включено",
|
||||||
|
"disabled": "Выключено",
|
||||||
|
"total": "Всего"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Čakám na odpojenie",
|
"connectionStatusPendingDisconnect": "Čakám na odpojenie",
|
||||||
"connectionStatusDisconnecting": "Odpájanie",
|
"connectionStatusDisconnecting": "Odpájanie",
|
||||||
"connectionStatusDisconnected": "Odpojené",
|
"connectionStatusDisconnected": "Odpojené",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Pripojené",
|
||||||
"uptime": "Prevádzka",
|
"uptime": "Prevádzka",
|
||||||
"maxDown": "Max. sťahovanie",
|
"maxDown": "Max. sťahovanie",
|
||||||
"maxUp": "Max. nahrávanie",
|
"maxUp": "Max. nahrávanie",
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Celkovo",
|
"total": "Celkovo",
|
||||||
"connected": "Connected",
|
"connected": "Pripojené",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Nové zariadenia",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Upozornenia o výpadkoch"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Dopyty",
|
"queries": "Dopyty",
|
||||||
@@ -846,7 +846,7 @@
|
|||||||
},
|
},
|
||||||
"stash": {
|
"stash": {
|
||||||
"scenes": "Scény",
|
"scenes": "Scény",
|
||||||
"scenesPlayed": "Scenes Played",
|
"scenesPlayed": "Prehrané scény",
|
||||||
"playCount": "Celkovo prehraní",
|
"playCount": "Celkovo prehraní",
|
||||||
"playDuration": "Pozeraný čas",
|
"playDuration": "Pozeraný čas",
|
||||||
"sceneSize": "Veľkosť obrazovky",
|
"sceneSize": "Veľkosť obrazovky",
|
||||||
@@ -869,12 +869,24 @@
|
|||||||
"items": "Položky",
|
"items": "Položky",
|
||||||
"totalWithWarranty": "So zárukou",
|
"totalWithWarranty": "So zárukou",
|
||||||
"locations": "Umiestnenia",
|
"locations": "Umiestnenia",
|
||||||
"labels": "Labels",
|
"labels": "Štítky",
|
||||||
"users": "Používatelia",
|
"users": "Používatelia",
|
||||||
"totalValue": "Total Value"
|
"totalValue": "Celková hodnota"
|
||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Upozornenia",
|
"alerts": "Upozornenia",
|
||||||
"bans": "Bans"
|
"bans": "Bany"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Pripojené",
|
||||||
|
"enabled": "Povolené",
|
||||||
|
"disabled": "Zakázané",
|
||||||
|
"total": "Celkovo"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Zastarané",
|
||||||
|
"banned": "Zabanovaný"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -153,7 +153,7 @@
|
|||||||
"caddy": {
|
"caddy": {
|
||||||
"upstreams": "Pretok gor",
|
"upstreams": "Pretok gor",
|
||||||
"requests": "Trenutnih zahtev",
|
"requests": "Trenutnih zahtev",
|
||||||
"requests_failed": "Neuspešnih zahtev"
|
"requests_failed": "Neuspeš. zahtev"
|
||||||
},
|
},
|
||||||
"changedetectionio": {
|
"changedetectionio": {
|
||||||
"totalObserved": "Skupaj opazovano",
|
"totalObserved": "Skupaj opazovano",
|
||||||
@@ -355,8 +355,8 @@
|
|||||||
"enableIndexers": "Indekserji",
|
"enableIndexers": "Indekserji",
|
||||||
"numberOfGrabs": "Zajemi",
|
"numberOfGrabs": "Zajemi",
|
||||||
"numberOfQueries": "Poizvedbe",
|
"numberOfQueries": "Poizvedbe",
|
||||||
"numberOfFailGrabs": "Neuspešni zajemi",
|
"numberOfFailGrabs": "Neuspeš. zajem",
|
||||||
"numberOfFailQueries": "Neuspešne poizvedbe"
|
"numberOfFailQueries": "Neuspeš. poizvedb"
|
||||||
},
|
},
|
||||||
"jackett": {
|
"jackett": {
|
||||||
"configured": "Nastavljeno",
|
"configured": "Nastavljeno",
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Opozorila",
|
"alerts": "Opozorila",
|
||||||
"bans": "Prepovedi"
|
"bans": "Prepovedi"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Povezan",
|
||||||
|
"enabled": "Omogočen",
|
||||||
|
"disabled": "Onemogočen",
|
||||||
|
"total": "Skupaj"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Čez proxi",
|
||||||
|
"auth": "Z Auth",
|
||||||
|
"outdated": "Zastarelo",
|
||||||
|
"banned": "Prepovedan"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Aktiverad",
|
||||||
|
"disabled": "Inaktiverad",
|
||||||
|
"total": "Total"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "ప్రారంభించబడింది",
|
||||||
|
"disabled": "డిసేబ్లెడ్",
|
||||||
|
"total": "మొత్తం"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "ทั้งหมด"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
"seconds": "s"
|
"seconds": "s"
|
||||||
},
|
},
|
||||||
"widget": {
|
"widget": {
|
||||||
"missing_type": "Kayıp Araç Türü: {{type}}",
|
"missing_type": "Eksik Araç Türü: {{type}}",
|
||||||
"api_error": "API Hatası",
|
"api_error": "API Hatası",
|
||||||
"information": "Bilgi",
|
"information": "Bilgi",
|
||||||
"status": "Durum",
|
"status": "Durum",
|
||||||
@@ -42,12 +42,12 @@
|
|||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"mem": "MEM",
|
"mem": "MEM",
|
||||||
"total": "Toplam",
|
"total": "Toplam",
|
||||||
"free": "Boşta",
|
"free": "Boş",
|
||||||
"used": "Kullanımda",
|
"used": "Kullanımda",
|
||||||
"load": "Yük",
|
"load": "Yük",
|
||||||
"temp": "Geçici",
|
"temp": "Sıcaklık",
|
||||||
"max": "En Yüksek",
|
"max": "En Yüksek",
|
||||||
"uptime": "Çalışma Süresi"
|
"uptime": "Çalışıyor"
|
||||||
},
|
},
|
||||||
"unifi": {
|
"unifi": {
|
||||||
"users": "Kullanıcılar",
|
"users": "Kullanıcılar",
|
||||||
@@ -61,7 +61,7 @@
|
|||||||
"wlan_devices": "WLAN Aygıtları",
|
"wlan_devices": "WLAN Aygıtları",
|
||||||
"lan_users": "LAN Kullanıcıları",
|
"lan_users": "LAN Kullanıcıları",
|
||||||
"wlan_users": "WLAN Kullanıcıları",
|
"wlan_users": "WLAN Kullanıcıları",
|
||||||
"up": "Çalışma Süresi",
|
"up": "Çalışıyor",
|
||||||
"down": "Aşağı",
|
"down": "Aşağı",
|
||||||
"wait": "Lütfen bekleyin",
|
"wait": "Lütfen bekleyin",
|
||||||
"empty_data": "Alt sistem durumu bilinmiyor"
|
"empty_data": "Alt sistem durumu bilinmiyor"
|
||||||
@@ -71,15 +71,15 @@
|
|||||||
"tx": "Giden Veri",
|
"tx": "Giden Veri",
|
||||||
"mem": "MEM",
|
"mem": "MEM",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"running": "Çalışan",
|
"running": "Çalışıyor",
|
||||||
"offline": "Çevrimdışı",
|
"offline": "Çevrimdışı",
|
||||||
"error": "Hata",
|
"error": "Hata",
|
||||||
"unknown": "Bilinmiyor",
|
"unknown": "Bilinmiyor",
|
||||||
"healthy": "Sağlık",
|
"healthy": "Sağlıklı",
|
||||||
"starting": "Başlatılıyor",
|
"starting": "Başlatılıyor",
|
||||||
"unhealthy": "Sağlıksız",
|
"unhealthy": "Sağlıksız",
|
||||||
"not_found": "Bulunamadı",
|
"not_found": "Bulunamadı",
|
||||||
"exited": "Durduruldu",
|
"exited": "Kapandı",
|
||||||
"partial": "Parçalı"
|
"partial": "Parçalı"
|
||||||
},
|
},
|
||||||
"ping": {
|
"ping": {
|
||||||
@@ -123,8 +123,8 @@
|
|||||||
"watt_hour": "Watt/Saat"
|
"watt_hour": "Watt/Saat"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"leech": "Tüketici",
|
"leech": "Tüketici",
|
||||||
"seed": "Sağlayıcı"
|
"seed": "Sağlayıcı"
|
||||||
},
|
},
|
||||||
@@ -140,7 +140,7 @@
|
|||||||
"connectionStatusPendingDisconnect": "Bağlantının Kesilmesi Bekleniyor",
|
"connectionStatusPendingDisconnect": "Bağlantının Kesilmesi Bekleniyor",
|
||||||
"connectionStatusDisconnecting": "Bağlantı kesiliyor...",
|
"connectionStatusDisconnecting": "Bağlantı kesiliyor...",
|
||||||
"connectionStatusDisconnected": "Bağlantı kesildi",
|
"connectionStatusDisconnected": "Bağlantı kesildi",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "Bağlandı",
|
||||||
"uptime": "Çalışma Süresi",
|
"uptime": "Çalışma Süresi",
|
||||||
"maxDown": "Max. Indirme",
|
"maxDown": "Max. Indirme",
|
||||||
"maxUp": "Max. Gönderme",
|
"maxUp": "Max. Gönderme",
|
||||||
@@ -197,18 +197,18 @@
|
|||||||
},
|
},
|
||||||
"rutorrent": {
|
"rutorrent": {
|
||||||
"active": "Aktif",
|
"active": "Aktif",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"download": "İndir"
|
"download": "İndirme"
|
||||||
},
|
},
|
||||||
"transmission": {
|
"transmission": {
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"leech": "Tüketici",
|
"leech": "Tüketici",
|
||||||
"seed": "Sağlayıcı"
|
"seed": "Sağlayıcı"
|
||||||
},
|
},
|
||||||
"qbittorrent": {
|
"qbittorrent": {
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"leech": "Tüketici",
|
"leech": "Tüketici",
|
||||||
"seed": "Sağlayıcı"
|
"seed": "Sağlayıcı"
|
||||||
},
|
},
|
||||||
@@ -221,87 +221,87 @@
|
|||||||
"invalid": "Geçersiz"
|
"invalid": "Geçersiz"
|
||||||
},
|
},
|
||||||
"deluge": {
|
"deluge": {
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"leech": "Tüketici",
|
"leech": "Tüketici",
|
||||||
"seed": "Sağlayıcı"
|
"seed": "Sağlayıcı"
|
||||||
},
|
},
|
||||||
"downloadstation": {
|
"downloadstation": {
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"leech": "Tüketici",
|
"leech": "Tüketici",
|
||||||
"seed": "Sağlayıcı"
|
"seed": "Sağlayıcı"
|
||||||
},
|
},
|
||||||
"sonarr": {
|
"sonarr": {
|
||||||
"wanted": "Aranan",
|
"wanted": "İstendi",
|
||||||
"queued": "Kuyrukta",
|
"queued": "Sırada",
|
||||||
"series": "Diziler",
|
"series": "Diziler",
|
||||||
"queue": "Kuyruk",
|
"queue": "Kuyruk",
|
||||||
"unknown": "Bilinmiyor"
|
"unknown": "Bilinmiyor"
|
||||||
},
|
},
|
||||||
"radarr": {
|
"radarr": {
|
||||||
"wanted": "Aranan",
|
"wanted": "İstendi",
|
||||||
"missing": "Kayıp",
|
"missing": "Eksik",
|
||||||
"queued": "Kuyrukta",
|
"queued": "Sırada",
|
||||||
"movies": "Filmler",
|
"movies": "Filmler",
|
||||||
"queue": "Kuyruk",
|
"queue": "Kuyruk",
|
||||||
"unknown": "Bilinmiyor"
|
"unknown": "Bilinmiyor"
|
||||||
},
|
},
|
||||||
"lidarr": {
|
"lidarr": {
|
||||||
"wanted": "Aranan",
|
"wanted": "İstendi",
|
||||||
"queued": "Kuyrukta",
|
"queued": "Sırada",
|
||||||
"artists": "Sanatçılar"
|
"artists": "Sanatçılar"
|
||||||
},
|
},
|
||||||
"readarr": {
|
"readarr": {
|
||||||
"wanted": "Aranan",
|
"wanted": "İstendi",
|
||||||
"queued": "Kuyrukta",
|
"queued": "Sırada",
|
||||||
"books": "Kitaplar"
|
"books": "Kitaplar"
|
||||||
},
|
},
|
||||||
"bazarr": {
|
"bazarr": {
|
||||||
"missingEpisodes": "Kayıp Bölümler",
|
"missingEpisodes": "Eksik Bölümler",
|
||||||
"missingMovies": "Kayıp Filmler"
|
"missingMovies": "Eksik Filmler"
|
||||||
},
|
},
|
||||||
"ombi": {
|
"ombi": {
|
||||||
"pending": "Bekliyor",
|
"pending": "Bekleyen",
|
||||||
"approved": "Onaylı",
|
"approved": "Onaylı",
|
||||||
"available": "Kullanılabilir"
|
"available": "Kullanılabilir"
|
||||||
},
|
},
|
||||||
"jellyseerr": {
|
"jellyseerr": {
|
||||||
"pending": "Bekliyor",
|
"pending": "Bekleyen",
|
||||||
"approved": "Onaylı",
|
"approved": "Onaylı",
|
||||||
"available": "Kullanılabilir"
|
"available": "Kullanılabilir"
|
||||||
},
|
},
|
||||||
"overseerr": {
|
"overseerr": {
|
||||||
"pending": "Bekliyor",
|
"pending": "Bekleyen",
|
||||||
"processing": "İşleniyor",
|
"processing": "İşleniyor",
|
||||||
"approved": "Onaylı",
|
"approved": "Onaylı",
|
||||||
"available": "Kullanılabilir"
|
"available": "Kullanılabilir"
|
||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "Toplam",
|
"total": "Toplam",
|
||||||
"connected": "Connected",
|
"connected": "Bağlandı",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "Yeni Cihazlar",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "Hata Uyarıları"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "Sorgular",
|
"queries": "Sorgular",
|
||||||
"blocked": "Engellenen",
|
"blocked": "Engellenen",
|
||||||
"blocked_percent": "Engellenen %",
|
"blocked_percent": "Engellenen %",
|
||||||
"gravity": "Yer Çekimi"
|
"gravity": "Gravity"
|
||||||
},
|
},
|
||||||
"adguard": {
|
"adguard": {
|
||||||
"queries": "Sorgular",
|
"queries": "Sorgular",
|
||||||
"blocked": "Engellenen",
|
"blocked": "Engellenen",
|
||||||
"filtered": "Filtrelenen",
|
"filtered": "Filtrelendi",
|
||||||
"latency": "Gecikme"
|
"latency": "Gecikme"
|
||||||
},
|
},
|
||||||
"speedtest": {
|
"speedtest": {
|
||||||
"upload": "Yükle",
|
"upload": "Yükleme",
|
||||||
"download": "İndir",
|
"download": "İndirme",
|
||||||
"ping": "Gecikme"
|
"ping": "Gecikme"
|
||||||
},
|
},
|
||||||
"portainer": {
|
"portainer": {
|
||||||
"running": "Çalışan",
|
"running": "Çalışıyor",
|
||||||
"stopped": "Durduruldu",
|
"stopped": "Durduruldu",
|
||||||
"total": "Toplam"
|
"total": "Toplam"
|
||||||
},
|
},
|
||||||
@@ -353,10 +353,10 @@
|
|||||||
},
|
},
|
||||||
"prowlarr": {
|
"prowlarr": {
|
||||||
"enableIndexers": "Dizin Oluşturucular",
|
"enableIndexers": "Dizin Oluşturucular",
|
||||||
"numberOfGrabs": "Yakalama Sayısı",
|
"numberOfGrabs": "Yakalamalar",
|
||||||
"numberOfQueries": "Sorgular",
|
"numberOfQueries": "Sorgular",
|
||||||
"numberOfFailGrabs": "Başarısız Yakalama Sayısı",
|
"numberOfFailGrabs": "Başarısız Yakalamalar",
|
||||||
"numberOfFailQueries": "Başarısız Sorgu Sayısı"
|
"numberOfFailQueries": "Başarısız Sorgular"
|
||||||
},
|
},
|
||||||
"jackett": {
|
"jackett": {
|
||||||
"configured": "Yapılandırılmış",
|
"configured": "Yapılandırılmış",
|
||||||
@@ -374,8 +374,8 @@
|
|||||||
"domain_count": "Etki Alanları"
|
"domain_count": "Etki Alanları"
|
||||||
},
|
},
|
||||||
"medusa": {
|
"medusa": {
|
||||||
"wanted": "Aranan",
|
"wanted": "İstendi",
|
||||||
"queued": "Kuyrukta",
|
"queued": "Sırada",
|
||||||
"series": "Diziler"
|
"series": "Diziler"
|
||||||
},
|
},
|
||||||
"minecraft": {
|
"minecraft": {
|
||||||
@@ -386,7 +386,7 @@
|
|||||||
"down": "Çevrimdışı"
|
"down": "Çevrimdışı"
|
||||||
},
|
},
|
||||||
"miniflux": {
|
"miniflux": {
|
||||||
"read": "Oku",
|
"read": "Okunan",
|
||||||
"unread": "Okunmamış"
|
"unread": "Okunmamış"
|
||||||
},
|
},
|
||||||
"authentik": {
|
"authentik": {
|
||||||
@@ -404,17 +404,17 @@
|
|||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"load": "Yük",
|
"load": "Yük",
|
||||||
"wait": "Lütfen bekleyin",
|
"wait": "Lütfen bekleyin",
|
||||||
"temp": "Geçici",
|
"temp": "Sıcaklık",
|
||||||
"_temp": "Sıcaklık",
|
"_temp": "Sıcaklık",
|
||||||
"warn": "Uyarı",
|
"warn": "Uyarı",
|
||||||
"uptime": "Çalışma Süresi",
|
"uptime": "Çalışıyor",
|
||||||
"total": "Toplam",
|
"total": "Toplam",
|
||||||
"free": "Boşta",
|
"free": "Boş",
|
||||||
"used": "Kullanımda",
|
"used": "Kullanımda",
|
||||||
"days": "g",
|
"days": "g",
|
||||||
"hours": "sa",
|
"hours": "sa",
|
||||||
"crit": "Kritik",
|
"crit": "Kritik",
|
||||||
"read": "Oku",
|
"read": "Okunan",
|
||||||
"write": "Yazma",
|
"write": "Yazma",
|
||||||
"gpu": "GPU",
|
"gpu": "GPU",
|
||||||
"mem": "Hafıza",
|
"mem": "Hafıza",
|
||||||
@@ -495,7 +495,7 @@
|
|||||||
"child_bridges": "Alt Köprüler",
|
"child_bridges": "Alt Köprüler",
|
||||||
"child_bridges_status": "{{ok}}/{{total}}",
|
"child_bridges_status": "{{ok}}/{{total}}",
|
||||||
"up": "Yükleme",
|
"up": "Yükleme",
|
||||||
"pending": "Bekliyor",
|
"pending": "Bekleyen",
|
||||||
"down": "İndirme"
|
"down": "İndirme"
|
||||||
},
|
},
|
||||||
"healthchecks": {
|
"healthchecks": {
|
||||||
@@ -503,7 +503,7 @@
|
|||||||
"up": "Yükleme",
|
"up": "Yükleme",
|
||||||
"grace": "Tolerans Döneminde",
|
"grace": "Tolerans Döneminde",
|
||||||
"down": "İndirme",
|
"down": "İndirme",
|
||||||
"paused": "Durduruldu",
|
"paused": "Duraklatıldı",
|
||||||
"status": "Durum",
|
"status": "Durum",
|
||||||
"last_ping": "Son Ping",
|
"last_ping": "Son Ping",
|
||||||
"never": "Henüz ping yok"
|
"never": "Henüz ping yok"
|
||||||
@@ -636,8 +636,8 @@
|
|||||||
"storage": "Depo"
|
"storage": "Depo"
|
||||||
},
|
},
|
||||||
"uptimekuma": {
|
"uptimekuma": {
|
||||||
"up": "Sites Up",
|
"up": "Siteler Çalışıyor",
|
||||||
"down": "Sites Down",
|
"down": "Siteler Çalışmıyor",
|
||||||
"uptime": "Çalışma Süresi",
|
"uptime": "Çalışma Süresi",
|
||||||
"incident": "Olay",
|
"incident": "Olay",
|
||||||
"m": "dk"
|
"m": "dk"
|
||||||
@@ -661,7 +661,7 @@
|
|||||||
"mylar": {
|
"mylar": {
|
||||||
"series": "Diziler",
|
"series": "Diziler",
|
||||||
"issues": "Sorunlar",
|
"issues": "Sorunlar",
|
||||||
"wanted": "Aranan"
|
"wanted": "İstendi"
|
||||||
},
|
},
|
||||||
"photoprism": {
|
"photoprism": {
|
||||||
"albums": "Albümler",
|
"albums": "Albümler",
|
||||||
@@ -706,13 +706,13 @@
|
|||||||
"nodes": "Düğümler"
|
"nodes": "Düğümler"
|
||||||
},
|
},
|
||||||
"prometheus": {
|
"prometheus": {
|
||||||
"targets_up": "Targets Up",
|
"targets_up": "Hedef Çalışıyor",
|
||||||
"targets_down": "Targets Down",
|
"targets_down": "Hedef Çalışmıyor",
|
||||||
"targets_total": "Toplam Hedef"
|
"targets_total": "Toplam Hedef"
|
||||||
},
|
},
|
||||||
"gatus": {
|
"gatus": {
|
||||||
"up": "Sites Up",
|
"up": "Siteler Çalışıyor",
|
||||||
"down": "Sites Down",
|
"down": "Siteler Çalışmıyor",
|
||||||
"uptime": "Çalışma Süresi"
|
"uptime": "Çalışma Süresi"
|
||||||
},
|
},
|
||||||
"ghostfolio": {
|
"ghostfolio": {
|
||||||
@@ -727,7 +727,7 @@
|
|||||||
"booksDuration": "Süre"
|
"booksDuration": "Süre"
|
||||||
},
|
},
|
||||||
"homeassistant": {
|
"homeassistant": {
|
||||||
"people_home": "People Home",
|
"people_home": "Evdeki İnsanlar",
|
||||||
"lights_on": "Işıklar Açık",
|
"lights_on": "Işıklar Açık",
|
||||||
"switches_on": "Aç"
|
"switches_on": "Aç"
|
||||||
},
|
},
|
||||||
@@ -754,14 +754,14 @@
|
|||||||
"azuredevops": {
|
"azuredevops": {
|
||||||
"result": "Sonuç",
|
"result": "Sonuç",
|
||||||
"status": "Durum",
|
"status": "Durum",
|
||||||
"buildId": "Build ID",
|
"buildId": "Yapı Kimliği",
|
||||||
"succeeded": "Başarılı",
|
"succeeded": "Başarılı",
|
||||||
"notStarted": "Henüz Başlamadı",
|
"notStarted": "Henüz Başlamadı",
|
||||||
"failed": "Başarısız",
|
"failed": "Başarısız",
|
||||||
"canceled": "İptal edildi",
|
"canceled": "İptal edildi",
|
||||||
"inProgress": "Sürüyor",
|
"inProgress": "Sürüyor",
|
||||||
"totalPrs": "Total PRs",
|
"totalPrs": "Toplam Çekme İstekleri",
|
||||||
"myPrs": "My PRs",
|
"myPrs": "Benim Çekme İsteklerim",
|
||||||
"approved": "Onaylı"
|
"approved": "Onaylı"
|
||||||
},
|
},
|
||||||
"gamedig": {
|
"gamedig": {
|
||||||
@@ -791,7 +791,7 @@
|
|||||||
"openmediavault": {
|
"openmediavault": {
|
||||||
"downloading": "İndiriliyor",
|
"downloading": "İndiriliyor",
|
||||||
"total": "Toplam",
|
"total": "Toplam",
|
||||||
"running": "Çalışan",
|
"running": "Çalışıyor",
|
||||||
"stopped": "Durduruldu",
|
"stopped": "Durduruldu",
|
||||||
"passed": "Geçti",
|
"passed": "Geçti",
|
||||||
"failed": "Başarısız"
|
"failed": "Başarısız"
|
||||||
@@ -809,9 +809,9 @@
|
|||||||
"uptime": "Çalışma Süresi",
|
"uptime": "Çalışma Süresi",
|
||||||
"lastDown": "Son Kesinti",
|
"lastDown": "Son Kesinti",
|
||||||
"downDuration": "Kesinti Süresi",
|
"downDuration": "Kesinti Süresi",
|
||||||
"sitesUp": "Sites Up",
|
"sitesUp": "Siteler Çalışıyor",
|
||||||
"sitesDown": "Sites Down",
|
"sitesDown": "Siteler Çalışmıyor",
|
||||||
"paused": "Durduruldu",
|
"paused": "Duraklatıldı",
|
||||||
"notyetchecked": "Henüz Kontrol Edilmedi",
|
"notyetchecked": "Henüz Kontrol Edilmedi",
|
||||||
"up": "Yükleme",
|
"up": "Yükleme",
|
||||||
"seemsdown": "Kapalı görünüyor",
|
"seemsdown": "Kapalı görünüyor",
|
||||||
@@ -821,7 +821,7 @@
|
|||||||
"calendar": {
|
"calendar": {
|
||||||
"inCinemas": "Sinemalarda",
|
"inCinemas": "Sinemalarda",
|
||||||
"physicalRelease": "Fiziksel Yayınlanan",
|
"physicalRelease": "Fiziksel Yayınlanan",
|
||||||
"digitalRelease": "Dijital Yayınlanan",
|
"digitalRelease": "Dijitalde Yayınlandı",
|
||||||
"noEventsToday": "Bugün için etkinlik yok!",
|
"noEventsToday": "Bugün için etkinlik yok!",
|
||||||
"noEventsFound": "Etkinlik bulunamadı"
|
"noEventsFound": "Etkinlik bulunamadı"
|
||||||
},
|
},
|
||||||
@@ -835,7 +835,7 @@
|
|||||||
},
|
},
|
||||||
"plantit": {
|
"plantit": {
|
||||||
"events": "Etkinlikler",
|
"events": "Etkinlikler",
|
||||||
"plants": "Plants",
|
"plants": "Bitkiler",
|
||||||
"photos": "Fotoğraflar",
|
"photos": "Fotoğraflar",
|
||||||
"species": "Türler"
|
"species": "Türler"
|
||||||
},
|
},
|
||||||
@@ -854,11 +854,11 @@
|
|||||||
"images": "Görseller",
|
"images": "Görseller",
|
||||||
"imageSize": "Görsel Boyutu",
|
"imageSize": "Görsel Boyutu",
|
||||||
"galleries": "Galeriler",
|
"galleries": "Galeriler",
|
||||||
"performers": "Performers",
|
"performers": "Oyuncu",
|
||||||
"studios": "Stüdyolar",
|
"studios": "Stüdyolar",
|
||||||
"movies": "Filmler",
|
"movies": "Filmler",
|
||||||
"tags": "Etiketler",
|
"tags": "Etiketler",
|
||||||
"oCount": "O Count"
|
"oCount": "O Sayısı"
|
||||||
},
|
},
|
||||||
"tandoor": {
|
"tandoor": {
|
||||||
"users": "Kullanıcılar",
|
"users": "Kullanıcılar",
|
||||||
@@ -875,6 +875,18 @@
|
|||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alarmlar",
|
"alerts": "Alarmlar",
|
||||||
"bans": "Bans"
|
"bans": "Yasaklar"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Bağlandı",
|
||||||
|
"enabled": "Etkin",
|
||||||
|
"disabled": "Devre Dışı",
|
||||||
|
"total": "Toplam"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Оповіщення",
|
"alerts": "Оповіщення",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Увімкнено",
|
||||||
|
"disabled": "Вимкнено",
|
||||||
|
"total": "Усього"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Alerts",
|
"alerts": "Alerts",
|
||||||
"bans": "Bans"
|
"bans": "Bans"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "Enabled",
|
||||||
|
"disabled": "Disabled",
|
||||||
|
"total": "Tổng"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "警示",
|
"alerts": "警示",
|
||||||
"bans": "禁止"
|
"bans": "禁止"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "啟用",
|
||||||
|
"disabled": "停用咗",
|
||||||
|
"total": "全部"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,10 +54,10 @@
|
|||||||
"uptime": "运行时间",
|
"uptime": "运行时间",
|
||||||
"days": "天",
|
"days": "天",
|
||||||
"wan": "WAN",
|
"wan": "WAN",
|
||||||
"lan": "局域网",
|
"lan": "LAN",
|
||||||
"wlan": "无线局域网",
|
"wlan": "WLAN",
|
||||||
"devices": "设备",
|
"devices": "设备",
|
||||||
"lan_devices": "有线设备",
|
"lan_devices": "LAN 设备",
|
||||||
"wlan_devices": "WLAN 设备",
|
"wlan_devices": "WLAN 设备",
|
||||||
"lan_users": "有线用户",
|
"lan_users": "有线用户",
|
||||||
"wlan_users": "无线用户",
|
"wlan_users": "无线用户",
|
||||||
@@ -140,13 +140,13 @@
|
|||||||
"connectionStatusPendingDisconnect": "等待断开连接",
|
"connectionStatusPendingDisconnect": "等待断开连接",
|
||||||
"connectionStatusDisconnecting": "正在断开连接",
|
"connectionStatusDisconnecting": "正在断开连接",
|
||||||
"connectionStatusDisconnected": "未连接",
|
"connectionStatusDisconnected": "未连接",
|
||||||
"connectionStatusConnected": "Connected",
|
"connectionStatusConnected": "已连接",
|
||||||
"uptime": "运行时间",
|
"uptime": "运行时间",
|
||||||
"maxDown": "最大下载速度",
|
"maxDown": "最大下载速度",
|
||||||
"maxUp": "",
|
"maxUp": "",
|
||||||
"down": "离线",
|
"down": "离线",
|
||||||
"up": "在线",
|
"up": "在线",
|
||||||
"received": "最大上传数",
|
"received": "已接收",
|
||||||
"sent": "已发送",
|
"sent": "已发送",
|
||||||
"externalIPAddress": "外部IP"
|
"externalIPAddress": "外部IP"
|
||||||
},
|
},
|
||||||
@@ -234,7 +234,7 @@
|
|||||||
},
|
},
|
||||||
"sonarr": {
|
"sonarr": {
|
||||||
"wanted": "关注中",
|
"wanted": "关注中",
|
||||||
"queued": "已加入队列",
|
"queued": "队列中",
|
||||||
"series": "剧集",
|
"series": "剧集",
|
||||||
"queue": "队列",
|
"queue": "队列",
|
||||||
"unknown": "未知"
|
"unknown": "未知"
|
||||||
@@ -242,19 +242,19 @@
|
|||||||
"radarr": {
|
"radarr": {
|
||||||
"wanted": "关注中",
|
"wanted": "关注中",
|
||||||
"missing": "缺失",
|
"missing": "缺失",
|
||||||
"queued": "已加入队列",
|
"queued": "队列中",
|
||||||
"movies": "电影",
|
"movies": "电影",
|
||||||
"queue": "队列",
|
"queue": "队列",
|
||||||
"unknown": "未知"
|
"unknown": "未知"
|
||||||
},
|
},
|
||||||
"lidarr": {
|
"lidarr": {
|
||||||
"wanted": "关注中",
|
"wanted": "关注中",
|
||||||
"queued": "已加入队列",
|
"queued": "队列中",
|
||||||
"artists": "艺术家"
|
"artists": "艺术家"
|
||||||
},
|
},
|
||||||
"readarr": {
|
"readarr": {
|
||||||
"wanted": "关注中",
|
"wanted": "关注中",
|
||||||
"queued": "已加入队列",
|
"queued": "队列中",
|
||||||
"books": "书籍"
|
"books": "书籍"
|
||||||
},
|
},
|
||||||
"bazarr": {
|
"bazarr": {
|
||||||
@@ -279,9 +279,9 @@
|
|||||||
},
|
},
|
||||||
"netalertx": {
|
"netalertx": {
|
||||||
"total": "总计",
|
"total": "总计",
|
||||||
"connected": "Connected",
|
"connected": "已连接",
|
||||||
"new_devices": "New Devices",
|
"new_devices": "新设备",
|
||||||
"down_alerts": "Down Alerts"
|
"down_alerts": "离线警报"
|
||||||
},
|
},
|
||||||
"pihole": {
|
"pihole": {
|
||||||
"queries": "查询",
|
"queries": "查询",
|
||||||
@@ -375,7 +375,7 @@
|
|||||||
},
|
},
|
||||||
"medusa": {
|
"medusa": {
|
||||||
"wanted": "关注中",
|
"wanted": "关注中",
|
||||||
"queued": "已加入队列",
|
"queued": "队列中",
|
||||||
"series": "剧集"
|
"series": "剧集"
|
||||||
},
|
},
|
||||||
"minecraft": {
|
"minecraft": {
|
||||||
@@ -802,7 +802,7 @@
|
|||||||
"up": "在线",
|
"up": "在线",
|
||||||
"down": "离线",
|
"down": "离线",
|
||||||
"bytesTx": "已传输",
|
"bytesTx": "已传输",
|
||||||
"bytesRx": "最大上传数"
|
"bytesRx": "已接收"
|
||||||
},
|
},
|
||||||
"uptimerobot": {
|
"uptimerobot": {
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "警告",
|
"alerts": "警告",
|
||||||
"bans": "禁用"
|
"bans": "禁用"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "已连接",
|
||||||
|
"enabled": "启用",
|
||||||
|
"disabled": "禁用",
|
||||||
|
"total": "总计"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "已代理",
|
||||||
|
"auth": "使用认证",
|
||||||
|
"outdated": "已过期",
|
||||||
|
"banned": "已禁止"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -876,5 +876,17 @@
|
|||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "警示",
|
"alerts": "警示",
|
||||||
"bans": "禁止"
|
"bans": "禁止"
|
||||||
|
},
|
||||||
|
"wgeasy": {
|
||||||
|
"connected": "Connected",
|
||||||
|
"enabled": "已啟用",
|
||||||
|
"disabled": "已停用",
|
||||||
|
"total": "全部"
|
||||||
|
},
|
||||||
|
"swagdashboard": {
|
||||||
|
"proxied": "Proxied",
|
||||||
|
"auth": "With Auth",
|
||||||
|
"outdated": "Outdated",
|
||||||
|
"banned": "Banned"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,26 +1,18 @@
|
|||||||
import { useTranslation } from "react-i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
import { useEffect, useState, useRef, useCallback, useContext } from "react";
|
import { useEffect, useState, useRef, useCallback, useContext } from "react";
|
||||||
import classNames from "classnames";
|
import classNames from "classnames";
|
||||||
|
import useSWR from "swr";
|
||||||
|
|
||||||
import ResolvedIcon from "./resolvedicon";
|
import ResolvedIcon from "./resolvedicon";
|
||||||
|
import { getStoredProvider, searchProviders } from "./widgets/search/search";
|
||||||
|
|
||||||
import { SettingsContext } from "utils/contexts/settings";
|
import { SettingsContext } from "utils/contexts/settings";
|
||||||
|
|
||||||
export default function QuickLaunch({
|
export default function QuickLaunch({ servicesAndBookmarks, searchString, setSearchString, isOpen, close }) {
|
||||||
servicesAndBookmarks,
|
|
||||||
searchString,
|
|
||||||
setSearchString,
|
|
||||||
isOpen,
|
|
||||||
close,
|
|
||||||
searchProvider,
|
|
||||||
}) {
|
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
const { settings } = useContext(SettingsContext);
|
const { settings } = useContext(SettingsContext);
|
||||||
const { searchDescriptions = false, hideVisitURL = false } = settings?.quicklaunch ?? {};
|
const { searchDescriptions = false, hideVisitURL = false } = settings?.quicklaunch ?? {};
|
||||||
const showSearchSuggestions = !!(
|
|
||||||
settings?.quicklaunch?.showSearchSuggestions ?? searchProvider?.showSearchSuggestions
|
|
||||||
);
|
|
||||||
|
|
||||||
const searchField = useRef();
|
const searchField = useRef();
|
||||||
|
|
||||||
@@ -29,9 +21,42 @@ export default function QuickLaunch({
|
|||||||
const [url, setUrl] = useState(null);
|
const [url, setUrl] = useState(null);
|
||||||
const [searchSuggestions, setSearchSuggestions] = useState([]);
|
const [searchSuggestions, setSearchSuggestions] = useState([]);
|
||||||
|
|
||||||
|
const { data: widgets } = useSWR("/api/widgets");
|
||||||
|
const searchWidget = Object.values(widgets).find((w) => w.type === "search");
|
||||||
|
|
||||||
|
let searchProvider;
|
||||||
|
|
||||||
|
if (settings?.quicklaunch?.provider === "custom" && settings?.quicklaunch?.url?.length > 0) {
|
||||||
|
searchProvider = settings.quicklaunch;
|
||||||
|
} else if (settings?.quicklaunch?.provider && settings?.quicklaunch?.provider !== "custom") {
|
||||||
|
searchProvider = searchProviders[settings.quicklaunch.provider];
|
||||||
|
} else if (searchWidget) {
|
||||||
|
// If there is no search provider in quick launch settings, try to get it from the search widget
|
||||||
|
if (Array.isArray(searchWidget.options?.provider)) {
|
||||||
|
// If search provider is a list, try to retrieve from localstorage, fall back to the first
|
||||||
|
searchProvider = getStoredProvider() ?? searchProviders[searchWidget.options.provider[0]];
|
||||||
|
} else if (searchWidget.options?.provider === "custom") {
|
||||||
|
searchProvider = searchWidget.options;
|
||||||
|
} else {
|
||||||
|
searchProvider = searchProviders[searchWidget.options?.provider];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (searchProvider) {
|
||||||
|
searchProvider.showSearchSuggestions = !!(
|
||||||
|
settings?.quicklaunch?.showSearchSuggestions ??
|
||||||
|
searchWidget?.options?.showSearchSuggestions ??
|
||||||
|
false
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
function openCurrentItem(newWindow) {
|
function openCurrentItem(newWindow) {
|
||||||
const result = results[currentItemIndex];
|
const result = results[currentItemIndex];
|
||||||
window.open(result.href, newWindow ? "_blank" : result.target ?? settings.target ?? "_blank", "noreferrer");
|
window.open(
|
||||||
|
result.href,
|
||||||
|
newWindow ? "_blank" : result.target ?? searchProvider?.target ?? settings.target ?? "_blank",
|
||||||
|
"noreferrer",
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const closeAndReset = useCallback(() => {
|
const closeAndReset = useCallback(() => {
|
||||||
@@ -119,7 +144,7 @@ export default function QuickLaunch({
|
|||||||
type: "search",
|
type: "search",
|
||||||
});
|
});
|
||||||
|
|
||||||
if (showSearchSuggestions && searchProvider.suggestionUrl) {
|
if (searchProvider.showSearchSuggestions && searchProvider.suggestionUrl) {
|
||||||
if (searchString.trim() !== searchSuggestions[0]?.trim()) {
|
if (searchString.trim() !== searchSuggestions[0]?.trim()) {
|
||||||
fetch(
|
fetch(
|
||||||
`/api/search/searchSuggestion?query=${encodeURIComponent(searchString)}&providerName=${
|
`/api/search/searchSuggestion?query=${encodeURIComponent(searchString)}&providerName=${
|
||||||
@@ -172,17 +197,7 @@ export default function QuickLaunch({
|
|||||||
return () => {
|
return () => {
|
||||||
abortController.abort();
|
abortController.abort();
|
||||||
};
|
};
|
||||||
}, [
|
}, [searchString, servicesAndBookmarks, searchDescriptions, hideVisitURL, searchSuggestions, searchProvider, url, t]);
|
||||||
searchString,
|
|
||||||
servicesAndBookmarks,
|
|
||||||
searchDescriptions,
|
|
||||||
hideVisitURL,
|
|
||||||
showSearchSuggestions,
|
|
||||||
searchSuggestions,
|
|
||||||
searchProvider,
|
|
||||||
url,
|
|
||||||
t,
|
|
||||||
]);
|
|
||||||
|
|
||||||
const [hidden, setHidden] = useState(true);
|
const [hidden, setHidden] = useState(true);
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
import { useTranslation } from "next-i18next";
|
import { useTranslation } from "next-i18next";
|
||||||
import { FaThermometerHalf } from "react-icons/fa";
|
import { FiHardDrive } from "react-icons/fi";
|
||||||
|
|
||||||
import Resource from "../widget/resource";
|
import Resource from "../widget/resource";
|
||||||
import WidgetLabel from "../widget/widget_label";
|
import WidgetLabel from "../widget/widget_label";
|
||||||
@@ -10,7 +10,7 @@ export default function Node({ data, expanded, labels }) {
|
|||||||
return (
|
return (
|
||||||
<Resource
|
<Resource
|
||||||
additionalClassNames="information-widget-longhorn-node"
|
additionalClassNames="information-widget-longhorn-node"
|
||||||
icon={FaThermometerHalf}
|
icon={FiHardDrive}
|
||||||
value={t("common.bytes", { value: data.node.available })}
|
value={t("common.bytes", { value: data.node.available })}
|
||||||
label={t("resources.free")}
|
label={t("resources.free")}
|
||||||
expandedValue={t("common.bytes", { value: data.node.maximum })}
|
expandedValue={t("common.bytes", { value: data.node.maximum })}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ function convertToFahrenheit(t) {
|
|||||||
return (t * 9) / 5 + 32;
|
return (t * 9) / 5 + 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function CpuTemp({ expanded, units, refresh = 1500 }) {
|
export default function CpuTemp({ expanded, units, refresh = 1500, tempmin = 0, tempmax = -1 }) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
const { data, error } = useSWR(`/api/widgets/resources?type=cputemp`, {
|
const { data, error } = useSWR(`/api/widgets/resources?type=cputemp`, {
|
||||||
@@ -39,7 +39,12 @@ export default function CpuTemp({ expanded, units, refresh = 1500 }) {
|
|||||||
}
|
}
|
||||||
const unit = units === "imperial" ? "fahrenheit" : "celsius";
|
const unit = units === "imperial" ? "fahrenheit" : "celsius";
|
||||||
mainTemp = unit === "celsius" ? mainTemp : convertToFahrenheit(mainTemp);
|
mainTemp = unit === "celsius" ? mainTemp : convertToFahrenheit(mainTemp);
|
||||||
const maxTemp = unit === "celsius" ? data.cputemp.max : convertToFahrenheit(data.cputemp.max);
|
|
||||||
|
const minTemp = tempmin < mainTemp ? tempmin : mainTemp;
|
||||||
|
let maxTemp = tempmax;
|
||||||
|
if (maxTemp < minTemp) {
|
||||||
|
maxTemp = unit === "celsius" ? data.cputemp.max : convertToFahrenheit(data.cputemp.max);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Resource
|
<Resource
|
||||||
@@ -58,7 +63,7 @@ export default function CpuTemp({ expanded, units, refresh = 1500 }) {
|
|||||||
unit,
|
unit,
|
||||||
})}
|
})}
|
||||||
expandedLabel={t("resources.max")}
|
expandedLabel={t("resources.max")}
|
||||||
percentage={Math.round((mainTemp / maxTemp) * 100)}
|
percentage={Math.round(((mainTemp - minTemp) / (maxTemp - minTemp)) * 100)}
|
||||||
expanded={expanded}
|
expanded={expanded}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import CpuTemp from "./cputemp";
|
|||||||
import Uptime from "./uptime";
|
import Uptime from "./uptime";
|
||||||
|
|
||||||
export default function Resources({ options }) {
|
export default function Resources({ options }) {
|
||||||
const { expanded, units, diskUnits } = options;
|
const { expanded, units, diskUnits, tempmin, tempmax } = options;
|
||||||
let { refresh } = options;
|
let { refresh } = options;
|
||||||
if (!refresh) refresh = 1500;
|
if (!refresh) refresh = 1500;
|
||||||
refresh = Math.max(refresh, 1000);
|
refresh = Math.max(refresh, 1000);
|
||||||
@@ -23,7 +23,9 @@ export default function Resources({ options }) {
|
|||||||
<Disk key={disk} options={{ disk }} expanded={expanded} diskUnits={diskUnits} refresh={refresh} />
|
<Disk key={disk} options={{ disk }} expanded={expanded} diskUnits={diskUnits} refresh={refresh} />
|
||||||
))
|
))
|
||||||
: options.disk && <Disk options={options} expanded={expanded} diskUnits={diskUnits} refresh={refresh} />}
|
: options.disk && <Disk options={options} expanded={expanded} diskUnits={diskUnits} refresh={refresh} />}
|
||||||
{options.cputemp && <CpuTemp expanded={expanded} units={units} refresh={refresh} />}
|
{options.cputemp && (
|
||||||
|
<CpuTemp expanded={expanded} units={units} refresh={refresh} tempmin={tempmin} tempmax={tempmax} />
|
||||||
|
)}
|
||||||
{options.uptime && <Uptime refresh={refresh} />}
|
{options.uptime && <Uptime refresh={refresh} />}
|
||||||
</div>
|
</div>
|
||||||
{options.label && (
|
{options.label && (
|
||||||
|
|||||||
@@ -14,8 +14,8 @@ import useWidgetAPI from "utils/proxy/use-widget-api";
|
|||||||
export default function Widget({ options }) {
|
export default function Widget({ options }) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
// eslint-disable-next-line no-param-reassign, no-multi-assign
|
||||||
options.type = "unifi_console";
|
options.service_group = options.service_name = "unifi_console";
|
||||||
const { data: statsData, error: statsError } = useWidgetAPI(options, "stat/sites", { index: options.index });
|
const { data: statsData, error: statsError } = useWidgetAPI(options, "stat/sites", { index: options.index });
|
||||||
|
|
||||||
if (statsError) {
|
if (statsError) {
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import { getAllClasses, getInnerBlock, getBottomBlock } from "./container";
|
|||||||
export default function ContainerLink({ children = [], options, additionalClassNames = "", target }) {
|
export default function ContainerLink({ children = [], options, additionalClassNames = "", target }) {
|
||||||
return (
|
return (
|
||||||
<a
|
<a
|
||||||
href={options.url}
|
href={options.href || options.url}
|
||||||
target={target}
|
target={target}
|
||||||
className={`${getAllClasses(options, additionalClassNames)} information-widget-link`}
|
className={`${getAllClasses(options, additionalClassNames)} information-widget-link`}
|
||||||
>
|
>
|
||||||
|
|||||||
@@ -43,8 +43,9 @@ export default async function handler(req, res) {
|
|||||||
|
|
||||||
if (pods.length === 0) {
|
if (pods.length === 0) {
|
||||||
res.status(404).send({
|
res.status(404).send({
|
||||||
error: `no pods found with namespace=${namespace} and labelSelector=${labelSelector}`,
|
status: "not found",
|
||||||
});
|
});
|
||||||
|
logger.error(`no pods found with namespace=${namespace} and labelSelector=${labelSelector}`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const someReady = pods.find((pod) => pod.status.phase === "Running");
|
const someReady = pods.find((pod) => pod.status.phase === "Running");
|
||||||
|
|||||||
@@ -2,12 +2,21 @@ import { formatApiCall } from "utils/proxy/api-helpers";
|
|||||||
import createLogger from "utils/logger";
|
import createLogger from "utils/logger";
|
||||||
import genericProxyHandler from "utils/proxy/handlers/generic";
|
import genericProxyHandler from "utils/proxy/handlers/generic";
|
||||||
import widgets from "widgets/widgets";
|
import widgets from "widgets/widgets";
|
||||||
|
import calendarProxyHandler from "widgets/calendar/proxy";
|
||||||
|
import getServiceWidget from "utils/config/service-helpers";
|
||||||
|
|
||||||
const logger = createLogger("servicesProxy");
|
const logger = createLogger("servicesProxy");
|
||||||
|
|
||||||
export default async function handler(req, res) {
|
export default async function handler(req, res) {
|
||||||
try {
|
try {
|
||||||
const { type } = req.query;
|
const { service, group } = req.query;
|
||||||
|
const serviceWidget = await getServiceWidget(group, service);
|
||||||
|
let type = serviceWidget?.type;
|
||||||
|
|
||||||
|
// exceptions
|
||||||
|
if (type === "calendar") type = "ical";
|
||||||
|
else if (service === "unifi_console" && group === "unifi_console") type = "unifi_console";
|
||||||
|
|
||||||
const widget = widgets[type];
|
const widget = widgets[type];
|
||||||
|
|
||||||
if (!widget) {
|
if (!widget) {
|
||||||
@@ -18,6 +27,11 @@ export default async function handler(req, res) {
|
|||||||
const serviceProxyHandler = widget.proxyHandler || genericProxyHandler;
|
const serviceProxyHandler = widget.proxyHandler || genericProxyHandler;
|
||||||
|
|
||||||
if (serviceProxyHandler instanceof Function) {
|
if (serviceProxyHandler instanceof Function) {
|
||||||
|
// quick return for no endpoint services, calendar is an exception
|
||||||
|
if (!req.query.endpoint || serviceProxyHandler === calendarProxyHandler) {
|
||||||
|
return serviceProxyHandler(req, res);
|
||||||
|
}
|
||||||
|
|
||||||
// map opaque endpoints to their actual endpoint
|
// map opaque endpoints to their actual endpoint
|
||||||
if (widget?.mappings) {
|
if (widget?.mappings) {
|
||||||
const mapping = widget?.mappings?.[req.query.endpoint];
|
const mapping = widget?.mappings?.[req.query.endpoint];
|
||||||
@@ -27,6 +41,11 @@ export default async function handler(req, res) {
|
|||||||
const endpoint = mapping?.endpoint;
|
const endpoint = mapping?.endpoint;
|
||||||
const endpointProxy = mapping?.proxyHandler || serviceProxyHandler;
|
const endpointProxy = mapping?.proxyHandler || serviceProxyHandler;
|
||||||
|
|
||||||
|
if (mapping.method && mapping.method !== req.method) {
|
||||||
|
logger.debug("Unsupported method: %s", req.method);
|
||||||
|
return res.status(403).json({ error: "Unsupported method" });
|
||||||
|
}
|
||||||
|
|
||||||
if (!endpoint) {
|
if (!endpoint) {
|
||||||
logger.debug("Unsupported service endpoint: %s", type);
|
logger.debug("Unsupported service endpoint: %s", type);
|
||||||
return res.status(403).json({ error: "Unsupported service endpoint" });
|
return res.status(403).json({ error: "Unsupported service endpoint" });
|
||||||
@@ -38,6 +57,17 @@ export default async function handler(req, res) {
|
|||||||
|
|
||||||
if (req.query.segments) {
|
if (req.query.segments) {
|
||||||
const segments = JSON.parse(req.query.segments);
|
const segments = JSON.parse(req.query.segments);
|
||||||
|
let validSegments = true;
|
||||||
|
Object.keys(segments).forEach((key) => {
|
||||||
|
if (!mapping.segments.includes(key)) {
|
||||||
|
logger.debug("Unsupported segment: %s", key);
|
||||||
|
validSegments = false;
|
||||||
|
} else if (segments[key].includes("/") || segments[key].includes("\\") || segments[key].includes("..")) {
|
||||||
|
logger.debug("Unsupported segment value: %s", segments[key]);
|
||||||
|
validSegments = false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (!validSegments) return res.status(403).json({ error: "Unsupported segment" });
|
||||||
req.query.endpoint = formatApiCall(endpoint, segments);
|
req.query.endpoint = formatApiCall(endpoint, segments);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -66,7 +96,14 @@ export default async function handler(req, res) {
|
|||||||
return serviceProxyHandler(req, res, map);
|
return serviceProxyHandler(req, res, map);
|
||||||
}
|
}
|
||||||
|
|
||||||
return serviceProxyHandler(req, res);
|
if (widget.allowedEndpoints instanceof RegExp) {
|
||||||
|
if (widget.allowedEndpoints.test(req.query.endpoint)) {
|
||||||
|
return serviceProxyHandler(req, res);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.debug("Unmapped proxy request.");
|
||||||
|
return res.status(403).json({ error: "Unmapped proxy request." });
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.debug("Unknown proxy service type: %s", type);
|
logger.debug("Unknown proxy service type: %s", type);
|
||||||
|
|||||||
@@ -26,7 +26,6 @@ import { bookmarksResponse, servicesResponse, widgetsResponse } from "utils/conf
|
|||||||
import ErrorBoundary from "components/errorboundry";
|
import ErrorBoundary from "components/errorboundry";
|
||||||
import themes from "utils/styles/themes";
|
import themes from "utils/styles/themes";
|
||||||
import QuickLaunch from "components/quicklaunch";
|
import QuickLaunch from "components/quicklaunch";
|
||||||
import { getStoredProvider, searchProviders } from "components/widgets/search/search";
|
|
||||||
|
|
||||||
const ThemeToggle = dynamic(() => import("components/toggles/theme"), {
|
const ThemeToggle = dynamic(() => import("components/toggles/theme"), {
|
||||||
ssr: false,
|
ssr: false,
|
||||||
@@ -204,20 +203,6 @@ function Home({ initialSettings }) {
|
|||||||
|
|
||||||
const [searching, setSearching] = useState(false);
|
const [searching, setSearching] = useState(false);
|
||||||
const [searchString, setSearchString] = useState("");
|
const [searchString, setSearchString] = useState("");
|
||||||
let searchProvider = null;
|
|
||||||
const searchWidget = Object.values(widgets).find((w) => w.type === "search");
|
|
||||||
if (searchWidget) {
|
|
||||||
if (Array.isArray(searchWidget.options?.provider)) {
|
|
||||||
// if search provider is a list, try to retrieve from localstorage, fall back to the first
|
|
||||||
searchProvider = getStoredProvider() ?? searchProviders[searchWidget.options.provider[0]];
|
|
||||||
} else if (searchWidget.options?.provider === "custom") {
|
|
||||||
searchProvider = searchWidget.options;
|
|
||||||
} else {
|
|
||||||
searchProvider = searchProviders[searchWidget.options?.provider];
|
|
||||||
}
|
|
||||||
// to pass to quicklaunch
|
|
||||||
searchProvider.showSearchSuggestions = searchWidget.options?.showSearchSuggestions;
|
|
||||||
}
|
|
||||||
const headerStyle = settings?.headerStyle || "underlined";
|
const headerStyle = settings?.headerStyle || "underlined";
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@@ -227,7 +212,8 @@ function Home({ initialSettings }) {
|
|||||||
(e.key.length === 1 &&
|
(e.key.length === 1 &&
|
||||||
e.key.match(/(\w|\s|[à-ü]|[À-Ü]|[\w\u0430-\u044f])/gi) &&
|
e.key.match(/(\w|\s|[à-ü]|[À-Ü]|[\w\u0430-\u044f])/gi) &&
|
||||||
!(e.altKey || e.ctrlKey || e.metaKey || e.shiftKey)) ||
|
!(e.altKey || e.ctrlKey || e.metaKey || e.shiftKey)) ||
|
||||||
e.key.match(/([à-ü]|[À-Ü])/g) || // accented characters may require modifier keys
|
// accented characters and the bang may require modifier keys
|
||||||
|
e.key.match(/([à-ü]|[À-Ü]|!)/g) ||
|
||||||
(e.key === "v" && (e.ctrlKey || e.metaKey))
|
(e.key === "v" && (e.ctrlKey || e.metaKey))
|
||||||
) {
|
) {
|
||||||
setSearching(true);
|
setSearching(true);
|
||||||
@@ -403,7 +389,6 @@ function Home({ initialSettings }) {
|
|||||||
setSearchString={setSearchString}
|
setSearchString={setSearchString}
|
||||||
isOpen={searching}
|
isOpen={searching}
|
||||||
close={setSearching}
|
close={setSearching}
|
||||||
searchProvider={settings.quicklaunch?.hideInternetSearch ? null : searchProvider}
|
|
||||||
/>
|
/>
|
||||||
<div
|
<div
|
||||||
id="information-widgets"
|
id="information-widgets"
|
||||||
|
|||||||
@@ -395,6 +395,8 @@ export function cleanServiceGroups(groups) {
|
|||||||
|
|
||||||
// emby, jellyfin, tautulli
|
// emby, jellyfin, tautulli
|
||||||
enableUser,
|
enableUser,
|
||||||
|
expandOneStreamToTwoRows,
|
||||||
|
showEpisodeNumber,
|
||||||
|
|
||||||
// glances, pihole
|
// glances, pihole
|
||||||
version,
|
version,
|
||||||
@@ -448,6 +450,9 @@ export function cleanServiceGroups(groups) {
|
|||||||
// proxmox
|
// proxmox
|
||||||
node,
|
node,
|
||||||
|
|
||||||
|
// speedtest
|
||||||
|
bitratePrecision,
|
||||||
|
|
||||||
// sonarr, radarr
|
// sonarr, radarr
|
||||||
enableQueue,
|
enableQueue,
|
||||||
|
|
||||||
@@ -457,6 +462,9 @@ export function cleanServiceGroups(groups) {
|
|||||||
|
|
||||||
// unifi
|
// unifi
|
||||||
site,
|
site,
|
||||||
|
|
||||||
|
// wgeasy
|
||||||
|
threshold,
|
||||||
} = cleanedService.widget;
|
} = cleanedService.widget;
|
||||||
|
|
||||||
let fieldsList = fields;
|
let fieldsList = fields;
|
||||||
@@ -520,14 +528,13 @@ export function cleanServiceGroups(groups) {
|
|||||||
if (["emby", "jellyfin"].includes(type)) {
|
if (["emby", "jellyfin"].includes(type)) {
|
||||||
if (enableBlocks !== undefined) cleanedService.widget.enableBlocks = JSON.parse(enableBlocks);
|
if (enableBlocks !== undefined) cleanedService.widget.enableBlocks = JSON.parse(enableBlocks);
|
||||||
if (enableNowPlaying !== undefined) cleanedService.widget.enableNowPlaying = JSON.parse(enableNowPlaying);
|
if (enableNowPlaying !== undefined) cleanedService.widget.enableNowPlaying = JSON.parse(enableNowPlaying);
|
||||||
if (enableUser !== undefined) {
|
|
||||||
cleanedService.widget.enableUser = !!JSON.parse(enableUser);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (["tautulli"].includes(type)) {
|
if (["emby", "jellyfin", "tautulli"].includes(type)) {
|
||||||
if (enableUser !== undefined) {
|
if (expandOneStreamToTwoRows !== undefined)
|
||||||
cleanedService.widget.enableUser = !!JSON.parse(enableUser);
|
cleanedService.widget.expandOneStreamToTwoRows = !!JSON.parse(expandOneStreamToTwoRows);
|
||||||
}
|
if (showEpisodeNumber !== undefined)
|
||||||
|
cleanedService.widget.showEpisodeNumber = !!JSON.parse(showEpisodeNumber);
|
||||||
|
if (enableUser !== undefined) cleanedService.widget.enableUser = !!JSON.parse(enableUser);
|
||||||
}
|
}
|
||||||
if (["sonarr", "radarr"].includes(type)) {
|
if (["sonarr", "radarr"].includes(type)) {
|
||||||
if (enableQueue !== undefined) cleanedService.widget.enableQueue = JSON.parse(enableQueue);
|
if (enableQueue !== undefined) cleanedService.widget.enableQueue = JSON.parse(enableQueue);
|
||||||
@@ -587,6 +594,14 @@ export function cleanServiceGroups(groups) {
|
|||||||
if (type === "healthchecks") {
|
if (type === "healthchecks") {
|
||||||
if (uuid !== undefined) cleanedService.widget.uuid = uuid;
|
if (uuid !== undefined) cleanedService.widget.uuid = uuid;
|
||||||
}
|
}
|
||||||
|
if (type === "speedtest") {
|
||||||
|
if (bitratePrecision !== undefined) {
|
||||||
|
cleanedService.widget.bitratePrecision = parseInt(bitratePrecision, 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (type === "wgeasy") {
|
||||||
|
if (threshold !== undefined) cleanedService.widget.threshold = parseInt(threshold, 10);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return cleanedService;
|
return cleanedService;
|
||||||
|
|||||||
@@ -8,22 +8,15 @@ export function formatApiCall(url, args) {
|
|||||||
return url.replace(/\/+$/, "").replace(find, replace).replace(find, replace);
|
return url.replace(/\/+$/, "").replace(find, replace).replace(find, replace);
|
||||||
}
|
}
|
||||||
|
|
||||||
function getURLSearchParams(widget, endpoint) {
|
export function getURLSearchParams(widget, endpoint) {
|
||||||
const params = new URLSearchParams({
|
const params = new URLSearchParams({
|
||||||
type: widget.type,
|
|
||||||
group: widget.service_group,
|
group: widget.service_group,
|
||||||
service: widget.service_name,
|
service: widget.service_name,
|
||||||
endpoint,
|
|
||||||
});
|
});
|
||||||
return params;
|
if (endpoint) {
|
||||||
}
|
params.append("endpoint", endpoint);
|
||||||
|
|
||||||
export function formatProxyUrlWithSegments(widget, endpoint, segments) {
|
|
||||||
const params = getURLSearchParams(widget, endpoint);
|
|
||||||
if (segments) {
|
|
||||||
params.append("segments", JSON.stringify(segments));
|
|
||||||
}
|
}
|
||||||
return `/api/services/proxy?${params.toString()}`;
|
return params;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function formatProxyUrl(widget, endpoint, queryParams) {
|
export function formatProxyUrl(widget, endpoint, queryParams) {
|
||||||
@@ -57,8 +50,9 @@ export function jsonArrayFilter(data, filter) {
|
|||||||
export function sanitizeErrorURL(errorURL) {
|
export function sanitizeErrorURL(errorURL) {
|
||||||
// Dont display sensitive params on frontend
|
// Dont display sensitive params on frontend
|
||||||
const url = new URL(errorURL);
|
const url = new URL(errorURL);
|
||||||
["apikey", "api_key", "token", "t", "access_token"].forEach((key) => {
|
["apikey", "api_key", "token", "t", "access_token", "auth"].forEach((key) => {
|
||||||
if (url.searchParams.has(key)) url.searchParams.set(key, "***");
|
if (url.searchParams.has(key)) url.searchParams.set(key, "***");
|
||||||
|
if (url.hash.includes(key)) url.hash = url.hash.replace(new RegExp(`${key}=[^&]+`), `${key}=***`);
|
||||||
});
|
});
|
||||||
return url.toString();
|
return url.toString();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import { createUnzip, constants as zlibConstants } from "node:zlib";
|
|||||||
import { http, https } from "follow-redirects";
|
import { http, https } from "follow-redirects";
|
||||||
|
|
||||||
import { addCookieToJar, setCookieHeader } from "./cookie-jar";
|
import { addCookieToJar, setCookieHeader } from "./cookie-jar";
|
||||||
|
import { sanitizeErrorURL } from "./api-helpers";
|
||||||
|
|
||||||
import createLogger from "utils/logger";
|
import createLogger from "utils/logger";
|
||||||
|
|
||||||
@@ -113,6 +114,11 @@ export async function httpProxy(url, params = {}) {
|
|||||||
constructedUrl.pathname,
|
constructedUrl.pathname,
|
||||||
);
|
);
|
||||||
if (err) logger.error(err);
|
if (err) logger.error(err);
|
||||||
return [500, "application/json", { error: { message: err?.message ?? "Unknown error", url, rawError: err } }, null];
|
return [
|
||||||
|
500,
|
||||||
|
"application/json",
|
||||||
|
{ error: { message: err?.message ?? "Unknown error", url: sanitizeErrorURL(url), rawError: err } },
|
||||||
|
null,
|
||||||
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ export default function Component({ service }) {
|
|||||||
if (!resultData) {
|
if (!resultData) {
|
||||||
return (
|
return (
|
||||||
<Container service={service}>
|
<Container service={service}>
|
||||||
,
|
|
||||||
<Block label="caddy.upstreams" />
|
<Block label="caddy.upstreams" />
|
||||||
<Block label="caddy.requests" />
|
<Block label="caddy.requests" />
|
||||||
<Block label="caddy.requests_failed" />
|
<Block label="caddy.requests_failed" />
|
||||||
|
|||||||
@@ -103,6 +103,7 @@ const components = {
|
|||||||
speedtest: dynamic(() => import("./speedtest/component")),
|
speedtest: dynamic(() => import("./speedtest/component")),
|
||||||
stash: dynamic(() => import("./stash/component")),
|
stash: dynamic(() => import("./stash/component")),
|
||||||
strelaysrv: dynamic(() => import("./strelaysrv/component")),
|
strelaysrv: dynamic(() => import("./strelaysrv/component")),
|
||||||
|
swagdashboard: dynamic(() => import("./swagdashboard/component")),
|
||||||
tailscale: dynamic(() => import("./tailscale/component")),
|
tailscale: dynamic(() => import("./tailscale/component")),
|
||||||
tandoor: dynamic(() => import("./tandoor/component")),
|
tandoor: dynamic(() => import("./tandoor/component")),
|
||||||
tautulli: dynamic(() => import("./tautulli/component")),
|
tautulli: dynamic(() => import("./tautulli/component")),
|
||||||
@@ -117,6 +118,7 @@ const components = {
|
|||||||
uptimerobot: dynamic(() => import("./uptimerobot/component")),
|
uptimerobot: dynamic(() => import("./uptimerobot/component")),
|
||||||
urbackup: dynamic(() => import("./urbackup/component")),
|
urbackup: dynamic(() => import("./urbackup/component")),
|
||||||
watchtower: dynamic(() => import("./watchtower/component")),
|
watchtower: dynamic(() => import("./watchtower/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")),
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import { MdOutlineSmartDisplay } from "react-icons/md";
|
|||||||
|
|
||||||
import Block from "components/services/widget/block";
|
import Block from "components/services/widget/block";
|
||||||
import Container from "components/services/widget/container";
|
import Container from "components/services/widget/container";
|
||||||
import { formatProxyUrlWithSegments } from "utils/proxy/api-helpers";
|
import { getURLSearchParams } from "utils/proxy/api-helpers";
|
||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
function ticksToTime(ticks) {
|
function ticksToTime(ticks) {
|
||||||
@@ -27,12 +27,28 @@ function ticksToString(ticks) {
|
|||||||
return parts.map((part) => part.toString().padStart(2, "0")).join(":");
|
return parts.map((part) => part.toString().padStart(2, "0")).join(":");
|
||||||
}
|
}
|
||||||
|
|
||||||
function SingleSessionEntry({ playCommand, session, enableUser }) {
|
function generateStreamTitle(session, enableUser, showEpisodeNumber) {
|
||||||
const {
|
const {
|
||||||
NowPlayingItem: { Name, SeriesName },
|
NowPlayingItem: { Name, SeriesName, Type, ParentIndexNumber, IndexNumber },
|
||||||
PlayState: { PositionTicks, IsPaused, IsMuted },
|
|
||||||
UserName,
|
UserName,
|
||||||
} = session;
|
} = session;
|
||||||
|
let streamTitle = "";
|
||||||
|
|
||||||
|
if (Type === "Episode" && showEpisodeNumber) {
|
||||||
|
const seasonStr = `S${ParentIndexNumber.toString().padStart(2, "0")}`;
|
||||||
|
const episodeStr = `E${IndexNumber.toString().padStart(2, "0")}`;
|
||||||
|
streamTitle = `${SeriesName}: ${seasonStr} · ${episodeStr} - ${Name}`;
|
||||||
|
} else {
|
||||||
|
streamTitle = `${Name}${SeriesName ? ` - ${SeriesName}` : ""}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return enableUser ? `${streamTitle} (${UserName})` : streamTitle;
|
||||||
|
}
|
||||||
|
|
||||||
|
function SingleSessionEntry({ playCommand, session, enableUser, showEpisodeNumber }) {
|
||||||
|
const {
|
||||||
|
PlayState: { PositionTicks, IsPaused, IsMuted },
|
||||||
|
} = session;
|
||||||
|
|
||||||
const RunTimeTicks =
|
const RunTimeTicks =
|
||||||
session.NowPlayingItem?.RunTimeTicks ?? session.NowPlayingItem?.CurrentProgram?.RunTimeTicks ?? 0;
|
session.NowPlayingItem?.RunTimeTicks ?? session.NowPlayingItem?.CurrentProgram?.RunTimeTicks ?? 0;
|
||||||
@@ -43,14 +59,13 @@ function SingleSessionEntry({ playCommand, session, enableUser }) {
|
|||||||
|
|
||||||
const percent = Math.min(1, PositionTicks / RunTimeTicks) * 100;
|
const percent = Math.min(1, PositionTicks / RunTimeTicks) * 100;
|
||||||
|
|
||||||
|
const streamTitle = generateStreamTitle(session, enableUser, showEpisodeNumber);
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
||||||
<div className="grow text-xs z-10 self-center ml-2 relative w-full h-4 mr-2">
|
<div className="grow text-xs z-10 self-center ml-2 relative w-full h-4 mr-2">
|
||||||
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden">
|
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden" title={streamTitle}>
|
||||||
{Name}
|
{streamTitle}
|
||||||
{SeriesName && ` - ${SeriesName}`}
|
|
||||||
{enableUser && ` (${UserName})`}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="self-center text-xs flex justify-end mr-1.5 pl-1">
|
<div className="self-center text-xs flex justify-end mr-1.5 pl-1">
|
||||||
@@ -99,11 +114,9 @@ function SingleSessionEntry({ playCommand, session, enableUser }) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function SessionEntry({ playCommand, session, enableUser }) {
|
function SessionEntry({ playCommand, session, enableUser, showEpisodeNumber }) {
|
||||||
const {
|
const {
|
||||||
NowPlayingItem: { Name, SeriesName },
|
|
||||||
PlayState: { PositionTicks, IsPaused, IsMuted },
|
PlayState: { PositionTicks, IsPaused, IsMuted },
|
||||||
UserName,
|
|
||||||
} = session;
|
} = session;
|
||||||
|
|
||||||
const RunTimeTicks =
|
const RunTimeTicks =
|
||||||
@@ -113,6 +126,8 @@ function SessionEntry({ playCommand, session, enableUser }) {
|
|||||||
IsVideoDirect: true,
|
IsVideoDirect: true,
|
||||||
}; // if no transcodinginfo its videodirect
|
}; // if no transcodinginfo its videodirect
|
||||||
|
|
||||||
|
const streamTitle = generateStreamTitle(session, enableUser, showEpisodeNumber);
|
||||||
|
|
||||||
const percent = Math.min(1, PositionTicks / RunTimeTicks) * 100;
|
const percent = Math.min(1, PositionTicks / RunTimeTicks) * 100;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@@ -142,10 +157,8 @@ function SessionEntry({ playCommand, session, enableUser }) {
|
|||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
<div className="grow text-xs z-10 self-center relative w-full h-4">
|
<div className="grow text-xs z-10 self-center relative w-full h-4">
|
||||||
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden">
|
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden" title={streamTitle}>
|
||||||
{Name}
|
{streamTitle}
|
||||||
{SeriesName && ` - ${SeriesName}`}
|
|
||||||
{enableUser && ` (${UserName})`}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="self-center text-xs flex justify-end mr-1 z-10">{IsMuted && <BsVolumeMuteFill />}</div>
|
<div className="self-center text-xs flex justify-end mr-1 z-10">{IsMuted && <BsVolumeMuteFill />}</div>
|
||||||
@@ -204,11 +217,17 @@ export default function Component({ service }) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
async function handlePlayCommand(session, command) {
|
async function handlePlayCommand(session, command) {
|
||||||
const url = formatProxyUrlWithSegments(widget, "PlayControl", {
|
const params = getURLSearchParams(widget, command);
|
||||||
sessionId: session.Id,
|
params.append(
|
||||||
command,
|
"segments",
|
||||||
});
|
JSON.stringify({
|
||||||
await fetch(url).then(() => {
|
sessionId: session.Id,
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
const url = `/api/services/proxy?${params.toString()}`;
|
||||||
|
await fetch(url, {
|
||||||
|
method: "POST",
|
||||||
|
}).then(() => {
|
||||||
sessionMutate();
|
sessionMutate();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -219,7 +238,9 @@ export default function Component({ service }) {
|
|||||||
|
|
||||||
const enableBlocks = service.widget?.enableBlocks;
|
const enableBlocks = service.widget?.enableBlocks;
|
||||||
const enableNowPlaying = service.widget?.enableNowPlaying ?? true;
|
const enableNowPlaying = service.widget?.enableNowPlaying ?? true;
|
||||||
const enableUser = !!service.widget?.enableUser;
|
const enableUser = !!service.widget?.enableUser; // default is false
|
||||||
|
const expandOneStreamToTwoRows = service.widget?.expandOneStreamToTwoRows !== false; // default is true
|
||||||
|
const showEpisodeNumber = !!service.widget?.showEpisodeNumber; // default is false
|
||||||
|
|
||||||
if (!sessionsData || !countData) {
|
if (!sessionsData || !countData) {
|
||||||
return (
|
return (
|
||||||
@@ -230,9 +251,11 @@ export default function Component({ service }) {
|
|||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
{expandOneStreamToTwoRows && (
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
</div>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
@@ -260,15 +283,17 @@ export default function Component({ service }) {
|
|||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">{t("emby.no_active")}</span>
|
<span className="absolute left-2 text-xs mt-[2px]">{t("emby.no_active")}</span>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
{expandOneStreamToTwoRows && (
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
</div>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (playing.length === 1) {
|
if (expandOneStreamToTwoRows && playing.length === 1) {
|
||||||
const session = playing[0];
|
const session = playing[0];
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
@@ -278,28 +303,29 @@ export default function Component({ service }) {
|
|||||||
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
||||||
session={session}
|
session={session}
|
||||||
enableUser={enableUser}
|
enableUser={enableUser}
|
||||||
|
showEpisodeNumber={showEpisodeNumber}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (playing.length > 0)
|
return (
|
||||||
return (
|
<>
|
||||||
<>
|
{enableBlocks && <CountBlocks service={service} countData={countData} />}
|
||||||
{enableBlocks && <CountBlocks service={service} countData={countData} />}
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
{playing.map((session) => (
|
||||||
{playing.map((session) => (
|
<SessionEntry
|
||||||
<SessionEntry
|
key={session.Id}
|
||||||
key={session.Id}
|
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
||||||
playCommand={(currentSession, command) => handlePlayCommand(currentSession, command)}
|
session={session}
|
||||||
session={session}
|
enableUser={enableUser}
|
||||||
enableUser={enableUser}
|
showEpisodeNumber={showEpisodeNumber}
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (enableBlocks) {
|
if (enableBlocks) {
|
||||||
|
|||||||
@@ -10,12 +10,16 @@ const widget = {
|
|||||||
},
|
},
|
||||||
Count: {
|
Count: {
|
||||||
endpoint: "Items/Counts",
|
endpoint: "Items/Counts",
|
||||||
segments: ["MovieCount", "SeriesCount", "EpisodeCount", "SongCount"],
|
|
||||||
},
|
},
|
||||||
PlayControl: {
|
Unpause: {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
endpoint: "Sessions/{sessionId}/Playing/{command}",
|
endpoint: "Sessions/{sessionId}/Playing/Unpause",
|
||||||
segments: ["sessionId", "command"],
|
segments: ["sessionId"],
|
||||||
|
},
|
||||||
|
Pause: {
|
||||||
|
method: "POST",
|
||||||
|
endpoint: "Sessions/{sessionId}/Playing/Pause",
|
||||||
|
segments: ["sessionId"],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ export default function Component({ service }) {
|
|||||||
if (!stateData) {
|
if (!stateData) {
|
||||||
return (
|
return (
|
||||||
<Container service={service}>
|
<Container service={service}>
|
||||||
,
|
|
||||||
<Block label="evcc.pv_power" />
|
<Block label="evcc.pv_power" />
|
||||||
<Block label="evcc.grid_power" />
|
<Block label="evcc.grid_power" />
|
||||||
<Block label="evcc.home_power" />
|
<Block label="evcc.home_power" />
|
||||||
|
|||||||
@@ -2,6 +2,12 @@ import floodProxyHandler from "./proxy";
|
|||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
proxyHandler: floodProxyHandler,
|
proxyHandler: floodProxyHandler,
|
||||||
|
|
||||||
|
mappings: {
|
||||||
|
torrents: {
|
||||||
|
endpoint: "torrents",
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import fritzboxProxyHandler from "./proxy";
|
|||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
proxyHandler: fritzboxProxyHandler,
|
proxyHandler: fritzboxProxyHandler,
|
||||||
|
allowedEndpoints: /status/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import gamedigProxyHandler from "./proxy";
|
|||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
proxyHandler: gamedigProxyHandler,
|
proxyHandler: gamedigProxyHandler,
|
||||||
|
allowedEndpoints: /status/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -5,8 +5,12 @@ import Block from "components/services/widget/block";
|
|||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
function getPerformancePercent(t, performanceRange) {
|
function getPerformancePercent(t, performanceRange) {
|
||||||
return `${performanceRange.performance.currentGrossPerformancePercent > 0 ? "+" : ""}${t("common.percent", {
|
// ghostfolio v2.79.0 changed to grossPerformancePercentage
|
||||||
value: performanceRange.performance.currentGrossPerformancePercent * 100,
|
const percent =
|
||||||
|
performanceRange.performance.grossPerformancePercentage ??
|
||||||
|
performanceRange.performance.currentGrossPerformancePercent;
|
||||||
|
return `${percent > 0 ? "+" : ""}${t("common.percent", {
|
||||||
|
value: percent * 100,
|
||||||
maximumFractionDigits: 2,
|
maximumFractionDigits: 2,
|
||||||
})}`;
|
})}`;
|
||||||
}
|
}
|
||||||
@@ -24,6 +28,10 @@ export default function Component({ service }) {
|
|||||||
return <Container service={service} error={finalError} />;
|
return <Container service={service} error={finalError} />;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (performanceToday?.statusCode === 401) {
|
||||||
|
return <Container service={service} error={performanceToday} />;
|
||||||
|
}
|
||||||
|
|
||||||
if (!performanceToday || !performanceYear || !performanceMax) {
|
if (!performanceToday || !performanceYear || !performanceMax) {
|
||||||
return (
|
return (
|
||||||
<Container service={service}>
|
<Container service={service}>
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import credentialedProxyHandler from "utils/proxy/handlers/credentialed";
|
|||||||
const widget = {
|
const widget = {
|
||||||
api: "{url}/api/{endpoint}",
|
api: "{url}/api/{endpoint}",
|
||||||
proxyHandler: credentialedProxyHandler,
|
proxyHandler: credentialedProxyHandler,
|
||||||
|
allowedEndpoints: /\d\/quicklook|diskio|cpu|fs|gpu|system|mem|network|processlist|sensors/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -18,10 +18,13 @@ export default function Component({ service }) {
|
|||||||
);
|
);
|
||||||
|
|
||||||
if (statsError || statusError) {
|
if (statsError || statusError) {
|
||||||
return <Container service={service} error={statsError ?? statusError} />;
|
return <Container service={service} error={statsError ?? statusError ?? statusData} />;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (statusData && !(statusData.status.includes("running") || statusData.status.includes("partial"))) {
|
if (
|
||||||
|
statusData &&
|
||||||
|
(!statusData.status || !(statusData.status.includes("running") || statusData.status.includes("partial")))
|
||||||
|
) {
|
||||||
return (
|
return (
|
||||||
<Container>
|
<Container>
|
||||||
<Block label={t("widget.status")} value={t("docker.offline")} />
|
<Block label={t("widget.status")} value={t("docker.offline")} />
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import minecraftProxyHandler from "./proxy";
|
|||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
proxyHandler: minecraftProxyHandler,
|
proxyHandler: minecraftProxyHandler,
|
||||||
|
allowedEndpoints: /status/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import useWidgetAPI from "utils/proxy/use-widget-api";
|
|||||||
export default function Component({ service }) {
|
export default function Component({ service }) {
|
||||||
const { widget } = service;
|
const { widget } = service;
|
||||||
|
|
||||||
const { data: infoData, error: infoError } = useWidgetAPI(widget, "nginx/proxy-hosts");
|
const { data: infoData, error: infoError } = useWidgetAPI(widget, "hosts");
|
||||||
|
|
||||||
if (infoError) {
|
if (infoError) {
|
||||||
return <Container service={service} error={infoError} />;
|
return <Container service={service} error={infoError} />;
|
||||||
|
|||||||
@@ -3,6 +3,12 @@ import npmProxyHandler from "./proxy";
|
|||||||
const widget = {
|
const widget = {
|
||||||
api: "{url}/api/{endpoint}",
|
api: "{url}/api/{endpoint}",
|
||||||
proxyHandler: npmProxyHandler,
|
proxyHandler: npmProxyHandler,
|
||||||
|
|
||||||
|
mappings: {
|
||||||
|
hosts: {
|
||||||
|
endpoint: "nginx/proxy-hosts",
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import jsonrpcProxyHandler from "utils/proxy/handlers/jsonrpc";
|
|||||||
const widget = {
|
const widget = {
|
||||||
api: "{url}/jsonrpc",
|
api: "{url}/jsonrpc",
|
||||||
proxyHandler: jsonrpcProxyHandler,
|
proxyHandler: jsonrpcProxyHandler,
|
||||||
|
allowedEndpoints: /status/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ export default function Component({ service }) {
|
|||||||
|
|
||||||
const { widget } = service;
|
const { widget } = service;
|
||||||
|
|
||||||
const { data: torrentData, error: torrentError } = useWidgetAPI(widget, "torrents/info");
|
const { data: torrentData, error: torrentError } = useWidgetAPI(widget, "torrents");
|
||||||
|
|
||||||
if (torrentError) {
|
if (torrentError) {
|
||||||
return <Container service={service} error={torrentError} />;
|
return <Container service={service} error={torrentError} />;
|
||||||
|
|||||||
@@ -2,6 +2,12 @@ import qbittorrentProxyHandler from "./proxy";
|
|||||||
|
|
||||||
const widget = {
|
const widget = {
|
||||||
proxyHandler: qbittorrentProxyHandler,
|
proxyHandler: qbittorrentProxyHandler,
|
||||||
|
|
||||||
|
mappings: {
|
||||||
|
torrents: {
|
||||||
|
endpoint: "torrents/info",
|
||||||
|
},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import qnapProxyHandler from "./proxy";
|
|||||||
const widget = {
|
const widget = {
|
||||||
api: "{url}",
|
api: "{url}",
|
||||||
proxyHandler: qnapProxyHandler,
|
proxyHandler: qnapProxyHandler,
|
||||||
|
allowedEndpoints: /status/,
|
||||||
};
|
};
|
||||||
|
|
||||||
export default widget;
|
export default widget;
|
||||||
|
|||||||
@@ -1,9 +1,12 @@
|
|||||||
|
import { useTranslation } from "next-i18next";
|
||||||
|
|
||||||
import Container from "components/services/widget/container";
|
import Container from "components/services/widget/container";
|
||||||
import Block from "components/services/widget/block";
|
import Block from "components/services/widget/block";
|
||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
export default function Component({ service }) {
|
export default function Component({ service }) {
|
||||||
const { widget } = service;
|
const { widget } = service;
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
const { data: response, error: responseError } = useWidgetAPI(widget, "statistics");
|
const { data: response, error: responseError } = useWidgetAPI(widget, "statistics");
|
||||||
|
|
||||||
@@ -24,8 +27,8 @@ export default function Component({ service }) {
|
|||||||
const totalRoms = response.reduce((total, stat) => total + stat.rom_count, 0);
|
const totalRoms = response.reduce((total, stat) => total + stat.rom_count, 0);
|
||||||
return (
|
return (
|
||||||
<Container service={service}>
|
<Container service={service}>
|
||||||
<Block label="romm.platforms" value={platforms} />
|
<Block label="romm.platforms" value={t("common.number", { value: platforms })} />
|
||||||
<Block label="romm.totalRoms" value={totalRoms} />
|
<Block label="romm.totalRoms" value={t("common.number", { value: totalRoms })} />
|
||||||
</Container>
|
</Container>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,11 @@ export default function Component({ service }) {
|
|||||||
|
|
||||||
const { data: speedtestData, error: speedtestError } = useWidgetAPI(widget, "speedtest/latest");
|
const { data: speedtestData, error: speedtestError } = useWidgetAPI(widget, "speedtest/latest");
|
||||||
|
|
||||||
|
const bitratePrecision =
|
||||||
|
!widget?.bitratePrecision || Number.isNaN(widget?.bitratePrecision) || widget?.bitratePrecision < 0
|
||||||
|
? 0
|
||||||
|
: widget.bitratePrecision;
|
||||||
|
|
||||||
if (speedtestError) {
|
if (speedtestError) {
|
||||||
return <Container service={service} error={speedtestError} />;
|
return <Container service={service} error={speedtestError} />;
|
||||||
}
|
}
|
||||||
@@ -29,9 +34,18 @@ export default function Component({ service }) {
|
|||||||
<Container service={service}>
|
<Container service={service}>
|
||||||
<Block
|
<Block
|
||||||
label="speedtest.download"
|
label="speedtest.download"
|
||||||
value={t("common.bitrate", { value: speedtestData.data.download * 1000 * 1000 })}
|
value={t("common.bitrate", {
|
||||||
|
value: speedtestData.data.download * 1000 * 1000,
|
||||||
|
decimals: bitratePrecision,
|
||||||
|
})}
|
||||||
|
/>
|
||||||
|
<Block
|
||||||
|
label="speedtest.upload"
|
||||||
|
value={t("common.bitrate", {
|
||||||
|
value: speedtestData.data.upload * 1000 * 1000,
|
||||||
|
decimals: bitratePrecision,
|
||||||
|
})}
|
||||||
/>
|
/>
|
||||||
<Block label="speedtest.upload" value={t("common.bitrate", { value: speedtestData.data.upload * 1000 * 1000 })} />
|
|
||||||
<Block
|
<Block
|
||||||
label="speedtest.ping"
|
label="speedtest.ping"
|
||||||
value={t("common.ms", {
|
value={t("common.ms", {
|
||||||
|
|||||||
@@ -1,18 +1,26 @@
|
|||||||
import { useTranslation } from "next-i18next";
|
import { useTranslation } from "next-i18next";
|
||||||
|
import { useEffect, useState } from "react";
|
||||||
|
|
||||||
import Container from "components/services/widget/container";
|
import Container from "components/services/widget/container";
|
||||||
import Block from "components/services/widget/block";
|
import Block from "components/services/widget/block";
|
||||||
import useWidgetAPI from "utils/proxy/use-widget-api";
|
import { formatProxyUrl } from "utils/proxy/api-helpers";
|
||||||
|
|
||||||
export default function Component({ service }) {
|
export default function Component({ service }) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
const { widget } = service;
|
const { widget } = service;
|
||||||
const { data: stats, error: stashError } = useWidgetAPI(widget, "stats");
|
const [stats, setStats] = useState(null);
|
||||||
|
|
||||||
if (stashError) {
|
useEffect(() => {
|
||||||
return <Container service={service} error={stashError} />;
|
async function fetchStats() {
|
||||||
}
|
const url = formatProxyUrl(widget, "stats");
|
||||||
|
const res = await fetch(url, { method: "POST" });
|
||||||
|
setStats(await res.json());
|
||||||
|
}
|
||||||
|
if (!stats) {
|
||||||
|
fetchStats();
|
||||||
|
}
|
||||||
|
}, [widget, stats]);
|
||||||
|
|
||||||
if (!stats) {
|
if (!stats) {
|
||||||
return (
|
return (
|
||||||
|
|||||||
33
src/widgets/swagdashboard/component.jsx
Normal file
33
src/widgets/swagdashboard/component.jsx
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
import Container from "components/services/widget/container";
|
||||||
|
import Block from "components/services/widget/block";
|
||||||
|
import useWidgetAPI from "utils/proxy/use-widget-api";
|
||||||
|
|
||||||
|
export default function Component({ service }) {
|
||||||
|
const { widget } = service;
|
||||||
|
|
||||||
|
const { data: swagData, error: swagError } = useWidgetAPI(widget, "overview");
|
||||||
|
|
||||||
|
if (swagError) {
|
||||||
|
return <Container service={service} error={swagError} />;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!swagData) {
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="swagdashboard.proxied" />
|
||||||
|
<Block label="swagdashboard.auth" />
|
||||||
|
<Block label="swagdashboard.outdated" />
|
||||||
|
<Block label="swagdashboard.banned" />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Container service={service}>
|
||||||
|
<Block label="swagdashboard.proxied" value={swagData.proxied} />
|
||||||
|
<Block label="swagdashboard.auth" value={swagData.auth} />
|
||||||
|
<Block label="swagdashboard.outdated" value={swagData.outdated} />
|
||||||
|
<Block label="swagdashboard.banned" value={swagData.banned} />
|
||||||
|
</Container>
|
||||||
|
);
|
||||||
|
}
|
||||||
9
src/widgets/swagdashboard/widget.js
Normal file
9
src/widgets/swagdashboard/widget.js
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
import genericProxyHandler from "utils/proxy/handlers/generic";
|
||||||
|
|
||||||
|
const widget = {
|
||||||
|
api: "{url}/?stats=true",
|
||||||
|
proxyHandler: genericProxyHandler,
|
||||||
|
allowedEndpoints: /overview/,
|
||||||
|
};
|
||||||
|
|
||||||
|
export default widget;
|
||||||
@@ -25,17 +25,31 @@ function millisecondsToString(milliseconds) {
|
|||||||
return parts.map((part) => part.toString().padStart(2, "0")).join(":");
|
return parts.map((part) => part.toString().padStart(2, "0")).join(":");
|
||||||
}
|
}
|
||||||
|
|
||||||
function SingleSessionEntry({ session, enableUser }) {
|
function generateStreamTitle(session, enableUser, showEpisodeNumber) {
|
||||||
const { full_title, duration, view_offset, progress_percent, state, video_decision, audio_decision, username } =
|
let stream_title = "";
|
||||||
session;
|
const { media_type, parent_media_index, media_index, title, grandparent_title, full_title, friendly_name } = session;
|
||||||
|
if (media_type === "episode" && showEpisodeNumber) {
|
||||||
|
const season_str = `S${parent_media_index.toString().padStart(2, "0")}`;
|
||||||
|
const episode_str = `E${media_index.toString().padStart(2, "0")}`;
|
||||||
|
stream_title = `${grandparent_title}: ${season_str} · ${episode_str} - ${title}`;
|
||||||
|
} else {
|
||||||
|
stream_title = full_title;
|
||||||
|
}
|
||||||
|
|
||||||
|
return enableUser ? `${stream_title} (${friendly_name})` : stream_title;
|
||||||
|
}
|
||||||
|
|
||||||
|
function SingleSessionEntry({ session, enableUser, showEpisodeNumber }) {
|
||||||
|
const { duration, view_offset, progress_percent, state, video_decision, audio_decision } = session;
|
||||||
|
|
||||||
|
const stream_title = generateStreamTitle(session, enableUser, showEpisodeNumber);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
||||||
<div className="text-xs z-10 self-center ml-2 relative w-full h-4 grow mr-2">
|
<div className="text-xs z-10 self-center ml-2 relative w-full h-4 grow mr-2">
|
||||||
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden">
|
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden" title={stream_title}>
|
||||||
{full_title}
|
{stream_title}
|
||||||
{enableUser && ` (${username})`}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="self-center text-xs flex justify-end mr-1.5 pl-1">
|
<div className="self-center text-xs flex justify-end mr-1.5 pl-1">
|
||||||
@@ -78,8 +92,10 @@ function SingleSessionEntry({ session, enableUser }) {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function SessionEntry({ session, enableUser }) {
|
function SessionEntry({ session, enableUser, showEpisodeNumber }) {
|
||||||
const { full_title, view_offset, progress_percent, state, video_decision, audio_decision, username } = session;
|
const { view_offset, progress_percent, state, video_decision, audio_decision } = session;
|
||||||
|
|
||||||
|
const stream_title = generateStreamTitle(session, enableUser, showEpisodeNumber);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
<div className="text-theme-700 dark:text-theme-200 relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1 flex">
|
||||||
@@ -98,9 +114,8 @@ function SessionEntry({ session, enableUser }) {
|
|||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
<div className="text-xs z-10 self-center ml-2 relative w-full h-4 grow mr-2">
|
<div className="text-xs z-10 self-center ml-2 relative w-full h-4 grow mr-2">
|
||||||
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden">
|
<div className="absolute w-full whitespace-nowrap text-ellipsis overflow-hidden" title={stream_title}>
|
||||||
{full_title}
|
{stream_title}
|
||||||
{enableUser && ` (${username})`}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="self-center text-xs flex justify-end mr-1.5 pl-1 z-10">
|
<div className="self-center text-xs flex justify-end mr-1.5 pl-1 z-10">
|
||||||
@@ -129,6 +144,10 @@ export default function Component({ service }) {
|
|||||||
refreshInterval: 5000,
|
refreshInterval: 5000,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const enableUser = !!service.widget?.enableUser; // default is false
|
||||||
|
const expandOneStreamToTwoRows = service.widget?.expandOneStreamToTwoRows !== false; // default is true
|
||||||
|
const showEpisodeNumber = !!service.widget?.showEpisodeNumber; // default is false
|
||||||
|
|
||||||
if (activityError || (activityData && Object.keys(activityData.response.data).length === 0)) {
|
if (activityError || (activityData && Object.keys(activityData.response.data).length === 0)) {
|
||||||
return <Container service={service} error={activityError ?? { message: t("tautulli.plex_connection_error") }} />;
|
return <Container service={service} error={activityError ?? { message: t("tautulli.plex_connection_error") }} />;
|
||||||
}
|
}
|
||||||
@@ -139,9 +158,11 @@ export default function Component({ service }) {
|
|||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
{expandOneStreamToTwoRows && (
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
</div>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -162,20 +183,20 @@ export default function Component({ service }) {
|
|||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">{t("tautulli.no_active")}</span>
|
<span className="absolute left-2 text-xs mt-[2px]">{t("tautulli.no_active")}</span>
|
||||||
</div>
|
</div>
|
||||||
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
{expandOneStreamToTwoRows && (
|
||||||
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
<div className="text-theme-700 dark:text-theme-200 text-xs relative h-5 w-full rounded-md bg-theme-200/50 dark:bg-theme-900/20 mt-1">
|
||||||
</div>
|
<span className="absolute left-2 text-xs mt-[2px]">-</span>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const enableUser = !!service.widget?.enableUser;
|
if (expandOneStreamToTwoRows && playing.length === 1) {
|
||||||
|
|
||||||
if (playing.length === 1) {
|
|
||||||
const session = playing[0];
|
const session = playing[0];
|
||||||
return (
|
return (
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
<SingleSessionEntry session={session} enableUser={enableUser} />
|
<SingleSessionEntry session={session} enableUser={enableUser} showEpisodeNumber={showEpisodeNumber} />
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -183,7 +204,12 @@ export default function Component({ service }) {
|
|||||||
return (
|
return (
|
||||||
<div className="flex flex-col pb-1 mx-1">
|
<div className="flex flex-col pb-1 mx-1">
|
||||||
{playing.map((session) => (
|
{playing.map((session) => (
|
||||||
<SessionEntry key={session.Id} session={session} enableUser={enableUser} />
|
<SessionEntry
|
||||||
|
key={session.Id}
|
||||||
|
session={session}
|
||||||
|
enableUser={enableUser}
|
||||||
|
showEpisodeNumber={showEpisodeNumber}
|
||||||
|
/>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ const proxyName = "tdarrProxyHandler";
|
|||||||
const logger = createLogger(proxyName);
|
const logger = createLogger(proxyName);
|
||||||
|
|
||||||
export default async function tdarrProxyHandler(req, res) {
|
export default async function tdarrProxyHandler(req, res) {
|
||||||
const { group, service, endpoint } = req.query;
|
const { group, service } = req.query;
|
||||||
|
|
||||||
if (!group || !service) {
|
if (!group || !service) {
|
||||||
logger.debug("Invalid or missing service '%s' or group '%s'", service, group);
|
logger.debug("Invalid or missing service '%s' or group '%s'", service, group);
|
||||||
@@ -22,7 +22,7 @@ export default async function tdarrProxyHandler(req, res) {
|
|||||||
return res.status(400).json({ error: "Invalid proxy service type" });
|
return res.status(400).json({ error: "Invalid proxy service type" });
|
||||||
}
|
}
|
||||||
|
|
||||||
const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint, ...widget }));
|
const url = new URL(formatApiCall(widgets[widget.type].api, { endpoint: undefined, ...widget }));
|
||||||
|
|
||||||
const [status, contentType, data] = await httpProxy(url, {
|
const [status, contentType, data] = await httpProxy(url, {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user