Compare commits
102 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e6a821ecc3 | ||
|
|
49036a9738 | ||
|
|
0197b449ed | ||
|
|
dc3382447c | ||
|
|
6beaf665fb | ||
|
|
b9622f75b0 | ||
|
|
fe462a71d6 | ||
|
|
1e556e105d | ||
|
|
b5f4daa8ef | ||
|
|
fd50241e2a | ||
|
|
6a0fbba407 | ||
|
|
2ee5fd123b | ||
|
|
86a13817df | ||
|
|
2f7d948a5c | ||
|
|
1b79e51194 | ||
|
|
2d98ac30f2 | ||
|
|
1a85175b15 | ||
|
|
6f429a6a4b | ||
|
|
3020a2d1fd | ||
|
|
a6e85240c6 | ||
|
|
98e816204a | ||
|
|
a0b5ac318a | ||
|
|
101461b7b5 | ||
|
|
ba6f50f21d | ||
|
|
dd3a229559 | ||
|
|
630d5024ac | ||
|
|
d239687e2e | ||
|
|
81a3dfbfe4 | ||
|
|
034720f47a | ||
|
|
0717607a97 | ||
|
|
ee5442c15c | ||
|
|
b2158b0921 | ||
|
|
a158866ca1 | ||
|
|
4f27ffbe2d | ||
|
|
10bc8a15a9 | ||
|
|
5d63b3d212 | ||
|
|
43decb0ed9 | ||
|
|
e4d42b5393 | ||
|
|
f717e59085 | ||
|
|
fd05ae377c | ||
|
|
cc9b4782f2 | ||
|
|
14cda38dbb | ||
|
|
27e3c9f1ed | ||
|
|
607c4b7750 | ||
|
|
1c6480586c | ||
|
|
31c04006da | ||
|
|
499ab4d701 | ||
|
|
fbb35d3dc8 | ||
|
|
94936ed09d | ||
|
|
31a511de02 | ||
|
|
2d91b2b748 | ||
|
|
7dabd0335f | ||
|
|
96431c6085 | ||
|
|
f64aa50cc0 | ||
|
|
ac39ffdc2f | ||
|
|
f4adebca92 | ||
|
|
b2d75a99e7 | ||
|
|
bda586b04e | ||
|
|
4a4ca95fe5 | ||
|
|
6753843202 | ||
|
|
6b77ae835b | ||
|
|
d0eabf7adb | ||
|
|
30fd42dba4 | ||
|
|
7bcdba16c6 | ||
|
|
59ed5ed114 | ||
|
|
6b2a3da7ee | ||
|
|
b853c566b2 | ||
|
|
bc3adf1f2a | ||
|
|
c437b414ab | ||
|
|
9aa46e4fdd | ||
|
|
0c352b1843 | ||
|
|
f229bca609 | ||
|
|
93c18a8077 | ||
|
|
deff2f5506 | ||
|
|
d0937fe6a8 | ||
|
|
a35c60f973 | ||
|
|
29928a9a5f | ||
|
|
191a95c55c | ||
|
|
48e0a0e8ef | ||
|
|
20445583cd | ||
|
|
5bc67137f6 | ||
|
|
22c02f4e45 | ||
|
|
3c28e4af44 | ||
|
|
01252c6193 | ||
|
|
27f536c267 | ||
|
|
cb3248117f | ||
|
|
c58f59c105 | ||
|
|
8cc6640d04 | ||
|
|
20df9a5e9c | ||
|
|
91e529f87a | ||
|
|
a28952ce69 | ||
|
|
276a1c3ef4 | ||
|
|
5cc487a96d | ||
|
|
e626274f34 | ||
|
|
6d829bce79 | ||
|
|
230da3d2eb | ||
|
|
aaf4a3e92f | ||
|
|
be8363cc35 | ||
|
|
907abee1aa | ||
|
|
385511f773 | ||
|
|
cbf304a4c8 | ||
|
|
897309a47c |
8
.github/DISCUSSION_TEMPLATE/support.yml
vendored
8
.github/DISCUSSION_TEMPLATE/support.yml
vendored
@ -54,3 +54,11 @@ body:
|
|||||||
description: Please include output from your [troubleshooting tests](https://gethomepage.dev/more/troubleshooting/#service-widget-errors), if relevant.
|
description: Please include output from your [troubleshooting tests](https://gethomepage.dev/more/troubleshooting/#service-widget-errors), if relevant.
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
|
- type: markdown
|
||||||
|
attributes:
|
||||||
|
value: |
|
||||||
|
## ⚠️ STOP ⚠️
|
||||||
|
|
||||||
|
Before you submit this support request, please ensure you have entered your configuration files and actually followed the steps from the troubleshooting guide linked above, if relevant. The troubleshooting steps often help to solve the problem.
|
||||||
|
|
||||||
|
*Please remember that this project is maintained by regular people **just like you**, so if you don't take the time to fill out the requested information, don't expect a reply back.*
|
||||||
|
|||||||
19
.github/PULL_REQUEST_TEMPLATE.md
vendored
19
.github/PULL_REQUEST_TEMPLATE.md
vendored
@ -1,11 +1,20 @@
|
|||||||
|
<!--
|
||||||
|
==== STOP ====================
|
||||||
|
======== STOP ================
|
||||||
|
============ STOP ============
|
||||||
|
================ STOP ========
|
||||||
|
==================== STOP ====
|
||||||
|
|
||||||
|
⚠️ Before opening this pull request please review the guidelines in the checklist below.
|
||||||
|
|
||||||
|
If this PR does not meet those guidelines it will not be accepted, and everyone will be sad.
|
||||||
|
-->
|
||||||
|
|
||||||
## Proposed change
|
## Proposed change
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
Please include a summary of the change. Screenshots and/or videos can also be helpful if appropriate.
|
Please include a summary of the change. Screenshots and/or videos can also be helpful if appropriate.
|
||||||
|
|
||||||
*** Please see the development guidelines for new widgets: https://gethomepage.dev/more/development/#service-widget-guidelines
|
|
||||||
*** If you do not follow these guidelines your PR will likely be closed without review.
|
|
||||||
|
|
||||||
New service widgets should include example(s) of relevant API output as well as updates to the docs for the new widget.
|
New service widgets should include example(s) of relevant API output as well as updates to the docs for the new widget.
|
||||||
-->
|
-->
|
||||||
|
|
||||||
@ -19,13 +28,13 @@ What type of change does your PR introduce to Homepage?
|
|||||||
|
|
||||||
- [ ] New service widget
|
- [ ] New service widget
|
||||||
- [ ] Bug fix (non-breaking change which fixes an issue)
|
- [ ] Bug fix (non-breaking change which fixes an issue)
|
||||||
- [ ] New feature (non-breaking change which adds functionality)
|
- [ ] New feature or enhancement (non-breaking change which adds functionality)
|
||||||
- [ ] Documentation only
|
- [ ] Documentation only
|
||||||
- [ ] Other (please explain)
|
- [ ] Other (please explain)
|
||||||
|
|
||||||
## Checklist:
|
## Checklist:
|
||||||
|
|
||||||
- [ ] If applicable, I have added corresponding documentation changes.
|
- [ ] If applicable, I have added corresponding documentation changes.
|
||||||
- [ ] If applicable, I have reviewed the [feature](https://gethomepage.dev/more/development/#new-feature-guidelines) and / or [service widget guidelines](https://gethomepage.dev/more/development/#service-widget-guidelines).
|
- [ ] If applicable, I have reviewed the [feature / enhancement](https://gethomepage.dev/more/development/#new-feature-guidelines) and / or [service widget guidelines](https://gethomepage.dev/more/development/#service-widget-guidelines).
|
||||||
- [ ] I have checked that all code style checks pass using [pre-commit hooks](https://gethomepage.dev/more/development/#code-formatting-with-pre-commit-hooks) and [linting checks](https://gethomepage.dev/more/development/#code-linting).
|
- [ ] I have checked that all code style checks pass using [pre-commit hooks](https://gethomepage.dev/more/development/#code-formatting-with-pre-commit-hooks) and [linting checks](https://gethomepage.dev/more/development/#code-linting).
|
||||||
- [ ] If applicable, I have tested my code for new features & regressions on both mobile & desktop devices, using the latest version of major browsers.
|
- [ ] If applicable, I have tested my code for new features & regressions on both mobile & desktop devices, using the latest version of major browsers.
|
||||||
|
|||||||
22
.github/workflows/docker-publish.yml
vendored
22
.github/workflows/docker-publish.yml
vendored
@ -46,6 +46,24 @@ jobs:
|
|||||||
-
|
-
|
||||||
name: Check files
|
name: Check files
|
||||||
uses: pre-commit/action@v3.0.1
|
uses: pre-commit/action@v3.0.1
|
||||||
|
-
|
||||||
|
name: Install pnpm
|
||||||
|
uses: pnpm/action-setup@v4
|
||||||
|
with:
|
||||||
|
version: 10
|
||||||
|
run_install: false
|
||||||
|
-
|
||||||
|
name: Install Node.js
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version: 20
|
||||||
|
cache: 'pnpm'
|
||||||
|
-
|
||||||
|
name: Install dependencies
|
||||||
|
run: pnpm install
|
||||||
|
-
|
||||||
|
name: Lint frontend
|
||||||
|
run: pnpm run lint
|
||||||
|
|
||||||
build:
|
build:
|
||||||
name: Docker Build & Push
|
name: Docker Build & Push
|
||||||
@ -118,7 +136,7 @@ jobs:
|
|||||||
uses: docker/build-push-action@v6
|
uses: docker/build-push-action@v6
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
push: ${{ github.event_name != 'pull_request' && !(github.event_name == 'push' && startsWith(github.ref, 'refs/heads/feature')) }}
|
push: ${{ github.event_name != 'pull_request' }}
|
||||||
tags: ${{ steps.meta.outputs.tags }}
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
build-args: |
|
build-args: |
|
||||||
@ -127,7 +145,7 @@ jobs:
|
|||||||
REVISION=${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.revision'] }}
|
REVISION=${{ fromJSON(steps.meta.outputs.json).labels['org.opencontainers.image.revision'] }}
|
||||||
# https://github.com/docker/setup-qemu-action#about
|
# https://github.com/docker/setup-qemu-action#about
|
||||||
# platforms: linux/amd64,linux/arm64,linux/riscv64,linux/ppc64le,linux/s390x,linux/386,linux/mips64le,linux/mips64,linux/arm/v7,linux/arm/v6
|
# platforms: linux/amd64,linux/arm64,linux/riscv64,linux/ppc64le,linux/s390x,linux/386,linux/mips64le,linux/mips64,linux/arm/v7,linux/arm/v6
|
||||||
platforms: linux/amd64,linux/arm64,linux/arm/v7,linux/arm/v6
|
platforms: linux/amd64,linux/arm64
|
||||||
cache-from: type=local,src=/tmp/.buildx-cache
|
cache-from: type=local,src=/tmp/.buildx-cache
|
||||||
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max
|
cache-to: type=local,dest=/tmp/.buildx-cache-new,mode=max
|
||||||
|
|
||||||
|
|||||||
4
.github/workflows/repo-maintenance.yml
vendored
4
.github/workflows/repo-maintenance.yml
vendored
@ -212,9 +212,9 @@ jobs:
|
|||||||
}
|
}
|
||||||
|
|
||||||
const CUTOFF_1_DAYS = 180;
|
const CUTOFF_1_DAYS = 180;
|
||||||
const CUTOFF_1_COUNT = 5;
|
const CUTOFF_1_COUNT = 10;
|
||||||
const CUTOFF_2_DAYS = 365;
|
const CUTOFF_2_DAYS = 365;
|
||||||
const CUTOFF_2_COUNT = 10;
|
const CUTOFF_2_COUNT = 20;
|
||||||
|
|
||||||
const cutoff1Date = new Date();
|
const cutoff1Date = new Date();
|
||||||
cutoff1Date.setDate(cutoff1Date.getDate() - CUTOFF_1_DAYS);
|
cutoff1Date.setDate(cutoff1Date.getDate() - CUTOFF_1_DAYS);
|
||||||
|
|||||||
@ -63,7 +63,7 @@ The homepage team appreciates all effort and interest from the community in fili
|
|||||||
- Issues, pull requests and discussions that are closed will be locked after 30 days of inactivity.
|
- Issues, pull requests and discussions that are closed will be locked after 30 days of inactivity.
|
||||||
- Discussions with a marked answer will be automatically closed.
|
- Discussions with a marked answer will be automatically closed.
|
||||||
- Discussions in the 'General' or 'Support' categories will be closed after 180 days of inactivity.
|
- Discussions in the 'General' or 'Support' categories will be closed after 180 days of inactivity.
|
||||||
- Feature requests that do not meet the following thresholds will be closed: 5 "up-votes" after 180 days of inactivity or 10 "up-votes" after 365 days.
|
- Feature requests that do not meet the following thresholds will be closed: 10 "up-votes" after 180 days of inactivity or 20 "up-votes" after 365 days.
|
||||||
|
|
||||||
In all cases, threads can be re-opened by project maintainers and, of course, users can always create a new discussion for related concerns.
|
In all cases, threads can be re-opened by project maintainers and, of course, users can always create a new discussion for related concerns.
|
||||||
Finally, remember that all information remains searchable and 'closed' feature requests can still serve as inspiration for new features.
|
Finally, remember that all information remains searchable and 'closed' feature requests can still serve as inspiration for new features.
|
||||||
|
|||||||
11
Dockerfile
11
Dockerfile
@ -1,7 +1,7 @@
|
|||||||
# syntax = docker/dockerfile:latest
|
# syntax = docker/dockerfile:latest
|
||||||
|
|
||||||
# Install dependencies only when needed
|
# Install dependencies only when needed
|
||||||
FROM docker.io/node:18-alpine AS deps
|
FROM docker.io/node:22-alpine AS deps
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
@ -17,7 +17,7 @@ RUN --mount=type=cache,id=pnpm-store,target=/root/.local/share/pnpm/store pnpm f
|
|||||||
RUN --mount=type=cache,id=pnpm-store,target=/root/.local/share/pnpm/store pnpm install -r --offline
|
RUN --mount=type=cache,id=pnpm-store,target=/root/.local/share/pnpm/store pnpm install -r --offline
|
||||||
|
|
||||||
# Rebuild the source code only when needed
|
# Rebuild the source code only when needed
|
||||||
FROM docker.io/node:18-alpine AS builder
|
FROM docker.io/node:22-alpine AS builder
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
ARG BUILDTIME
|
ARG BUILDTIME
|
||||||
@ -33,7 +33,7 @@ RUN npm run telemetry \
|
|||||||
&& NEXT_PUBLIC_BUILDTIME=$BUILDTIME NEXT_PUBLIC_VERSION=$VERSION NEXT_PUBLIC_REVISION=$REVISION npm run build
|
&& NEXT_PUBLIC_BUILDTIME=$BUILDTIME NEXT_PUBLIC_VERSION=$VERSION NEXT_PUBLIC_REVISION=$REVISION npm run build
|
||||||
|
|
||||||
# Production image, copy all the files and run next
|
# Production image, copy all the files and run next
|
||||||
FROM docker.io/node:18-alpine AS runner
|
FROM docker.io/node:22-alpine AS runner
|
||||||
LABEL org.opencontainers.image.title "Homepage"
|
LABEL org.opencontainers.image.title "Homepage"
|
||||||
LABEL org.opencontainers.image.description "A self-hosted services landing page, with docker and service integrations."
|
LABEL org.opencontainers.image.description "A self-hosted services landing page, with docker and service integrations."
|
||||||
LABEL org.opencontainers.image.url="https://github.com/gethomepage/homepage"
|
LABEL org.opencontainers.image.url="https://github.com/gethomepage/homepage"
|
||||||
@ -41,7 +41,7 @@ LABEL org.opencontainers.image.documentation='https://github.com/gethomepage/hom
|
|||||||
LABEL org.opencontainers.image.source='https://github.com/gethomepage/homepage'
|
LABEL org.opencontainers.image.source='https://github.com/gethomepage/homepage'
|
||||||
LABEL org.opencontainers.image.licenses='Apache-2.0'
|
LABEL org.opencontainers.image.licenses='Apache-2.0'
|
||||||
|
|
||||||
ENV NODE_ENV production
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
@ -56,7 +56,8 @@ COPY --link --chmod=755 docker-entrypoint.sh /usr/local/bin/
|
|||||||
|
|
||||||
RUN apk add --no-cache su-exec
|
RUN apk add --no-cache su-exec
|
||||||
|
|
||||||
ENV PORT 3000
|
ENV HOSTNAME=::
|
||||||
|
ENV PORT=3000
|
||||||
EXPOSE $PORT
|
EXPOSE $PORT
|
||||||
|
|
||||||
HEALTHCHECK --interval=10s --timeout=3s --start-period=20s \
|
HEALTHCHECK --interval=10s --timeout=3s --start-period=20s \
|
||||||
|
|||||||
@ -38,7 +38,7 @@ With features like quick search, bookmarks, weather support, a wide range of int
|
|||||||
|
|
||||||
- **Fast** - The site is statically generated at build time for instant load times.
|
- **Fast** - The site is statically generated at build time for instant load times.
|
||||||
- **Secure** - All API requests to backend services are proxied, keeping your API keys hidden. Constantly reviewed for security by the community.
|
- **Secure** - All API requests to backend services are proxied, keeping your API keys hidden. Constantly reviewed for security by the community.
|
||||||
- **For Everyone** - Images built for AMD64, ARM64, ARMv7, and ARMv6.
|
- **For Everyone** - Images built for AMD64, ARM64.
|
||||||
- **Full i18n** - Support for over 40 languages.
|
- **Full i18n** - Support for over 40 languages.
|
||||||
- **Service & Web Bookmarks** - Add custom links to the homepage.
|
- **Service & Web Bookmarks** - Add custom links to the homepage.
|
||||||
- **Docker Integration** - Container status and stats. Automatic service discovery via labels.
|
- **Docker Integration** - Container status and stats. Automatic service discovery via labels.
|
||||||
@ -52,7 +52,7 @@ Homepage has built-in support for Docker, and can automatically discover and add
|
|||||||
|
|
||||||
## Service Widgets
|
## Service Widgets
|
||||||
|
|
||||||
Homepage also has support for over 100 3rd party services, including all popular starr apps, and most popular self-hosted apps. Some examples include: Radarr, Sonarr, Lidarr, Bazarr, Ombi, Tautulli, Plex, Jellyfin, Emby, Transmission, qBittorrent, Deluge, Jackett, NZBGet, SABnzbd, etc. As well as service integrations, Homepage also has a number of information providers, sourcing information from a variety of external 3rd party APIs. See the [Service](https://gethomepage.dev/widgets/) page for more information.
|
Homepage also has support for hundreds of 3rd-party services, including all popular \*arr apps, and most popular self-hosted apps. Some examples include: Radarr, Sonarr, Lidarr, Bazarr, Ombi, Tautulli, Plex, Jellyfin, Emby, Transmission, qBittorrent, Deluge, Jackett, NZBGet, SABnzbd, etc. As well as service integrations, Homepage also has a number of information providers, sourcing information from a variety of external 3rd-party APIs. See the [Service](https://gethomepage.dev/widgets/) page for more information.
|
||||||
|
|
||||||
## Information Widgets
|
## Information Widgets
|
||||||
|
|
||||||
|
|||||||
@ -153,6 +153,18 @@ labels:
|
|||||||
- homepage.widget.fields=["field1","field2"] # optional
|
- homepage.widget.fields=["field1","field2"] # optional
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Multiple widgets can be specified by incrementing the index, e.g.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
labels: ...
|
||||||
|
- homepage.widget[0].type=emby
|
||||||
|
- homepage.widget[0].url=http://emby.home
|
||||||
|
- homepage.widget[0].key=yourembyapikeyhere
|
||||||
|
- homepage.widget[1].type=uptimekuma
|
||||||
|
- homepage.widget[1].url=http://uptimekuma.home
|
||||||
|
- homepage.widget[1].slug=youreventslughere
|
||||||
|
```
|
||||||
|
|
||||||
You can add specify fields for e.g. the [CustomAPI](../widgets/services/customapi.md) widget by using array-style dot notation:
|
You can add specify fields for e.g. the [CustomAPI](../widgets/services/customapi.md) widget by using array-style dot notation:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
|
|||||||
24
docs/configs/info-widgets.md
Normal file
24
docs/configs/info-widgets.md
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
title: Information Widgets
|
||||||
|
description: Homepage info widgets.
|
||||||
|
---
|
||||||
|
|
||||||
|
Information widgets are widgets that provide information about your system or environment and are displayed at the top of the homepage. You can find a list of all available info widgets under the [Info Widgets](../widgets/info/index.md) section.
|
||||||
|
|
||||||
|
Info widgets are defined in the widgets.yaml
|
||||||
|
|
||||||
|
Each widget has its own configuration options, which are detailed in the widget's documentation.
|
||||||
|
|
||||||
|
## Layout
|
||||||
|
|
||||||
|
Info widgets are displayed in the order they are defined in the `widgets.yaml` file. You can change the order by moving the widgets around in the file. However, some widgets (weather, search and datetime) are aligned to the right side of the screen which can affect the layout of the widgets.
|
||||||
|
|
||||||
|
## Adding A Link
|
||||||
|
|
||||||
|
You can add a link to an info widget such as the logo or text widgets by adding an `href` option, for example:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
logo:
|
||||||
|
href: https://example.com
|
||||||
|
target: _blank # Optional, can be set in settings
|
||||||
|
```
|
||||||
@ -1,40 +0,0 @@
|
|||||||
---
|
|
||||||
title: Service Widgets
|
|
||||||
description: Service Widget Configuration
|
|
||||||
---
|
|
||||||
|
|
||||||
Unless otherwise noted, URLs should not end with a `/` or other API path. Each widget will handle the path on its own.
|
|
||||||
|
|
||||||
Each service can have one widget attached to it (often matching the service type, but that's not forced).
|
|
||||||
|
|
||||||
In addition to the href of the service, you can also specify the target location in which to open that link. See [Link Target](settings.md#link-target) for more details.
|
|
||||||
|
|
||||||
Using Emby as an example, this is how you would attach the Emby service widget.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- Emby:
|
|
||||||
icon: emby.png
|
|
||||||
href: http://emby.host.or.ip/
|
|
||||||
description: Movies & TV Shows
|
|
||||||
widget:
|
|
||||||
type: emby
|
|
||||||
url: http://emby.host.or.ip
|
|
||||||
key: apikeyapikeyapikeyapikeyapikey
|
|
||||||
```
|
|
||||||
|
|
||||||
## Field Visibility
|
|
||||||
|
|
||||||
Each widget can optionally provide a list of which fields should be visible via the `fields` widget property. If no fields are specified, then all fields will be displayed. The `fields` property must be a valid YAML array of strings. As an example, here is the entry for Sonarr showing only a couple of fields.
|
|
||||||
|
|
||||||
**In all cases a widget will work and display all fields without specifying the `fields` property.**
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- Sonarr:
|
|
||||||
icon: sonarr.png
|
|
||||||
href: http://sonarr.host.or.ip
|
|
||||||
widget:
|
|
||||||
type: sonarr
|
|
||||||
fields: ["wanted", "queued"]
|
|
||||||
url: http://sonarr.host.or.ip
|
|
||||||
key: apikeyapikeyapikeyapikeyapikey
|
|
||||||
```
|
|
||||||
@ -21,6 +21,23 @@ Groups are defined as top-level array entries.
|
|||||||
|
|
||||||
<img width="1038" alt="Service Groups" src="https://user-images.githubusercontent.com/82196/187040754-28065242-4534-4409-881c-93d1921c6141.png">
|
<img width="1038" alt="Service Groups" src="https://user-images.githubusercontent.com/82196/187040754-28065242-4534-4409-881c-93d1921c6141.png">
|
||||||
|
|
||||||
|
### Nested Groups
|
||||||
|
|
||||||
|
Groups can be nested by using the same format as the top-level groups.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- Group A:
|
||||||
|
- Service A:
|
||||||
|
href: http://localhost/
|
||||||
|
|
||||||
|
- Group B:
|
||||||
|
- Service B:
|
||||||
|
href: http://localhost/
|
||||||
|
|
||||||
|
- Service C:
|
||||||
|
href: http://localhost/
|
||||||
|
```
|
||||||
|
|
||||||
## Services
|
## Services
|
||||||
|
|
||||||
Services are defined as array entries on groups,
|
Services are defined as array entries on groups,
|
||||||
@ -43,6 +60,60 @@ Services are defined as array entries on groups,
|
|||||||
|
|
||||||
<img width="1038" alt="Service Services" src="https://user-images.githubusercontent.com/82196/187040763-038023a2-8bee-4d87-b5cc-13447e7365a4.png">
|
<img width="1038" alt="Service Services" src="https://user-images.githubusercontent.com/82196/187040763-038023a2-8bee-4d87-b5cc-13447e7365a4.png">
|
||||||
|
|
||||||
|
### Service Widgets
|
||||||
|
|
||||||
|
Each service can have widgets attached to it (often matching the service type, but that's not forced).
|
||||||
|
|
||||||
|
In addition to the href of the service, you can also specify the target location in which to open that link. See [Link Target](settings.md#link-target) for more details.
|
||||||
|
|
||||||
|
Using Emby as an example, this is how you would attach the Emby service widget.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- Emby:
|
||||||
|
icon: emby.png
|
||||||
|
href: http://emby.host.or.ip/
|
||||||
|
description: Movies & TV Shows
|
||||||
|
widget:
|
||||||
|
type: emby
|
||||||
|
url: http://emby.host.or.ip
|
||||||
|
key: apikeyapikeyapikeyapikeyapikey
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Multiple Widgets
|
||||||
|
|
||||||
|
Each service can have multiple widgets attached to it, for example:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- Emby:
|
||||||
|
icon: emby.png
|
||||||
|
href: http://emby.host.or.ip/
|
||||||
|
description: Movies & TV Shows
|
||||||
|
widgets:
|
||||||
|
- type: emby
|
||||||
|
url: http://emby.host.or.ip
|
||||||
|
key: apikeyapikeyapikeyapikeyapikey
|
||||||
|
- type: uptimekuma
|
||||||
|
url: http://uptimekuma.host.or.ip:port
|
||||||
|
slug: statuspageslug
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Field Visibility
|
||||||
|
|
||||||
|
Each widget can optionally provide a list of which fields should be visible via the `fields` widget property. If no fields are specified, then all fields will be displayed. The `fields` property must be a valid YAML array of strings. As an example, here is the entry for Sonarr showing only a couple of fields.
|
||||||
|
|
||||||
|
**In all cases a widget will work and display all fields without specifying the `fields` property.**
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
- Sonarr:
|
||||||
|
icon: sonarr.png
|
||||||
|
href: http://sonarr.host.or.ip
|
||||||
|
widget:
|
||||||
|
type: sonarr
|
||||||
|
fields: ["wanted", "queued"]
|
||||||
|
url: http://sonarr.host.or.ip
|
||||||
|
key: apikeyapikeyapikeyapikeyapikey
|
||||||
|
```
|
||||||
|
|
||||||
## Descriptions
|
## Descriptions
|
||||||
|
|
||||||
Services may have descriptions,
|
Services may have descriptions,
|
||||||
@ -63,7 +134,7 @@ Services may have descriptions,
|
|||||||
|
|
||||||
## Icons
|
## Icons
|
||||||
|
|
||||||
Services may have an icon attached to them, you can use icons from [Dashboard Icons](https://github.com/walkxcode/dashboard-icons) automatically, by passing the name of the icon, with, or without `.png` or with `.svg` to use the svg version.
|
Services may have an icon attached to them, you can use icons from [Dashboard Icons](https://github.com/homarr-labs/dashboard-icons) automatically, by passing the name of the icon, with, or without `.png`, `.webp` or `.svg` to specify the desired version.
|
||||||
|
|
||||||
You can also specify prefixed icons from:
|
You can also specify prefixed icons from:
|
||||||
|
|
||||||
|
|||||||
@ -13,6 +13,14 @@ You can customize the title of the page if you'd like.
|
|||||||
title: My Awesome Homepage
|
title: My Awesome Homepage
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Description
|
||||||
|
|
||||||
|
You can customize the description of the page if you'd like.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
description: A description of my awesome homepage
|
||||||
|
```
|
||||||
|
|
||||||
## Start URL
|
## Start URL
|
||||||
|
|
||||||
You can customize the start_url as required for installable apps. The default is "/".
|
You can customize the start_url as required for installable apps. The default is "/".
|
||||||
@ -118,6 +126,22 @@ As an example, this would produce the following layout:
|
|||||||
|
|
||||||
<img width="1260" alt="Screenshot 2022-09-15 at 8 03 57 PM" src="https://user-images.githubusercontent.com/82196/190466646-8ca94505-0fcf-4964-9687-3a6c7cd3144f.png">
|
<img width="1260" alt="Screenshot 2022-09-15 at 8 03 57 PM" src="https://user-images.githubusercontent.com/82196/190466646-8ca94505-0fcf-4964-9687-3a6c7cd3144f.png">
|
||||||
|
|
||||||
|
### Icons-Only Layout
|
||||||
|
|
||||||
|
You can also specify the an icon-only layout for bookmarks, either like so:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
layout:
|
||||||
|
Media:
|
||||||
|
iconsOnly: true
|
||||||
|
```
|
||||||
|
|
||||||
|
or globally:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
bookmarksStyle: icons
|
||||||
|
```
|
||||||
|
|
||||||
### Sorting
|
### Sorting
|
||||||
|
|
||||||
Service groups and bookmark groups can be mixed in order, **but should use different group names**. If you do not specify any bookmark groups they will all show at the bottom of the page.
|
Service groups and bookmark groups can be mixed in order, **but should use different group names**. If you do not specify any bookmark groups they will all show at the bottom of the page.
|
||||||
@ -137,6 +161,27 @@ layout:
|
|||||||
columns: 3
|
columns: 3
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Nested Groups
|
||||||
|
|
||||||
|
If your services config has nested groups, you can apply settings to these groups by nesting them in the layout block
|
||||||
|
and using the same settings. For example
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
layout:
|
||||||
|
Group A:
|
||||||
|
style: row
|
||||||
|
columns: 4
|
||||||
|
Group C:
|
||||||
|
style: row
|
||||||
|
columns: 2
|
||||||
|
Nested Group A:
|
||||||
|
style: row
|
||||||
|
columns: 2
|
||||||
|
Nested Group B:
|
||||||
|
style: row
|
||||||
|
columns: 2
|
||||||
|
```
|
||||||
|
|
||||||
### Headers
|
### Headers
|
||||||
|
|
||||||
You can hide headers for each section in the layout as well by passing `header` as false, like so:
|
You can hide headers for each section in the layout as well by passing `header` as false, like so:
|
||||||
@ -348,12 +393,12 @@ This can also be set for individual services. Note setting this at the service l
|
|||||||
|
|
||||||
## Providers
|
## Providers
|
||||||
|
|
||||||
The `providers` section allows you to define shared API provider options and secrets. Currently this allows you to define your weather API keys in secret and is also the location of the Longhorn URL and credentials.
|
The `providers` section allows you to define shared API provider options and secrets.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
providers:
|
providers:
|
||||||
openweathermap: openweathermapapikey
|
openweathermap: openweathermapapikey
|
||||||
weatherapi: weatherapiapikey
|
finnhub: yourfinnhubapikeyhere
|
||||||
longhorn:
|
longhorn:
|
||||||
url: https://longhorn.example.com
|
url: https://longhorn.example.com
|
||||||
username: admin
|
username: admin
|
||||||
@ -363,10 +408,10 @@ 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
|
||||||
- weatherapi:
|
- openweathermap:
|
||||||
latitude: 50.449684
|
latitude: 50.449684
|
||||||
longitude: 30.525026
|
longitude: 30.525026
|
||||||
provider: weatherapi
|
provider: openweathermap
|
||||||
```
|
```
|
||||||
|
|
||||||
## Quick Launch
|
## Quick Launch
|
||||||
|
|||||||
@ -175,6 +175,7 @@ data:
|
|||||||
expanded: true
|
expanded: true
|
||||||
cpu: true
|
cpu: true
|
||||||
memory: true
|
memory: true
|
||||||
|
network: default
|
||||||
- search:
|
- search:
|
||||||
provider: duckduckgo
|
provider: duckduckgo
|
||||||
target: _blank
|
target: _blank
|
||||||
@ -209,7 +210,7 @@ rules:
|
|||||||
- get
|
- get
|
||||||
- list
|
- list
|
||||||
- apiGroups:
|
- apiGroups:
|
||||||
- traefik.containo.us
|
- traefik.io
|
||||||
resources:
|
resources:
|
||||||
- ingressroutes
|
- ingressroutes
|
||||||
verbs:
|
verbs:
|
||||||
@ -370,7 +371,7 @@ prevent unnecessary re-renders on page loads and window / tab focusing. The
|
|||||||
procedure for enabling sticky sessions depends on your Ingress controller. Below
|
procedure for enabling sticky sessions depends on your Ingress controller. Below
|
||||||
is an example using Traefik as the Ingress controller.
|
is an example using Traefik as the Ingress controller.
|
||||||
|
|
||||||
```
|
```yaml
|
||||||
apiVersion: traefik.io/v1alpha1
|
apiVersion: traefik.io/v1alpha1
|
||||||
kind: IngressRoute
|
kind: IngressRoute
|
||||||
metadata:
|
metadata:
|
||||||
|
|||||||
@ -23,3 +23,5 @@ Finally, run the server:
|
|||||||
```bash
|
```bash
|
||||||
pnpm start
|
pnpm start
|
||||||
```
|
```
|
||||||
|
|
||||||
|
When updating homepage versions you will need to re-build the static files i.e. repeat the process above.
|
||||||
|
|||||||
@ -17,7 +17,7 @@ hide:
|
|||||||
|
|
||||||
All service widgets work essentially the same, that is, homepage makes a proxied call to an API made available by that service. The majority of the time widgets don't work it is a configuration issue. Of course, sometimes things do break. Some basic steps to try:
|
All service widgets work essentially the same, that is, homepage makes a proxied call to an API made available by that service. The majority of the time widgets don't work it is a configuration issue. Of course, sometimes things do break. Some basic steps to try:
|
||||||
|
|
||||||
1. Ensure that you follow the rule mentioned on https://gethomepage.dev/configs/service-widgets/. **Unless otherwise noted, URLs should not end with a / or other API path. Each widget will handle the path on its own.**. This is very important as including a trailing slash can result in an error.
|
1. **URLs should not end with a / or other API path. Each widget will handle the path on its own.**. Including a trailing slash can result in an error.
|
||||||
|
|
||||||
2. Verify the homepage installation can connect to the IP address or host you are using for the widget `url`. This is most simply achieved by pinging the server from the homepage machine, in Docker this means _from inside the container_ itself, e.g.:
|
2. Verify the homepage installation can connect to the IP address or host you are using for the widget `url`. This is most simply achieved by pinging the server from the homepage machine, in Docker this means _from inside the container_ itself, e.g.:
|
||||||
|
|
||||||
|
|||||||
@ -46,16 +46,16 @@ See the [pre-commit documentation](https://pre-commit.com/#install) to get start
|
|||||||
In general, homepage is meant to be a dashboard for 'self-hosted' services and we believe it is a small way we can help showcase this kind of software. While exceptions are made, mostly when there is no viable
|
In general, homepage is meant to be a dashboard for 'self-hosted' services and we believe it is a small way we can help showcase this kind of software. While exceptions are made, mostly when there is no viable
|
||||||
self-hosted / open-source alternative, we ask that any widgets, etc. are developed primarily for a self-hosted tool.
|
self-hosted / open-source alternative, we ask that any widgets, etc. are developed primarily for a self-hosted tool.
|
||||||
|
|
||||||
## New Feature Guidelines
|
## New Feature or Enhancement Guidelines {#new-feature-guidelines}
|
||||||
|
|
||||||
- New features should usually be linked to an existing feature request. The purpose of this requirement is to avoid the addition (and maintenance) of features that might only benefit a small number of users.
|
- New features or enhancements, **no matter how small**, must be linked to an existing feature request. The purpose of this requirement is to avoid the addition (and maintenance) of features that might only benefit a small number of users.
|
||||||
- If you have ideas for a larger feature you may want to open a discussion first.
|
- If you have ideas for a larger feature you may want to open a discussion first.
|
||||||
|
|
||||||
## Service Widget Guidelines
|
## Service Widget Guidelines
|
||||||
|
|
||||||
To ensure cohesiveness of various widgets, the following should be used as a guide for developing new widgets:
|
To ensure cohesiveness of various widgets, the following should be used as a guide for developing new widgets:
|
||||||
|
|
||||||
- Please only submit widgets that target a feature request discussion with at least 10 'up-votes'. The purpose of this requirement is to avoid the addition (and maintenance) of service widgets that might only benefit a small number of users.
|
- Please only submit widgets that target a feature request discussion with at least 20 'up-votes'. The purpose of this requirement is to avoid the addition (and maintenance) of service widgets that might only benefit a small number of users.
|
||||||
- Note that we reserve the right to decline widgets for projects that are very young (eg < ~1y) or those with a small reach (eg low GitHub stars). Again, this is in an effort to keep overall widget maintenance under control.
|
- Note that we reserve the right to decline widgets for projects that are very young (eg < ~1y) or those with a small reach (eg low GitHub stars). Again, this is in an effort to keep overall widget maintenance under control.
|
||||||
- Widgets should be only one row of blocks
|
- Widgets should be only one row of blocks
|
||||||
- Widgets should be no more than 4 blocks wide and generally conform to the styling / design choices of other widgets
|
- Widgets should be no more than 4 blocks wide and generally conform to the styling / design choices of other widgets
|
||||||
|
|||||||
@ -50,7 +50,7 @@ You can also pass API keys from the widget configuration to the proxy handler, f
|
|||||||
|
|
||||||
### `credentialedProxyHandler`
|
### `credentialedProxyHandler`
|
||||||
|
|
||||||
A proxy handler that makes authenticated by setting request headers. Credentials are pulled from the widgets configuration.
|
A proxy handler that makes authenticated requests by setting request headers. Credentials are pulled from the widgets configuration.
|
||||||
|
|
||||||
By default the key is passed as an `X-API-Key` header. If you need to pass the key as something else, either add a case to the credentialedProxyHandler or create a new proxy handler.
|
By default the key is passed as an `X-API-Key` header. If you need to pass the key as something else, either add a case to the credentialedProxyHandler or create a new proxy handler.
|
||||||
|
|
||||||
|
|||||||
@ -19,12 +19,17 @@ Service widgets are used to display the status of a service, often a web service
|
|||||||
description: Watch movies and TV shows.
|
description: Watch movies and TV shows.
|
||||||
server: localhost
|
server: localhost
|
||||||
container: plex
|
container: plex
|
||||||
widget:
|
widgets:
|
||||||
type: tautulli
|
- type: tautulli
|
||||||
url: http://172.16.1.1:8181
|
url: http://172.16.1.1:8181
|
||||||
key: aabbccddeeffgghhiijjkkllmmnnoo
|
key: aabbccddeeffgghhiijjkkllmmnnoo
|
||||||
|
- type: uptimekuma
|
||||||
|
url: http://172.16.1.2:8080
|
||||||
|
slug: aaaaaaabbbbb
|
||||||
```
|
```
|
||||||
|
|
||||||
|
More detail on configuring service widgets can be found in the [Service Widgets Config](../configs/services.md) section.
|
||||||
|
|
||||||
## Info Widgets
|
## Info Widgets
|
||||||
|
|
||||||
Info widgets are used to display information in the header, often about your system or environment. Info widgets are defined your `widgets.yaml` file. Here's an example:
|
Info widgets are used to display information in the header, often about your system or environment. Info widgets are defined your `widgets.yaml` file. Here's an example:
|
||||||
@ -36,3 +41,5 @@ Info widgets are used to display information in the header, often about your sys
|
|||||||
longitude: -117.51
|
longitude: -117.51
|
||||||
cache: 5
|
cache: 5
|
||||||
```
|
```
|
||||||
|
|
||||||
|
More detail on configuring info widgets can be found in the [Info Widgets Config](../configs/info-widgets.md) section.
|
||||||
|
|||||||
@ -3,7 +3,7 @@ title: Open-Meteo
|
|||||||
description: Open-Meteo Information Widget Configuration
|
description: Open-Meteo Information Widget Configuration
|
||||||
---
|
---
|
||||||
|
|
||||||
No registration is required at all! See [https://open-meteo.com/en/docs](https://open-meteo.com/en/docs)
|
Homepage's recommended weather widget. No registration is required at all! See [https://open-meteo.com/en/docs](https://open-meteo.com/en/docs)
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
- openmeteo:
|
- openmeteo:
|
||||||
|
|||||||
@ -24,9 +24,10 @@ _Note: unfortunately, the package used for getting CPU temp ([systeminformation]
|
|||||||
tempmin: 0 # optional, minimum cpu temp
|
tempmin: 0 # optional, minimum cpu temp
|
||||||
tempmax: 100 # optional, maximum 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, options: 'imperial' or 'metric'
|
||||||
refresh: 3000 # optional, in ms
|
refresh: 3000 # optional, in ms
|
||||||
diskUnits: bytes # optional, bytes (default) or bbytes. Only applies to disk
|
diskUnits: bytes # optional, bytes (default) or bbytes. Only applies to disk
|
||||||
|
network: true # optional, uses 'default' if true or specify a network interface name
|
||||||
```
|
```
|
||||||
|
|
||||||
You can also pass a `label` option, which allows you to group resources under named sections,
|
You can also pass a `label` option, which allows you to group resources under named sections,
|
||||||
|
|||||||
@ -7,7 +7,7 @@ _(Find the Unifi Controller service widget [here](../services/unifi-controller.m
|
|||||||
|
|
||||||
You can display general connectivity status from your Unifi (Network) Controller.
|
You can display general connectivity status from your Unifi (Network) Controller.
|
||||||
|
|
||||||
!!!
|
!!! warning
|
||||||
|
|
||||||
When authenticating you will want to use a local account that has at least read privileges.
|
When authenticating you will want to use a local account that has at least read privileges.
|
||||||
|
|
||||||
|
|||||||
@ -1,22 +0,0 @@
|
|||||||
---
|
|
||||||
title: Weather API
|
|
||||||
description: Weather API Information Widget Configuration
|
|
||||||
---
|
|
||||||
|
|
||||||
**Note: this widget is considered 'deprecated' since there is no longer a free Weather API tier for new members. See the openmeteo or openweathermap widgets for alternatives.**
|
|
||||||
|
|
||||||
The free tier is all that's required, you will need to [register](https://www.weatherapi.com/signup.aspx) and grab your API key.
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
- weatherapi:
|
|
||||||
label: Kyiv # optional
|
|
||||||
latitude: 50.449684
|
|
||||||
longitude: 30.525026
|
|
||||||
units: metric # or imperial
|
|
||||||
apiKey: yourweatherapikey
|
|
||||||
cache: 5 # Time in minutes to cache API responses, to stay within limits
|
|
||||||
format: # optional, Intl.NumberFormat options
|
|
||||||
maximumFractionDigits: 1
|
|
||||||
```
|
|
||||||
|
|
||||||
You can optionally not pass a `latitude` and `longitude` and the widget will use your current location (requires a secure context, eg. HTTPS).
|
|
||||||
@ -7,11 +7,16 @@ Learn more about [Beszel](https://github.com/henrygd/beszel)
|
|||||||
|
|
||||||
The widget has two modes, a single system with detailed info if `systemId` is provided, or an overview of all systems if `systemId` is not provided.
|
The widget has two modes, a single system with detailed info if `systemId` is provided, or an overview of all systems if `systemId` is not provided.
|
||||||
|
|
||||||
The `systemID` in the `id` field on the collections page of Beszel.
|
The `systemID` is the `id` field on the collections page of Beszel under the PocketBase admin panel. You can also use the 'nice name' from the Beszel UI.
|
||||||
|
|
||||||
Allowed fields for 'overview' mode: `["systems", "up"]`
|
Allowed fields for 'overview' mode: `["systems", "up"]`
|
||||||
Allowed fields for a single system: `["name", "status", "updated", "cpu", "memory", "disk", "network"]`
|
Allowed fields for a single system: `["name", "status", "updated", "cpu", "memory", "disk", "network"]`
|
||||||
|
|
||||||
|
| Beszel Version | Homepage Widget Version |
|
||||||
|
| -------------- | ----------------------- |
|
||||||
|
| < 0.9.0 | 1 (default) |
|
||||||
|
| >= 0.9.0 | 2 |
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
widget:
|
widget:
|
||||||
type: beszel
|
type: beszel
|
||||||
@ -19,4 +24,5 @@ widget:
|
|||||||
username: username # email
|
username: username # email
|
||||||
password: password
|
password: password
|
||||||
systemId: systemId # optional
|
systemId: systemId # optional
|
||||||
|
version: 2 # optional, default is 1
|
||||||
```
|
```
|
||||||
|
|||||||
@ -62,10 +62,12 @@ widget:
|
|||||||
format: size
|
format: size
|
||||||
```
|
```
|
||||||
|
|
||||||
Supported formats for the values are `text`, `number`, `float`, `percent`, `bytes`, `bitrate`, `size`, `date` and `relativeDate`.
|
Supported formats for the values are `text`, `number`, `float`, `percent`, `duration`, `bytes`, `bitrate`, `size`, `date` and `relativeDate`.
|
||||||
|
|
||||||
The `dateStyle` and `timeStyle` options of the `date` format are passed directly to [Intl.DateTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat) and the `style` and `numeric` options of `relativeDate` are passed to [Intl.RelativeTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/RelativeTimeFormat).
|
The `dateStyle` and `timeStyle` options of the `date` format are passed directly to [Intl.DateTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat) and the `style` and `numeric` options of `relativeDate` are passed to [Intl.RelativeTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/RelativeTimeFormat).
|
||||||
|
|
||||||
|
The `duration` format expects the duration to be specified in seconds. The `scale` transformation tool can be used if a conversion is required.
|
||||||
|
|
||||||
The `size` format will return the length of the array or string, or the number of keys in an object. This is then formatted as `number`.
|
The `size` format will return the length of the array or string, or the number of keys in an object. This is then formatted as `number`.
|
||||||
|
|
||||||
## Example
|
## Example
|
||||||
|
|||||||
@ -14,4 +14,5 @@ widget:
|
|||||||
type: deluge
|
type: deluge
|
||||||
url: http://deluge.host.or.ip
|
url: http://deluge.host.or.ip
|
||||||
password: password # webui password
|
password: password # webui password
|
||||||
|
enableLeechProgress: true # optional, defaults to false
|
||||||
```
|
```
|
||||||
|
|||||||
@ -16,5 +16,6 @@ To group both `offline` and `unknown` devices together, users should use the `of
|
|||||||
widget:
|
widget:
|
||||||
type: esphome
|
type: esphome
|
||||||
url: http://esphome.host.or.ip:port
|
url: http://esphome.host.or.ip:port
|
||||||
key: myesphomecookie # only if auth enabled, get the value from a request from the frontend e.g. `authenticated=myesphomecookie`
|
username: myesphomeuser # only if auth enabled
|
||||||
|
password: myesphomepass # only if auth enabled
|
||||||
```
|
```
|
||||||
|
|||||||
@ -3,7 +3,7 @@ title: EVCC
|
|||||||
description: EVCC Widget Configuration
|
description: EVCC Widget Configuration
|
||||||
---
|
---
|
||||||
|
|
||||||
Learn more about [EVSS](https://github.com/evcc-io/evcc).
|
Learn more about [EVCC](https://github.com/evcc-io/evcc).
|
||||||
|
|
||||||
Allowed fields: `["pv_power", "grid_power", "home_power", "charge_power]`.
|
Allowed fields: `["pv_power", "grid_power", "home_power", "charge_power]`.
|
||||||
|
|
||||||
|
|||||||
@ -51,6 +51,8 @@ The metric field in the configuration determines the type of system monitoring d
|
|||||||
|
|
||||||
`process`: Top 5 processes based on CPU usage. Gives an overview of which processes are consuming the most resources.
|
`process`: Top 5 processes based on CPU usage. Gives an overview of which processes are consuming the most resources.
|
||||||
|
|
||||||
|
`containers`: Docker or Kubernetes containers list. Shows up to 5 containers running on the system and their resource usage.
|
||||||
|
|
||||||
`network:<interface_name>`: Network data usage for the specified interface. Replace `<interface_name>` with the name of your network interface, e.g., `network:enp0s25`, as specified in glances.
|
`network:<interface_name>`: Network data usage for the specified interface. Replace `<interface_name>` with the name of your network interface, e.g., `network:enp0s25`, as specified in glances.
|
||||||
|
|
||||||
`sensor:<sensor_id>`: Temperature of the specified sensor, typically used to monitor CPU temperature. Replace `<sensor_id>` with the name of your sensor, e.g., `sensor:Package id 0` as specified in glances.
|
`sensor:<sensor_id>`: Temperature of the specified sensor, typically used to monitor CPU temperature. Replace `<sensor_id>` with the name of your sensor, e.g., `sensor:Package id 0` as specified in glances.
|
||||||
|
|||||||
@ -11,7 +11,7 @@ Learn more about [Gluetun](https://github.com/qdm12/gluetun).
|
|||||||
|
|
||||||
Allowed fields: `["public_ip", "region", "country"]`.
|
Allowed fields: `["public_ip", "region", "country"]`.
|
||||||
|
|
||||||
To setup authentication, follow [the official Gluetun documentation](https://github.com/qdm12/gluetun-wiki/blob/main/setup/advanced/control-server.md#authentication).
|
To setup authentication, follow [the official Gluetun documentation](https://github.com/qdm12/gluetun-wiki/blob/main/setup/advanced/control-server.md#authentication). Note that to use the api key method, you must add the route `GET /v1/publicip/ip` to the `routes` array in your Gluetun config.toml.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
widget:
|
widget:
|
||||||
|
|||||||
@ -14,6 +14,7 @@ Allowed fields: `["name", "address", "last_seen", "status"]`.
|
|||||||
```yaml
|
```yaml
|
||||||
widget:
|
widget:
|
||||||
type: headscale
|
type: headscale
|
||||||
|
url: http://headscale.host.or.ip:port
|
||||||
nodeId: nodeid
|
nodeId: nodeid
|
||||||
key: headscaleapiaccesstoken
|
key: headscaleapiaccesstoken
|
||||||
```
|
```
|
||||||
|
|||||||
@ -15,4 +15,5 @@ widget:
|
|||||||
url: http://qbittorrent.host.or.ip
|
url: http://qbittorrent.host.or.ip
|
||||||
username: username
|
username: username
|
||||||
password: password
|
password: password
|
||||||
|
enableLeechProgress: true # optional, defaults to false
|
||||||
```
|
```
|
||||||
|
|||||||
@ -9,7 +9,7 @@ _(Find the Unifi Controller information widget [here](../info/unifi_controller.m
|
|||||||
|
|
||||||
You can display general connectivity status from your Unifi (Network) Controller.
|
You can display general connectivity status from your Unifi (Network) Controller.
|
||||||
|
|
||||||
!!!
|
!!! warning
|
||||||
|
|
||||||
When authenticating you will want to use a local account that has at least read privileges.
|
When authenticating you will want to use a local account that has at least read privileges.
|
||||||
|
|
||||||
@ -19,7 +19,7 @@ Allowed fields: `["uptime", "wan", "lan", "lan_users", "lan_devices", "wlan", "w
|
|||||||
|
|
||||||
!!! hint
|
!!! hint
|
||||||
|
|
||||||
If you enter e.g. incorrect credentials and receive an "API Error", you may need to recreate the container to clear the cache.
|
If you enter e.g. incorrect credentials and receive an "API Error", you may need to recreate the container or restart the service to clear the cache.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
widget:
|
widget:
|
||||||
|
|||||||
@ -21,8 +21,8 @@ nav:
|
|||||||
- configs/index.md
|
- configs/index.md
|
||||||
- configs/settings.md
|
- configs/settings.md
|
||||||
- configs/bookmarks.md
|
- configs/bookmarks.md
|
||||||
|
- configs/info-widgets.md
|
||||||
- configs/services.md
|
- configs/services.md
|
||||||
- configs/service-widgets.md
|
|
||||||
- configs/kubernetes.md
|
- configs/kubernetes.md
|
||||||
- configs/docker.md
|
- configs/docker.md
|
||||||
- configs/custom-css-js.md
|
- configs/custom-css-js.md
|
||||||
@ -142,6 +142,7 @@ nav:
|
|||||||
- widgets/services/spoolman.md
|
- widgets/services/spoolman.md
|
||||||
- widgets/services/stash.md
|
- widgets/services/stash.md
|
||||||
- widgets/services/stocks.md
|
- widgets/services/stocks.md
|
||||||
|
- widgets/services/suwayomi.md
|
||||||
- widgets/services/swagdashboard.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
|
||||||
@ -177,7 +178,6 @@ nav:
|
|||||||
- widgets/info/search.md
|
- widgets/info/search.md
|
||||||
- widgets/info/stocks.md
|
- widgets/info/stocks.md
|
||||||
- widgets/info/unifi_controller.md
|
- widgets/info/unifi_controller.md
|
||||||
- widgets/info/weather.md
|
|
||||||
- "Learn":
|
- "Learn":
|
||||||
- widgets/authoring/index.md
|
- widgets/authoring/index.md
|
||||||
- "Getting Started": widgets/authoring/getting-started.md
|
- "Getting Started": widgets/authoring/getting-started.md
|
||||||
|
|||||||
3169
package-lock.json
generated
3169
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
32
package.json
32
package.json
@ -10,36 +10,36 @@
|
|||||||
"telemetry": "next telemetry disable"
|
"telemetry": "next telemetry disable"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@headlessui/react": "^1.7.18",
|
"@headlessui/react": "^1.7.19",
|
||||||
"@kubernetes/client-node": "^0.17.1",
|
"@kubernetes/client-node": "^0.17.1",
|
||||||
"cal-parser": "^1.0.2",
|
"cal-parser": "^1.0.2",
|
||||||
"classnames": "^2.5.1",
|
"classnames": "^2.5.1",
|
||||||
"compare-versions": "^6.1.0",
|
"compare-versions": "^6.1.0",
|
||||||
"dockerode": "^4.0.2",
|
"dockerode": "^4.0.2",
|
||||||
"follow-redirects": "^1.15.9",
|
"follow-redirects": "^1.15.9",
|
||||||
"gamedig": "^5.1.2",
|
"gamedig": "^5.1.4",
|
||||||
"i18next": "^21.10.0",
|
"i18next": "^21.10.0",
|
||||||
"js-yaml": "^4.1.0",
|
"js-yaml": "^4.1.0",
|
||||||
"json-rpc-2.0": "^1.7.0",
|
"json-rpc-2.0": "^1.7.0",
|
||||||
"luxon": "^3.5.0",
|
"luxon": "^3.5.0",
|
||||||
"memory-cache": "^0.2.0",
|
"memory-cache": "^0.2.0",
|
||||||
"minecraft-ping-js": "^1.0.2",
|
"minecraft-ping-js": "^1.0.2",
|
||||||
"next": "^12.3.4",
|
"next": "^15.0.3",
|
||||||
"next-i18next": "^12.1.0",
|
"next-i18next": "^12.1.0",
|
||||||
"ping": "^0.4.4",
|
"ping": "^0.4.4",
|
||||||
"pretty-bytes": "^6.1.1",
|
"pretty-bytes": "^6.1.1",
|
||||||
"raw-body": "^3.0.0",
|
"raw-body": "^3.0.0",
|
||||||
"react": "^18.3.1",
|
"react": "^18.3.1",
|
||||||
"react-dom": "^18.2.0",
|
"react-dom": "^18.3.1",
|
||||||
"react-i18next": "^11.18.6",
|
"react-i18next": "^11.18.6",
|
||||||
"react-icons": "^4.12.0",
|
"react-icons": "^5.4.0",
|
||||||
"recharts": "^2.12.6",
|
"recharts": "^2.12.7",
|
||||||
"rrule": "^2.8.1",
|
"rrule": "^2.8.1",
|
||||||
"swr": "^1.3.0",
|
"swr": "^1.3.0",
|
||||||
"systeminformation": "^5.23.2",
|
"systeminformation": "^5.24.3",
|
||||||
"tough-cookie": "^4.1.3",
|
"tough-cookie": "^4.1.4",
|
||||||
"urbackup-server-api": "^0.52.1",
|
"urbackup-server-api": "^0.8.9",
|
||||||
"winston": "^3.11.0",
|
"winston": "^3.13.0",
|
||||||
"xml-js": "^1.6.11"
|
"xml-js": "^1.6.11"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
@ -47,17 +47,17 @@
|
|||||||
"autoprefixer": "^10.4.20",
|
"autoprefixer": "^10.4.20",
|
||||||
"eslint": "^8.57.1",
|
"eslint": "^8.57.1",
|
||||||
"eslint-config-airbnb": "^19.0.4",
|
"eslint-config-airbnb": "^19.0.4",
|
||||||
"eslint-config-next": "^14.2.3",
|
"eslint-config-next": "^14.2.4",
|
||||||
"eslint-config-prettier": "^9.1.0",
|
"eslint-config-prettier": "^9.1.0",
|
||||||
"eslint-plugin-import": "^2.31.0",
|
"eslint-plugin-import": "^2.31.0",
|
||||||
"eslint-plugin-jsx-a11y": "^6.8.0",
|
"eslint-plugin-jsx-a11y": "^6.9.0",
|
||||||
"eslint-plugin-prettier": "^5.2.1",
|
"eslint-plugin-prettier": "^5.2.1",
|
||||||
"eslint-plugin-react": "^7.37.1",
|
"eslint-plugin-react": "^7.37.3",
|
||||||
"eslint-plugin-react-hooks": "^4.6.2",
|
"eslint-plugin-react-hooks": "^4.6.2",
|
||||||
"postcss": "^8.4.47",
|
"postcss": "^8.4.48",
|
||||||
"prettier": "^3.2.5",
|
"prettier": "^3.3.2",
|
||||||
"tailwind-scrollbar": "^3.0.5",
|
"tailwind-scrollbar": "^3.0.5",
|
||||||
"tailwindcss": "^3.4.14",
|
"tailwindcss": "^3.4.17",
|
||||||
"typescript": "^5.6.3"
|
"typescript": "^5.6.3"
|
||||||
},
|
},
|
||||||
"optionalDependencies": {
|
"optionalDependencies": {
|
||||||
|
|||||||
2784
pnpm-lock.yaml
2784
pnpm-lock.yaml
File diff suppressed because it is too large
Load Diff
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Rooster",
|
"grid_power": "Rooster",
|
||||||
"home_power": "Verbruik",
|
"home_power": "Verbruik",
|
||||||
"charge_power": "Laaier",
|
"charge_power": "Laaier",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Aflaai",
|
"download": "Aflaai",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Naam",
|
"name": "Naam",
|
||||||
"systems": "Stelsels",
|
"systems": "Stelsels",
|
||||||
"up": "Op",
|
"up": "Op",
|
||||||
|
"down": "Af",
|
||||||
|
"paused": "Onderbreek",
|
||||||
|
"pending": "Afwagtend",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Opgedateer",
|
"updated": "Opgedateer",
|
||||||
"cpu": "SVE",
|
"cpu": "SVE",
|
||||||
@ -990,22 +993,22 @@
|
|||||||
"network": "NET"
|
"network": "NET"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Programme",
|
||||||
"synced": "Synced",
|
"synced": "Gesinkroniseer",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Nie Gesinchroniseer Nie",
|
||||||
"healthy": "Gesond",
|
"healthy": "Gesond",
|
||||||
"degraded": "Degraded",
|
"degraded": "Gedegradeer",
|
||||||
"progressing": "Progressing",
|
"progressing": "Vorderend",
|
||||||
"missing": "Vermis",
|
"missing": "Vermis",
|
||||||
"suspended": "Suspended"
|
"suspended": "Geskors"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Laai"
|
"loading": "Laai"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Groepe",
|
||||||
"issues": "Kwessies",
|
"issues": "Kwessies",
|
||||||
"merges": "Merge Requests",
|
"merges": "Saamvleg Versoeke",
|
||||||
"projects": "Projects"
|
"projects": "Projekte"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "شبكة",
|
"grid_power": "شبكة",
|
||||||
"home_power": "الاستهلاك",
|
"home_power": "الاستهلاك",
|
||||||
"charge_power": "شاحن",
|
"charge_power": "شاحن",
|
||||||
"watt_hour": "واط ساعة"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "التنزيل",
|
"download": "التنزيل",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "الاسم",
|
"name": "الاسم",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "يعمل",
|
"up": "يعمل",
|
||||||
|
"down": "لا يعمل",
|
||||||
|
"paused": "متوقف",
|
||||||
|
"pending": "معلق",
|
||||||
"status": "الحالة",
|
"status": "الحالة",
|
||||||
"updated": "محدث",
|
"updated": "محدث",
|
||||||
"cpu": "المعالج",
|
"cpu": "المعالج",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Статус",
|
"status": "Статус",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "Процесор",
|
"cpu": "Процесор",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Xarxa",
|
"grid_power": "Xarxa",
|
||||||
"home_power": "Consum",
|
"home_power": "Consum",
|
||||||
"charge_power": "Carregador",
|
"charge_power": "Carregador",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Descarregar",
|
"download": "Descarregar",
|
||||||
@ -350,7 +350,7 @@
|
|||||||
"queue": "Cua",
|
"queue": "Cua",
|
||||||
"processed": "Processat",
|
"processed": "Processat",
|
||||||
"errored": "Error",
|
"errored": "Error",
|
||||||
"saved": "Desat"
|
"saved": "Estalviat"
|
||||||
},
|
},
|
||||||
"traefik": {
|
"traefik": {
|
||||||
"routers": "Encaminadors",
|
"routers": "Encaminadors",
|
||||||
@ -581,7 +581,7 @@
|
|||||||
"clientIP": "Client"
|
"clientIP": "Client"
|
||||||
},
|
},
|
||||||
"scrutiny": {
|
"scrutiny": {
|
||||||
"passed": "Aprobat",
|
"passed": "Aprovat",
|
||||||
"failed": "Error",
|
"failed": "Error",
|
||||||
"unknown": "Desconegut"
|
"unknown": "Desconegut"
|
||||||
},
|
},
|
||||||
@ -820,7 +820,7 @@
|
|||||||
"total": "Total",
|
"total": "Total",
|
||||||
"running": "En execució",
|
"running": "En execució",
|
||||||
"stopped": "Aturat",
|
"stopped": "Aturat",
|
||||||
"passed": "Aprobat",
|
"passed": "Aprovat",
|
||||||
"failed": "Error"
|
"failed": "Error"
|
||||||
},
|
},
|
||||||
"openwrt": {
|
"openwrt": {
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nom",
|
"name": "Nom",
|
||||||
"systems": "Sistemes",
|
"systems": "Sistemes",
|
||||||
"up": "Actiu",
|
"up": "Actiu",
|
||||||
|
"down": "Inactiu",
|
||||||
|
"paused": "En pausa",
|
||||||
|
"pending": "Pendent",
|
||||||
"status": "Estat",
|
"status": "Estat",
|
||||||
"updated": "Actualitzat",
|
"updated": "Actualitzat",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
@ -991,21 +994,21 @@
|
|||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Apps",
|
||||||
"synced": "Synced",
|
"synced": "Sincronitzats",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Dessincronitzats",
|
||||||
"healthy": "Saludable",
|
"healthy": "Saludable",
|
||||||
"degraded": "Degraded",
|
"degraded": "Degradats",
|
||||||
"progressing": "Progressing",
|
"progressing": "Progressant",
|
||||||
"missing": "Falten",
|
"missing": "Falten",
|
||||||
"suspended": "Suspended"
|
"suspended": "Suspesos"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Carregant"
|
"loading": "Carregant"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Grups",
|
||||||
"issues": "Problemes",
|
"issues": "Problemes",
|
||||||
"merges": "Merge Requests",
|
"merges": "Merge Requests",
|
||||||
"projects": "Projects"
|
"projects": "Projectes"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Mřížka",
|
"grid_power": "Mřížka",
|
||||||
"home_power": "Spotřeba",
|
"home_power": "Spotřeba",
|
||||||
"charge_power": "Nabíječka",
|
"charge_power": "Nabíječka",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Stahování",
|
"download": "Stahování",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Pozastaveno",
|
||||||
|
"pending": "Čeká",
|
||||||
"status": "Stav",
|
"status": "Stav",
|
||||||
"updated": "Aktualizováno",
|
"updated": "Aktualizováno",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Gitter",
|
"grid_power": "Gitter",
|
||||||
"home_power": "Forbrug",
|
"home_power": "Forbrug",
|
||||||
"charge_power": "Oplader",
|
"charge_power": "Oplader",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Navn",
|
"name": "Navn",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Op",
|
"up": "Op",
|
||||||
|
"down": "Ned",
|
||||||
|
"paused": "Pause",
|
||||||
|
"pending": "Afventer",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Opdateret",
|
"updated": "Opdateret",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Netz",
|
"grid_power": "Netz",
|
||||||
"home_power": "verbauch",
|
"home_power": "verbauch",
|
||||||
"charge_power": "Ladegerät",
|
"charge_power": "Ladegerät",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systeme",
|
"systems": "Systeme",
|
||||||
"up": "Senden",
|
"up": "Senden",
|
||||||
|
"down": "Empfangen",
|
||||||
|
"paused": "Pausiert",
|
||||||
|
"pending": "Ausstehend",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Aktualisiert",
|
"updated": "Aktualisiert",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
@ -1003,9 +1006,9 @@
|
|||||||
"loading": "Wird geladen"
|
"loading": "Wird geladen"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Gruppen",
|
||||||
"issues": "Probleme",
|
"issues": "Probleme",
|
||||||
"merges": "Merge Requests",
|
"merges": "Merge Requests",
|
||||||
"projects": "Projects"
|
"projects": "Projekte"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Πλέγμα",
|
"grid_power": "Πλέγμα",
|
||||||
"home_power": "Κατανάλωση",
|
"home_power": "Κατανάλωση",
|
||||||
"charge_power": "Φορτιστής",
|
"charge_power": "Φορτιστής",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Λήξη",
|
"download": "Λήξη",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Όνομα",
|
"name": "Όνομα",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Ping up",
|
"up": "Ping up",
|
||||||
|
"down": "Ping down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Σε εκκρεμότητα",
|
||||||
"status": "Κατάσταση",
|
"status": "Κατάσταση",
|
||||||
"updated": "Ενημερώθηκε",
|
"updated": "Ενημερώθηκε",
|
||||||
"cpu": "Επεξεργαστής",
|
"cpu": "Επεξεργαστής",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Elŝuti",
|
"download": "Elŝuti",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Stato",
|
"status": "Stato",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "Ĉefprocesoro",
|
"cpu": "Ĉefprocesoro",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Red",
|
"grid_power": "Red",
|
||||||
"home_power": "Consumo",
|
"home_power": "Consumo",
|
||||||
"charge_power": "Cargador",
|
"charge_power": "Cargador",
|
||||||
"watt_hour": "vatio-hora (Wh)"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Descarga",
|
"download": "Descarga",
|
||||||
@ -311,13 +311,13 @@
|
|||||||
},
|
},
|
||||||
"suwayomi": {
|
"suwayomi": {
|
||||||
"download": "Descargado",
|
"download": "Descargado",
|
||||||
"nondownload": "Non-Downloaded",
|
"nondownload": "No descargado",
|
||||||
"read": "Leer",
|
"read": "Leer",
|
||||||
"unread": "Sin leer",
|
"unread": "Sin leer",
|
||||||
"downloadedread": "Downloaded & Read",
|
"downloadedread": "Descargado y leído",
|
||||||
"downloadedunread": "Downloaded & Unread",
|
"downloadedunread": "Descargado y no leído",
|
||||||
"nondownloadedread": "Non-Downloaded & Read",
|
"nondownloadedread": "No descargado y leído",
|
||||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
"nondownloadedunread": "No descargado y no leído"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Dirección",
|
"address": "Dirección",
|
||||||
@ -980,32 +980,35 @@
|
|||||||
},
|
},
|
||||||
"beszel": {
|
"beszel": {
|
||||||
"name": "Nombre",
|
"name": "Nombre",
|
||||||
"systems": "Systems",
|
"systems": "Sistemas",
|
||||||
"up": "Activo",
|
"up": "Activo",
|
||||||
|
"down": "Inactivo",
|
||||||
|
"paused": "Pausado",
|
||||||
|
"pending": "Pendiente",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"updated": "Actualizado",
|
"updated": "Actualizado",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"memory": "MEM",
|
"memory": "MEM",
|
||||||
"disk": "Disk",
|
"disk": "Disco",
|
||||||
"network": "NET"
|
"network": "RED"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Apps",
|
||||||
"synced": "Synced",
|
"synced": "Sincronizado",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Desincronizado",
|
||||||
"healthy": "Saludable",
|
"healthy": "Saludable",
|
||||||
"degraded": "Degraded",
|
"degraded": "Degradado",
|
||||||
"progressing": "Progressing",
|
"progressing": "Progresando",
|
||||||
"missing": "Faltantes",
|
"missing": "Faltantes",
|
||||||
"suspended": "Suspended"
|
"suspended": "Suspendido"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Cargando"
|
"loading": "Cargando"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Grupos",
|
||||||
"issues": "Números",
|
"issues": "Números",
|
||||||
"merges": "Merge Requests",
|
"merges": "Solicitudes de fusión",
|
||||||
"projects": "Projects"
|
"projects": "Proyectos"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Vireillä",
|
||||||
"status": "Tila",
|
"status": "Tila",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -58,7 +58,7 @@
|
|||||||
"wlan": "WLAN",
|
"wlan": "WLAN",
|
||||||
"devices": "Équipt.",
|
"devices": "Équipt.",
|
||||||
"lan_devices": "Équipt. LAN",
|
"lan_devices": "Équipt. LAN",
|
||||||
"wlan_devices": "Équipt. WLAN",
|
"wlan_devices": "Périphériques WLAN",
|
||||||
"lan_users": "Utilisateurs LAN",
|
"lan_users": "Utilisateurs LAN",
|
||||||
"wlan_users": "Utilisateurs WLAN",
|
"wlan_users": "Utilisateurs WLAN",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grille",
|
"grid_power": "Grille",
|
||||||
"home_power": "Consommation",
|
"home_power": "Consommation",
|
||||||
"charge_power": "Chargeur",
|
"charge_power": "Chargeur",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Récep.",
|
"download": "Récep.",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nom",
|
"name": "Nom",
|
||||||
"systems": "Systèmes",
|
"systems": "Systèmes",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "En Pause",
|
||||||
|
"pending": "En attente",
|
||||||
"status": "Statut",
|
"status": "Statut",
|
||||||
"updated": "Mis à jour",
|
"updated": "Mis à jour",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
@ -990,22 +993,22 @@
|
|||||||
"network": "Réseau"
|
"network": "Réseau"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Applications",
|
||||||
"synced": "Synced",
|
"synced": "Synchronisé",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Désynchronisé",
|
||||||
"healthy": "Fonctionnel",
|
"healthy": "Fonctionnel",
|
||||||
"degraded": "Degraded",
|
"degraded": "Dégradé",
|
||||||
"progressing": "Progressing",
|
"progressing": "En cours",
|
||||||
"missing": "Manquant",
|
"missing": "Manquant",
|
||||||
"suspended": "Suspended"
|
"suspended": "Suspendu"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Chargement"
|
"loading": "Chargement"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Groupes",
|
||||||
"issues": "Anomalies",
|
"issues": "Anomalies",
|
||||||
"merges": "Merge Requests",
|
"merges": "Demandes de fusion de branches",
|
||||||
"projects": "Projects"
|
"projects": "Projets"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "ממתין",
|
||||||
"status": "סטטוס",
|
"status": "סטטוס",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Raspored",
|
"grid_power": "Raspored",
|
||||||
"home_power": "Potrošnja",
|
"home_power": "Potrošnja",
|
||||||
"charge_power": "Punjač",
|
"charge_power": "Punjač",
|
||||||
"watt_hour": "Kilovat-sat"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Preuzimanje",
|
"download": "Preuzimanje",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Ime",
|
"name": "Ime",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Dostupno",
|
"up": "Dostupno",
|
||||||
|
"down": "Nedostupno",
|
||||||
|
"paused": "Zaustavljeno",
|
||||||
|
"pending": "U tijeku",
|
||||||
"status": "Stanje",
|
"status": "Stanje",
|
||||||
"updated": "Aktualizirano",
|
"updated": "Aktualizirano",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -25,7 +25,7 @@
|
|||||||
"api_error": "API Hiba",
|
"api_error": "API Hiba",
|
||||||
"information": "Információ",
|
"information": "Információ",
|
||||||
"status": "Státusz",
|
"status": "Státusz",
|
||||||
"url": "LINK",
|
"url": "URL",
|
||||||
"raw_error": "Nyers hiba",
|
"raw_error": "Nyers hiba",
|
||||||
"response_data": "Válaszadatok"
|
"response_data": "Válaszadatok"
|
||||||
},
|
},
|
||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Rács",
|
"grid_power": "Rács",
|
||||||
"home_power": "Fogyasztás",
|
"home_power": "Fogyasztás",
|
||||||
"charge_power": "Töltő",
|
"charge_power": "Töltő",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Letöltés",
|
"download": "Letöltés",
|
||||||
@ -227,8 +227,8 @@
|
|||||||
"seed": "Seed"
|
"seed": "Seed"
|
||||||
},
|
},
|
||||||
"develancacheui": {
|
"develancacheui": {
|
||||||
"cachehitbytes": "Cache Hit Bytes",
|
"cachehitbytes": "Gyorsítótárban Sikeres Bitek",
|
||||||
"cachemissbytes": "Cache Miss Bytes"
|
"cachemissbytes": "Gyorsítótárban Hibás Bitek"
|
||||||
},
|
},
|
||||||
"downloadstation": {
|
"downloadstation": {
|
||||||
"download": "Letöltés",
|
"download": "Letöltés",
|
||||||
@ -311,13 +311,13 @@
|
|||||||
},
|
},
|
||||||
"suwayomi": {
|
"suwayomi": {
|
||||||
"download": "Letöltött",
|
"download": "Letöltött",
|
||||||
"nondownload": "Non-Downloaded",
|
"nondownload": "Nem Letöltött",
|
||||||
"read": "Olvasott",
|
"read": "Olvasott",
|
||||||
"unread": "Olvasatlan",
|
"unread": "Olvasatlan",
|
||||||
"downloadedread": "Downloaded & Read",
|
"downloadedread": "Letöltött & Olvasott",
|
||||||
"downloadedunread": "Downloaded & Unread",
|
"downloadedunread": "Letöltött & Olvasatlan",
|
||||||
"nondownloadedread": "Non-Downloaded & Read",
|
"nondownloadedread": "Nem Letöltött & Olvasatlan",
|
||||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
"nondownloadedunread": "Nem Letöltött & Olvasatlan"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Cím",
|
"address": "Cím",
|
||||||
@ -335,15 +335,15 @@
|
|||||||
},
|
},
|
||||||
"technitium": {
|
"technitium": {
|
||||||
"totalQueries": "Lekérdezések",
|
"totalQueries": "Lekérdezések",
|
||||||
"totalNoError": "Success",
|
"totalNoError": "Sikerek",
|
||||||
"totalServerFailure": "Failures",
|
"totalServerFailure": "Hibák",
|
||||||
"totalNxDomain": "NX Domains",
|
"totalNxDomain": "NX Domainek",
|
||||||
"totalRefused": "Refused",
|
"totalRefused": "Elutasított",
|
||||||
"totalAuthoritative": "Authoritative",
|
"totalAuthoritative": "Irányadó",
|
||||||
"totalRecursive": "Recursive",
|
"totalRecursive": "Rekurzív",
|
||||||
"totalCached": "Cached",
|
"totalCached": "Gyorsítótárazott",
|
||||||
"totalBlocked": "Blokkolt",
|
"totalBlocked": "Blokkolt",
|
||||||
"totalDropped": "Dropped",
|
"totalDropped": "Eldobott",
|
||||||
"totalClients": "Kliensek"
|
"totalClients": "Kliensek"
|
||||||
},
|
},
|
||||||
"tdarr": {
|
"tdarr": {
|
||||||
@ -453,7 +453,7 @@
|
|||||||
"search": "Keresés",
|
"search": "Keresés",
|
||||||
"custom": "Egyedi",
|
"custom": "Egyedi",
|
||||||
"visit": "Megnéz",
|
"visit": "Megnéz",
|
||||||
"url": "LINK",
|
"url": "URL",
|
||||||
"searchsuggestion": "Javaslat"
|
"searchsuggestion": "Javaslat"
|
||||||
},
|
},
|
||||||
"wmo": {
|
"wmo": {
|
||||||
@ -854,16 +854,16 @@
|
|||||||
},
|
},
|
||||||
"romm": {
|
"romm": {
|
||||||
"platforms": "Felület",
|
"platforms": "Felület",
|
||||||
"totalRoms": "Games",
|
"totalRoms": "Játékok",
|
||||||
"saves": "Saves",
|
"saves": "Mentések",
|
||||||
"states": "States",
|
"states": "Állapotok",
|
||||||
"screenshots": "Screenshots",
|
"screenshots": "Képernyőképek",
|
||||||
"totalfilesize": "Total Size"
|
"totalfilesize": "Teljes méret"
|
||||||
},
|
},
|
||||||
"mailcow": {
|
"mailcow": {
|
||||||
"domains": "Domainek",
|
"domains": "Domainek",
|
||||||
"mailboxes": "Mailboxes",
|
"mailboxes": "E-mail fiókok",
|
||||||
"mails": "Mails",
|
"mails": "Mailek",
|
||||||
"storage": "Tárhely"
|
"storage": "Tárhely"
|
||||||
},
|
},
|
||||||
"netdata": {
|
"netdata": {
|
||||||
@ -912,7 +912,7 @@
|
|||||||
},
|
},
|
||||||
"crowdsec": {
|
"crowdsec": {
|
||||||
"alerts": "Riasztások",
|
"alerts": "Riasztások",
|
||||||
"bans": "Bans"
|
"bans": "Kitiltások"
|
||||||
},
|
},
|
||||||
"wgeasy": {
|
"wgeasy": {
|
||||||
"connected": "Csatlakozva",
|
"connected": "Csatlakozva",
|
||||||
@ -921,10 +921,10 @@
|
|||||||
"total": "Összes"
|
"total": "Összes"
|
||||||
},
|
},
|
||||||
"swagdashboard": {
|
"swagdashboard": {
|
||||||
"proxied": "Proxied",
|
"proxied": "Proxyzott",
|
||||||
"auth": "With Auth",
|
"auth": "Hitelesítéssel",
|
||||||
"outdated": "Outdated",
|
"outdated": "Elavult",
|
||||||
"banned": "Banned"
|
"banned": "Kitiltott"
|
||||||
},
|
},
|
||||||
"myspeed": {
|
"myspeed": {
|
||||||
"ping": "Ping",
|
"ping": "Ping",
|
||||||
@ -932,29 +932,29 @@
|
|||||||
"upload": "Feltöltés"
|
"upload": "Feltöltés"
|
||||||
},
|
},
|
||||||
"stocks": {
|
"stocks": {
|
||||||
"stocks": "Stocks",
|
"stocks": "Tőzsde",
|
||||||
"loading": "Loading",
|
"loading": "Betöltés",
|
||||||
"open": "Open - US Market",
|
"open": "Nyitva - US Piac",
|
||||||
"closed": "Closed - US Market",
|
"closed": "Zárva - US Piac",
|
||||||
"invalidConfiguration": "Invalid Configuration"
|
"invalidConfiguration": "Érvénytelen konfiguráció"
|
||||||
},
|
},
|
||||||
"frigate": {
|
"frigate": {
|
||||||
"cameras": "Cameras",
|
"cameras": "Kamerák",
|
||||||
"uptime": "Üzemidő",
|
"uptime": "Üzemidő",
|
||||||
"version": "Verzió"
|
"version": "Verzió"
|
||||||
},
|
},
|
||||||
"linkwarden": {
|
"linkwarden": {
|
||||||
"links": "Links",
|
"links": "Linkek",
|
||||||
"collections": "Collections",
|
"collections": "Gyűjtemény",
|
||||||
"tags": "Címkék"
|
"tags": "Címkék"
|
||||||
},
|
},
|
||||||
"zabbix": {
|
"zabbix": {
|
||||||
"unclassified": "Not classified",
|
"unclassified": "Nem titkosított",
|
||||||
"information": "Információ",
|
"information": "Információ",
|
||||||
"warning": "Warning",
|
"warning": "Figyelmeztetés",
|
||||||
"average": "Average",
|
"average": "Átlag",
|
||||||
"high": "High",
|
"high": "Magas",
|
||||||
"disaster": "Disaster"
|
"disaster": "Katasztrófa"
|
||||||
},
|
},
|
||||||
"lubelogger": {
|
"lubelogger": {
|
||||||
"vehicle": "Jármű",
|
"vehicle": "Jármű",
|
||||||
@ -962,13 +962,13 @@
|
|||||||
"serviceRecords": "Szolgáltatások nyílvántartása",
|
"serviceRecords": "Szolgáltatások nyílvántartása",
|
||||||
"reminders": "Emlékeztetők",
|
"reminders": "Emlékeztetők",
|
||||||
"nextReminder": "Következő emlékeztető",
|
"nextReminder": "Következő emlékeztető",
|
||||||
"none": "None"
|
"none": "Semmi"
|
||||||
},
|
},
|
||||||
"vikunja": {
|
"vikunja": {
|
||||||
"projects": "Active Projects",
|
"projects": "Aktív Projektek",
|
||||||
"tasks7d": "Tasks Due This Week",
|
"tasks7d": "Hátralévő feladatok a héten",
|
||||||
"tasksOverdue": "Overdue Tasks",
|
"tasksOverdue": "Lejárt feladatok",
|
||||||
"tasksInProgress": "Tasks In Progress"
|
"tasksInProgress": "Folyamatban levő Feladatok"
|
||||||
},
|
},
|
||||||
"headscale": {
|
"headscale": {
|
||||||
"name": "Név",
|
"name": "Név",
|
||||||
@ -980,32 +980,35 @@
|
|||||||
},
|
},
|
||||||
"beszel": {
|
"beszel": {
|
||||||
"name": "Név",
|
"name": "Név",
|
||||||
"systems": "Systems",
|
"systems": "Rendszerek",
|
||||||
"up": "Fel",
|
"up": "Fel",
|
||||||
|
"down": "Le",
|
||||||
|
"paused": "Szünetel",
|
||||||
|
"pending": "Függőben",
|
||||||
"status": "Státusz",
|
"status": "Státusz",
|
||||||
"updated": "Frissített",
|
"updated": "Frissített",
|
||||||
"cpu": "Processzor",
|
"cpu": "Processzor",
|
||||||
"memory": "RAM",
|
"memory": "RAM",
|
||||||
"disk": "Disk",
|
"disk": "Lemez",
|
||||||
"network": "NET"
|
"network": "Hálózat"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Alkalmazások",
|
||||||
"synced": "Synced",
|
"synced": "Szinkronizált",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Nincs szinkronban",
|
||||||
"healthy": "Egészséges",
|
"healthy": "Egészséges",
|
||||||
"degraded": "Degraded",
|
"degraded": "Leépült",
|
||||||
"progressing": "Progressing",
|
"progressing": "Halad",
|
||||||
"missing": "Hiányzik",
|
"missing": "Hiányzik",
|
||||||
"suspended": "Suspended"
|
"suspended": "Felfüggesztett"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Loading"
|
"loading": "Betöltés"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Csoportok",
|
||||||
"issues": "Problémák",
|
"issues": "Problémák",
|
||||||
"merges": "Merge Requests",
|
"merges": "Merge kérések",
|
||||||
"projects": "Projects"
|
"projects": "Projektek"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Konsumsi",
|
"home_power": "Konsumsi",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Watt/jam"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Unduh",
|
"download": "Unduh",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nama",
|
"name": "Nama",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Hidup",
|
"up": "Hidup",
|
||||||
|
"down": "Mati",
|
||||||
|
"paused": "Pause",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Terbarui",
|
"updated": "Terbarui",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Griglia",
|
"grid_power": "Griglia",
|
||||||
"home_power": "Consumo",
|
"home_power": "Consumo",
|
||||||
"charge_power": "Caricatore",
|
"charge_power": "Caricatore",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -335,7 +335,7 @@
|
|||||||
},
|
},
|
||||||
"technitium": {
|
"technitium": {
|
||||||
"totalQueries": "Richieste",
|
"totalQueries": "Richieste",
|
||||||
"totalNoError": "Success",
|
"totalNoError": "Successo",
|
||||||
"totalServerFailure": "Failures",
|
"totalServerFailure": "Failures",
|
||||||
"totalNxDomain": "NX Domains",
|
"totalNxDomain": "NX Domains",
|
||||||
"totalRefused": "Refused",
|
"totalRefused": "Refused",
|
||||||
@ -590,7 +590,7 @@
|
|||||||
"total": "Totale"
|
"total": "Totale"
|
||||||
},
|
},
|
||||||
"peanut": {
|
"peanut": {
|
||||||
"battery_charge": "Battery Charge",
|
"battery_charge": "Carica Batteria",
|
||||||
"ups_load": "Carico UPS",
|
"ups_load": "Carico UPS",
|
||||||
"ups_status": "Stato UPS",
|
"ups_status": "Stato UPS",
|
||||||
"online": "Online",
|
"online": "Online",
|
||||||
@ -854,7 +854,7 @@
|
|||||||
},
|
},
|
||||||
"romm": {
|
"romm": {
|
||||||
"platforms": "Piattaforme",
|
"platforms": "Piattaforme",
|
||||||
"totalRoms": "Games",
|
"totalRoms": "Giochi",
|
||||||
"saves": "Saves",
|
"saves": "Saves",
|
||||||
"states": "States",
|
"states": "States",
|
||||||
"screenshots": "Screenshots",
|
"screenshots": "Screenshots",
|
||||||
@ -890,7 +890,7 @@
|
|||||||
"sceneDuration": "Durata Delle Scene",
|
"sceneDuration": "Durata Delle Scene",
|
||||||
"images": "Immagini",
|
"images": "Immagini",
|
||||||
"imageSize": "Dimensioni immagine",
|
"imageSize": "Dimensioni immagine",
|
||||||
"galleries": "Galleries",
|
"galleries": "Gallerie",
|
||||||
"performers": "Esecutori",
|
"performers": "Esecutori",
|
||||||
"studios": "Studi",
|
"studios": "Studi",
|
||||||
"movies": "Film",
|
"movies": "Film",
|
||||||
@ -933,7 +933,7 @@
|
|||||||
},
|
},
|
||||||
"stocks": {
|
"stocks": {
|
||||||
"stocks": "Stocks",
|
"stocks": "Stocks",
|
||||||
"loading": "Loading",
|
"loading": "Caricamento",
|
||||||
"open": "Open - US Market",
|
"open": "Open - US Market",
|
||||||
"closed": "Closed - US Market",
|
"closed": "Closed - US Market",
|
||||||
"invalidConfiguration": "Invalid Configuration"
|
"invalidConfiguration": "Invalid Configuration"
|
||||||
@ -944,8 +944,8 @@
|
|||||||
"version": "Versione"
|
"version": "Versione"
|
||||||
},
|
},
|
||||||
"linkwarden": {
|
"linkwarden": {
|
||||||
"links": "Links",
|
"links": "Collegamenti",
|
||||||
"collections": "Collections",
|
"collections": "Raccolte",
|
||||||
"tags": "Tag"
|
"tags": "Tag"
|
||||||
},
|
},
|
||||||
"zabbix": {
|
"zabbix": {
|
||||||
@ -957,12 +957,12 @@
|
|||||||
"disaster": "Disaster"
|
"disaster": "Disaster"
|
||||||
},
|
},
|
||||||
"lubelogger": {
|
"lubelogger": {
|
||||||
"vehicle": "Vehicle",
|
"vehicle": "Veicolo",
|
||||||
"vehicles": "Vehicles",
|
"vehicles": "Veicoli",
|
||||||
"serviceRecords": "Service Records",
|
"serviceRecords": "Service Records",
|
||||||
"reminders": "Reminders",
|
"reminders": "Promemoria",
|
||||||
"nextReminder": "Next Reminder",
|
"nextReminder": "Promemoria Seguente",
|
||||||
"none": "None"
|
"none": "Nessuno"
|
||||||
},
|
},
|
||||||
"vikunja": {
|
"vikunja": {
|
||||||
"projects": "Active Projects",
|
"projects": "Active Projects",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "In Pausa",
|
||||||
|
"pending": "In attesa",
|
||||||
"status": "Stato",
|
"status": "Stato",
|
||||||
"updated": "Aggiornato",
|
"updated": "Aggiornato",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
@ -1000,7 +1003,7 @@
|
|||||||
"suspended": "Suspended"
|
"suspended": "Suspended"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Loading"
|
"loading": "Caricamento"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Groups",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "グリッド",
|
"grid_power": "グリッド",
|
||||||
"home_power": "消費",
|
"home_power": "消費",
|
||||||
"charge_power": "チャージャー",
|
"charge_power": "チャージャー",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "ダウンロード",
|
"download": "ダウンロード",
|
||||||
@ -804,7 +804,7 @@
|
|||||||
"ping": "Ping"
|
"ping": "Ping"
|
||||||
},
|
},
|
||||||
"urbackup": {
|
"urbackup": {
|
||||||
"ok": "はい",
|
"ok": "正常",
|
||||||
"errored": "エラー",
|
"errored": "エラー",
|
||||||
"noRecent": "期限切れ",
|
"noRecent": "期限切れ",
|
||||||
"totalUsed": "使用済みストレージ"
|
"totalUsed": "使用済みストレージ"
|
||||||
@ -957,7 +957,7 @@
|
|||||||
"disaster": "災害"
|
"disaster": "災害"
|
||||||
},
|
},
|
||||||
"lubelogger": {
|
"lubelogger": {
|
||||||
"vehicle": "Vehicle",
|
"vehicle": "車両",
|
||||||
"vehicles": "Vehicles",
|
"vehicles": "Vehicles",
|
||||||
"serviceRecords": "Service Records",
|
"serviceRecords": "Service Records",
|
||||||
"reminders": "Reminders",
|
"reminders": "Reminders",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "名前",
|
"name": "名前",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "稼働",
|
"up": "稼働",
|
||||||
|
"down": "下へ",
|
||||||
|
"paused": "一時停止中",
|
||||||
|
"pending": "保留中",
|
||||||
"status": "状態",
|
"status": "状態",
|
||||||
"updated": "更新済",
|
"updated": "更新済",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "눈금",
|
"grid_power": "눈금",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "다운로드",
|
"download": "다운로드",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "이름",
|
"name": "이름",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "대기 중",
|
||||||
"status": "상태",
|
"status": "상태",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Lejupielāde",
|
"download": "Lejupielāde",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Statuss",
|
"status": "Statuss",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Penggunaan",
|
"home_power": "Penggunaan",
|
||||||
"charge_power": "Pengecas",
|
"charge_power": "Pengecas",
|
||||||
"watt_hour": "Wj"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Muat turun",
|
"download": "Muat turun",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nama",
|
"name": "Nama",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Hidup",
|
"up": "Hidup",
|
||||||
|
"down": "Mati",
|
||||||
|
"paused": "Tangguh",
|
||||||
|
"pending": "Tertunda",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Dikemaskini",
|
"updated": "Dikemaskini",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Netstroom",
|
"grid_power": "Netstroom",
|
||||||
"home_power": "Consumptie",
|
"home_power": "Consumptie",
|
||||||
"charge_power": "Oplader",
|
"charge_power": "Oplader",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -311,13 +311,13 @@
|
|||||||
},
|
},
|
||||||
"suwayomi": {
|
"suwayomi": {
|
||||||
"download": "Gedownload",
|
"download": "Gedownload",
|
||||||
"nondownload": "Non-Downloaded",
|
"nondownload": "Niet gedownload",
|
||||||
"read": "Gelezen",
|
"read": "Gelezen",
|
||||||
"unread": "Ongelezen",
|
"unread": "Ongelezen",
|
||||||
"downloadedread": "Downloaded & Read",
|
"downloadedread": "Gedownload & gelezen",
|
||||||
"downloadedunread": "Downloaded & Unread",
|
"downloadedunread": "Gedownload & ongelezen",
|
||||||
"nondownloadedread": "Non-Downloaded & Read",
|
"nondownloadedread": "Niet-gedownload & gelezen",
|
||||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
"nondownloadedunread": "Niet-gedownload & ongelezen"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Adres",
|
"address": "Adres",
|
||||||
@ -980,32 +980,35 @@
|
|||||||
},
|
},
|
||||||
"beszel": {
|
"beszel": {
|
||||||
"name": "Naam",
|
"name": "Naam",
|
||||||
"systems": "Systems",
|
"systems": "Systemen",
|
||||||
"up": "Online",
|
"up": "Online",
|
||||||
|
"down": "Offline",
|
||||||
|
"paused": "Gepauzeerd",
|
||||||
|
"pending": "In afwachting",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Bijgewerkt",
|
"updated": "Bijgewerkt",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
"memory": "GEH",
|
"memory": "GEH",
|
||||||
"disk": "Disk",
|
"disk": "Schijf",
|
||||||
"network": "NET"
|
"network": "NET"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Apps",
|
||||||
"synced": "Synced",
|
"synced": "Gesynchroniseerd",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Niet gesynchroniseerd",
|
||||||
"healthy": "Gezond",
|
"healthy": "Gezond",
|
||||||
"degraded": "Degraded",
|
"degraded": "Gedegradeerd",
|
||||||
"progressing": "Progressing",
|
"progressing": "Doorvoeren",
|
||||||
"missing": "Ontbreekt",
|
"missing": "Ontbreekt",
|
||||||
"suspended": "Suspended"
|
"suspended": "Onderbroken"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Laden"
|
"loading": "Laden"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Groepen",
|
||||||
"issues": "Problemen",
|
"issues": "Problemen",
|
||||||
"merges": "Merge Requests",
|
"merges": "Merge Verzoeken",
|
||||||
"projects": "Projects"
|
"projects": "Projecten"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Nett",
|
"grid_power": "Nett",
|
||||||
"home_power": "Forbruk",
|
"home_power": "Forbruk",
|
||||||
"charge_power": "Lader",
|
"charge_power": "Lader",
|
||||||
"watt_hour": "W/t"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Last ned",
|
"download": "Last ned",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Navn",
|
"name": "Navn",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Oppe",
|
"up": "Oppe",
|
||||||
|
"down": "Nede",
|
||||||
|
"paused": "Pauset",
|
||||||
|
"pending": "Ventende",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Oppdatert",
|
"updated": "Oppdatert",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Siatka",
|
"grid_power": "Siatka",
|
||||||
"home_power": "Zużycie",
|
"home_power": "Zużycie",
|
||||||
"charge_power": "Ładowarka",
|
"charge_power": "Ładowarka",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Pobieranie",
|
"download": "Pobieranie",
|
||||||
@ -311,13 +311,13 @@
|
|||||||
},
|
},
|
||||||
"suwayomi": {
|
"suwayomi": {
|
||||||
"download": "Pobrano",
|
"download": "Pobrano",
|
||||||
"nondownload": "Non-Downloaded",
|
"nondownload": "Niepobrane",
|
||||||
"read": "Przeczytane",
|
"read": "Przeczytane",
|
||||||
"unread": "Nieprzeczytane",
|
"unread": "Nieprzeczytane",
|
||||||
"downloadedread": "Downloaded & Read",
|
"downloadedread": "Pobrane i przeczytane",
|
||||||
"downloadedunread": "Downloaded & Unread",
|
"downloadedunread": "Pobrane i nieprzeczytane",
|
||||||
"nondownloadedread": "Non-Downloaded & Read",
|
"nondownloadedread": "Niepobrane i przeczytane",
|
||||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
"nondownloadedunread": "Niepobrane i nieprzeczytane"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Adres",
|
"address": "Adres",
|
||||||
@ -957,18 +957,18 @@
|
|||||||
"disaster": "Katastrofa"
|
"disaster": "Katastrofa"
|
||||||
},
|
},
|
||||||
"lubelogger": {
|
"lubelogger": {
|
||||||
"vehicle": "Vehicle",
|
"vehicle": "Pojazd",
|
||||||
"vehicles": "Vehicles",
|
"vehicles": "Pojazdy",
|
||||||
"serviceRecords": "Service Records",
|
"serviceRecords": "Wpisy serwisowe",
|
||||||
"reminders": "Reminders",
|
"reminders": "Przypomnienia",
|
||||||
"nextReminder": "Next Reminder",
|
"nextReminder": "Następne przypomnienie",
|
||||||
"none": "None"
|
"none": "Brak"
|
||||||
},
|
},
|
||||||
"vikunja": {
|
"vikunja": {
|
||||||
"projects": "Active Projects",
|
"projects": "Aktywne Projekty",
|
||||||
"tasks7d": "Tasks Due This Week",
|
"tasks7d": "Zadania w tym tygodniu",
|
||||||
"tasksOverdue": "Overdue Tasks",
|
"tasksOverdue": "Zaległe zadania",
|
||||||
"tasksInProgress": "Tasks In Progress"
|
"tasksInProgress": "Zadania w toku"
|
||||||
},
|
},
|
||||||
"headscale": {
|
"headscale": {
|
||||||
"name": "Nazwa",
|
"name": "Nazwa",
|
||||||
@ -980,32 +980,35 @@
|
|||||||
},
|
},
|
||||||
"beszel": {
|
"beszel": {
|
||||||
"name": "Nazwa",
|
"name": "Nazwa",
|
||||||
"systems": "Systems",
|
"systems": "Systemy",
|
||||||
"up": "Dostępny",
|
"up": "Dostępny",
|
||||||
|
"down": "Niedostępny",
|
||||||
|
"paused": "Zatrzymane",
|
||||||
|
"pending": "Oczekiwane",
|
||||||
"status": "Stan",
|
"status": "Stan",
|
||||||
"updated": "Zaktualizowane",
|
"updated": "Zaktualizowane",
|
||||||
"cpu": "Procesor",
|
"cpu": "Procesor",
|
||||||
"memory": "RAM",
|
"memory": "RAM",
|
||||||
"disk": "Disk",
|
"disk": "Dysk",
|
||||||
"network": "NET"
|
"network": "NET"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Aplikacje",
|
||||||
"synced": "Synced",
|
"synced": "Synchronizowane",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Bez synchronizacji",
|
||||||
"healthy": "Zdrowy",
|
"healthy": "Zdrowy",
|
||||||
"degraded": "Degraded",
|
"degraded": "Zdegradowane",
|
||||||
"progressing": "Progressing",
|
"progressing": "Postępujące",
|
||||||
"missing": "Brakujące",
|
"missing": "Brakujące",
|
||||||
"suspended": "Suspended"
|
"suspended": "Zawieszone"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Wczytywanie"
|
"loading": "Wczytywanie"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Grupy",
|
||||||
"issues": "Zgłoszenia",
|
"issues": "Zgłoszenia",
|
||||||
"merges": "Merge Requests",
|
"merges": "Żądania scaleń",
|
||||||
"projects": "Projects"
|
"projects": "Projekty"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grelha",
|
"grid_power": "Grelha",
|
||||||
"home_power": "Consumo",
|
"home_power": "Consumo",
|
||||||
"charge_power": "Carregador",
|
"charge_power": "Carregador",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Descarregar",
|
"download": "Descarregar",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Pausa",
|
||||||
|
"pending": "Pendente",
|
||||||
"status": "Estado",
|
"status": "Estado",
|
||||||
"updated": "Atualizado",
|
"updated": "Atualizado",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grade",
|
"grid_power": "Grade",
|
||||||
"home_power": "Consumo",
|
"home_power": "Consumo",
|
||||||
"charge_power": "Carregador",
|
"charge_power": "Carregador",
|
||||||
"watt_hour": "Kw"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Descarregar",
|
"download": "Descarregar",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Ativo",
|
"up": "Ativo",
|
||||||
|
"down": "Inativo",
|
||||||
|
"paused": "Pausado",
|
||||||
|
"pending": "Pendente",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Atualizado",
|
"updated": "Atualizado",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grilă",
|
"grid_power": "Grilă",
|
||||||
"home_power": "Consum",
|
"home_power": "Consum",
|
||||||
"charge_power": "Încărcător",
|
"charge_power": "Încărcător",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Descarcă",
|
"download": "Descarcă",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Sus",
|
"up": "Sus",
|
||||||
|
"down": "Jos",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "În așteptare",
|
||||||
"status": "Stare",
|
"status": "Stare",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "Procesor",
|
"cpu": "Procesor",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Сетка",
|
"grid_power": "Сетка",
|
||||||
"home_power": "Потребление",
|
"home_power": "Потребление",
|
||||||
"charge_power": "Зарядка",
|
"charge_power": "Зарядка",
|
||||||
"watt_hour": "Вт/ч"
|
"kilowatt": "кВт"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Скачивание",
|
"download": "Скачивание",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Имя",
|
"name": "Имя",
|
||||||
"systems": "Системы",
|
"systems": "Системы",
|
||||||
"up": "Онлайн",
|
"up": "Онлайн",
|
||||||
|
"down": "Офлайн",
|
||||||
|
"paused": "Приостановлено",
|
||||||
|
"pending": "В обработке",
|
||||||
"status": "Статус",
|
"status": "Статус",
|
||||||
"updated": "Обновленно",
|
"updated": "Обновленно",
|
||||||
"cpu": "ЦП",
|
"cpu": "ЦП",
|
||||||
@ -990,22 +993,22 @@
|
|||||||
"network": "Сеть"
|
"network": "Сеть"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Приложения",
|
||||||
"synced": "Synced",
|
"synced": "Синхронизированные",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Не синхронизированные",
|
||||||
"healthy": "Здоровый",
|
"healthy": "Здоровый",
|
||||||
"degraded": "Degraded",
|
"degraded": "Деградированные",
|
||||||
"progressing": "Progressing",
|
"progressing": "Выполняются",
|
||||||
"missing": "Отсутствует",
|
"missing": "Отсутствует",
|
||||||
"suspended": "Suspended"
|
"suspended": "Приостановленные"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Загрузка"
|
"loading": "Загрузка"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Группы",
|
||||||
"issues": "Вопросы",
|
"issues": "Вопросы",
|
||||||
"merges": "Merge Requests",
|
"merges": "Мердж-реквесты",
|
||||||
"projects": "Projects"
|
"projects": "Проекты"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Mriežka",
|
"grid_power": "Mriežka",
|
||||||
"home_power": "Spotreba",
|
"home_power": "Spotreba",
|
||||||
"charge_power": "Nabíjačka",
|
"charge_power": "Nabíjačka",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Sťahovanie",
|
"download": "Sťahovanie",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Meno",
|
"name": "Meno",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Nahrávanie",
|
"up": "Nahrávanie",
|
||||||
|
"down": "Sťahovanie",
|
||||||
|
"paused": "Pozastavené",
|
||||||
|
"pending": "Čakajúce",
|
||||||
"status": "Stav",
|
"status": "Stav",
|
||||||
"updated": "Aktualizované",
|
"updated": "Aktualizované",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Omrežje",
|
"grid_power": "Omrežje",
|
||||||
"home_power": "Poraba",
|
"home_power": "Poraba",
|
||||||
"charge_power": "Polnilec",
|
"charge_power": "Polnilec",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Prenos",
|
"download": "Prenos",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Naziv",
|
"name": "Naziv",
|
||||||
"systems": "Sistemi",
|
"systems": "Sistemi",
|
||||||
"up": "Povezan",
|
"up": "Povezan",
|
||||||
|
"down": "Nepovezan",
|
||||||
|
"paused": "Pavziran",
|
||||||
|
"pending": "V teku",
|
||||||
"status": "Stanje",
|
"status": "Stanje",
|
||||||
"updated": "Posodobljen",
|
"updated": "Posodobljen",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
@ -1003,9 +1006,9 @@
|
|||||||
"loading": "Nalaganje"
|
"loading": "Nalaganje"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Skupine",
|
||||||
"issues": "Težave",
|
"issues": "Težave",
|
||||||
"merges": "Merge Requests",
|
"merges": "Združi zahtevke",
|
||||||
"projects": "Projects"
|
"projects": "Projekti"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Avvaktar",
|
||||||
"status": "Status",
|
"status": "Status",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "పెండింగ్",
|
||||||
"status": "హోదా",
|
"status": "హోదా",
|
||||||
"updated": "నవీకరించబడింది",
|
"updated": "నవీకరించబడింది",
|
||||||
"cpu": "సీపియూ",
|
"cpu": "సీపియూ",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "ดาวน์โหลด",
|
"download": "ดาวน์โหลด",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Pending",
|
||||||
"status": "สถานะ",
|
"status": "สถานะ",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "ซีพียู",
|
"cpu": "ซีพียู",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Güç",
|
"grid_power": "Güç",
|
||||||
"home_power": "Tüketim",
|
"home_power": "Tüketim",
|
||||||
"charge_power": "Şarj",
|
"charge_power": "Şarj",
|
||||||
"watt_hour": "Watt/Saat"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "İndirme",
|
"download": "İndirme",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "İsim",
|
"name": "İsim",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Yükleme",
|
"up": "Yükleme",
|
||||||
|
"down": "İndirme",
|
||||||
|
"paused": "Duraklatıldı",
|
||||||
|
"pending": "Bekleyen",
|
||||||
"status": "Durum",
|
"status": "Durum",
|
||||||
"updated": "Güncellendi",
|
"updated": "Güncellendi",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Сітка",
|
"grid_power": "Сітка",
|
||||||
"home_power": "Споживання",
|
"home_power": "Споживання",
|
||||||
"charge_power": "Зарядний пристрій",
|
"charge_power": "Зарядний пристрій",
|
||||||
"watt_hour": "Вт/год"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Завантажено",
|
"download": "Завантажено",
|
||||||
@ -311,13 +311,13 @@
|
|||||||
},
|
},
|
||||||
"suwayomi": {
|
"suwayomi": {
|
||||||
"download": "Завантажено",
|
"download": "Завантажено",
|
||||||
"nondownload": "Non-Downloaded",
|
"nondownload": "Не завантажено",
|
||||||
"read": "Прочитано",
|
"read": "Прочитано",
|
||||||
"unread": "Не прочитано",
|
"unread": "Не прочитано",
|
||||||
"downloadedread": "Downloaded & Read",
|
"downloadedread": "Завантажено та Прочитано",
|
||||||
"downloadedunread": "Downloaded & Unread",
|
"downloadedunread": "Завантажено та Непрочитано",
|
||||||
"nondownloadedread": "Non-Downloaded & Read",
|
"nondownloadedread": "Не завантажено та Прочитано",
|
||||||
"nondownloadedunread": "Non-Downloaded & Unread"
|
"nondownloadedunread": "Не завантажено та Не прочитано"
|
||||||
},
|
},
|
||||||
"tailscale": {
|
"tailscale": {
|
||||||
"address": "Адреса",
|
"address": "Адреса",
|
||||||
@ -965,10 +965,10 @@
|
|||||||
"none": "Жодного"
|
"none": "Жодного"
|
||||||
},
|
},
|
||||||
"vikunja": {
|
"vikunja": {
|
||||||
"projects": "Active Projects",
|
"projects": "Активні проекти",
|
||||||
"tasks7d": "Tasks Due This Week",
|
"tasks7d": "Завдання цього тижня",
|
||||||
"tasksOverdue": "Overdue Tasks",
|
"tasksOverdue": "Прострочені завдання",
|
||||||
"tasksInProgress": "Tasks In Progress"
|
"tasksInProgress": "Завдання в процесі"
|
||||||
},
|
},
|
||||||
"headscale": {
|
"headscale": {
|
||||||
"name": "Назва",
|
"name": "Назва",
|
||||||
@ -980,32 +980,35 @@
|
|||||||
},
|
},
|
||||||
"beszel": {
|
"beszel": {
|
||||||
"name": "Назва",
|
"name": "Назва",
|
||||||
"systems": "Systems",
|
"systems": "Системи",
|
||||||
"up": "Онлайн",
|
"up": "Онлайн",
|
||||||
|
"down": "Офлайн",
|
||||||
|
"paused": "Призупинено",
|
||||||
|
"pending": "В очікуванні",
|
||||||
"status": "Стан",
|
"status": "Стан",
|
||||||
"updated": "Оновлено",
|
"updated": "Оновлено",
|
||||||
"cpu": "ЦП",
|
"cpu": "ЦП",
|
||||||
"memory": "ОЗП",
|
"memory": "ОЗП",
|
||||||
"disk": "Disk",
|
"disk": "Диск",
|
||||||
"network": "NET"
|
"network": "МЕРЕЖА"
|
||||||
},
|
},
|
||||||
"argocd": {
|
"argocd": {
|
||||||
"apps": "Apps",
|
"apps": "Додатки",
|
||||||
"synced": "Synced",
|
"synced": "Синхронізовано",
|
||||||
"outOfSync": "Out Of Sync",
|
"outOfSync": "Не синхронізовано",
|
||||||
"healthy": "Здоровий",
|
"healthy": "Здоровий",
|
||||||
"degraded": "Degraded",
|
"degraded": "Деградує",
|
||||||
"progressing": "Progressing",
|
"progressing": "Прогрес",
|
||||||
"missing": "Відсутній",
|
"missing": "Відсутній",
|
||||||
"suspended": "Suspended"
|
"suspended": "Призупинено"
|
||||||
},
|
},
|
||||||
"spoolman": {
|
"spoolman": {
|
||||||
"loading": "Завантажую"
|
"loading": "Завантажую"
|
||||||
},
|
},
|
||||||
"gitlab": {
|
"gitlab": {
|
||||||
"groups": "Groups",
|
"groups": "Групи",
|
||||||
"issues": "Питання",
|
"issues": "Питання",
|
||||||
"merges": "Merge Requests",
|
"merges": "Запити на злиття",
|
||||||
"projects": "Projects"
|
"projects": "Проєкти"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "Download",
|
"download": "Download",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "Paused",
|
||||||
|
"pending": "Đang xử lý",
|
||||||
"status": "Trạng thái",
|
"status": "Trạng thái",
|
||||||
"updated": "Updated",
|
"updated": "Updated",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "電網",
|
"grid_power": "電網",
|
||||||
"home_power": "電源使用率",
|
"home_power": "電源使用率",
|
||||||
"charge_power": "充電",
|
"charge_power": "充電",
|
||||||
"watt_hour": "瓦時 (Wh)"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "下載速率",
|
"download": "下載速率",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "名稱",
|
"name": "名稱",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "在線",
|
"up": "在線",
|
||||||
|
"down": "離線",
|
||||||
|
"paused": "擱置中",
|
||||||
|
"pending": "待定",
|
||||||
"status": "狀況",
|
"status": "狀況",
|
||||||
"updated": "已更新",
|
"updated": "已更新",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "Grid",
|
"grid_power": "Grid",
|
||||||
"home_power": "Consumption",
|
"home_power": "Consumption",
|
||||||
"charge_power": "Charger",
|
"charge_power": "Charger",
|
||||||
"watt_hour": "Wh"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "下载",
|
"download": "下载",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "Name",
|
"name": "Name",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "Up",
|
"up": "Up",
|
||||||
|
"down": "Down",
|
||||||
|
"paused": "暂停",
|
||||||
|
"pending": "待办的",
|
||||||
"status": "状态",
|
"status": "状态",
|
||||||
"updated": "已升级",
|
"updated": "已升级",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -120,7 +120,7 @@
|
|||||||
"grid_power": "電網",
|
"grid_power": "電網",
|
||||||
"home_power": "電源使用率",
|
"home_power": "電源使用率",
|
||||||
"charge_power": "充電",
|
"charge_power": "充電",
|
||||||
"watt_hour": "瓦時 (Wh)"
|
"kilowatt": "kW"
|
||||||
},
|
},
|
||||||
"flood": {
|
"flood": {
|
||||||
"download": "下載速率",
|
"download": "下載速率",
|
||||||
@ -982,6 +982,9 @@
|
|||||||
"name": "名稱",
|
"name": "名稱",
|
||||||
"systems": "Systems",
|
"systems": "Systems",
|
||||||
"up": "在線",
|
"up": "在線",
|
||||||
|
"down": "離線",
|
||||||
|
"paused": "擱置中",
|
||||||
|
"pending": "待下載",
|
||||||
"status": "狀態",
|
"status": "狀態",
|
||||||
"updated": "已更新",
|
"updated": "已更新",
|
||||||
"cpu": "CPU",
|
"cpu": "CPU",
|
||||||
|
|||||||
@ -7,7 +7,13 @@ import ErrorBoundary from "components/errorboundry";
|
|||||||
import List from "components/bookmarks/list";
|
import List from "components/bookmarks/list";
|
||||||
import ResolvedIcon from "components/resolvedicon";
|
import ResolvedIcon from "components/resolvedicon";
|
||||||
|
|
||||||
export default function BookmarksGroup({ bookmarks, layout, disableCollapse, groupsInitiallyCollapsed }) {
|
export default function BookmarksGroup({
|
||||||
|
bookmarks,
|
||||||
|
layout,
|
||||||
|
disableCollapse,
|
||||||
|
groupsInitiallyCollapsed,
|
||||||
|
bookmarksStyle,
|
||||||
|
}) {
|
||||||
const panel = useRef();
|
const panel = useRef();
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -18,9 +24,9 @@ export default function BookmarksGroup({ bookmarks, layout, disableCollapse, gro
|
|||||||
<div
|
<div
|
||||||
key={bookmarks.name}
|
key={bookmarks.name}
|
||||||
className={classNames(
|
className={classNames(
|
||||||
"bookmark-group",
|
"bookmark-group flex-1 overflow-hidden",
|
||||||
layout?.style === "row" ? "basis-full" : "basis-full md:basis-1/4 lg:basis-1/5 xl:basis-1/6",
|
layout?.style === "row" ? "basis-full" : "basis-full md:basis-1/4 lg:basis-1/5 xl:basis-1/6",
|
||||||
layout?.header === false ? "flex-1 px-1 -my-1 overflow-hidden" : "flex-1 p-1 overflow-hidden",
|
layout?.header === false ? "px-1" : "p-1 pb-0",
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<Disclosure defaultOpen={!(layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) ?? true}>
|
<Disclosure defaultOpen={!(layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) ?? true}>
|
||||||
@ -64,7 +70,7 @@ export default function BookmarksGroup({ bookmarks, layout, disableCollapse, gro
|
|||||||
>
|
>
|
||||||
<Disclosure.Panel className="transition-all overflow-hidden duration-300 ease-out" ref={panel} static>
|
<Disclosure.Panel className="transition-all overflow-hidden duration-300 ease-out" ref={panel} static>
|
||||||
<ErrorBoundary>
|
<ErrorBoundary>
|
||||||
<List bookmarks={bookmarks.bookmarks} layout={layout} />
|
<List bookmarks={bookmarks.bookmarks} layout={layout} bookmarksStyle={bookmarksStyle} />
|
||||||
</ErrorBoundary>
|
</ErrorBoundary>
|
||||||
</Disclosure.Panel>
|
</Disclosure.Panel>
|
||||||
</Transition>
|
</Transition>
|
||||||
|
|||||||
@ -4,12 +4,17 @@ import classNames from "classnames";
|
|||||||
import { SettingsContext } from "utils/contexts/settings";
|
import { SettingsContext } from "utils/contexts/settings";
|
||||||
import ResolvedIcon from "components/resolvedicon";
|
import ResolvedIcon from "components/resolvedicon";
|
||||||
|
|
||||||
export default function Item({ bookmark }) {
|
export default function Item({ bookmark, iconOnly = false }) {
|
||||||
const description = bookmark.description ?? new URL(bookmark.href).hostname;
|
const description = bookmark.description ?? new URL(bookmark.href).hostname;
|
||||||
const { settings } = useContext(SettingsContext);
|
const { settings } = useContext(SettingsContext);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<li key={bookmark.name} id={bookmark.id} className="bookmark" data-name={bookmark.name}>
|
<li
|
||||||
|
key={bookmark.name}
|
||||||
|
id={bookmark.id}
|
||||||
|
className={classNames("bookmark", iconOnly && "grid")}
|
||||||
|
data-name={bookmark.name}
|
||||||
|
>
|
||||||
<a
|
<a
|
||||||
href={bookmark.href}
|
href={bookmark.href}
|
||||||
title={bookmark.name}
|
title={bookmark.name}
|
||||||
@ -17,25 +22,37 @@ export default function Item({ bookmark }) {
|
|||||||
target={bookmark.target ?? settings.target ?? "_blank"}
|
target={bookmark.target ?? settings.target ?? "_blank"}
|
||||||
className={classNames(
|
className={classNames(
|
||||||
settings.cardBlur !== undefined && `backdrop-blur${settings.cardBlur.length ? "-" : ""}${settings.cardBlur}`,
|
settings.cardBlur !== undefined && `backdrop-blur${settings.cardBlur.length ? "-" : ""}${settings.cardBlur}`,
|
||||||
"block w-full text-left cursor-pointer transition-all h-15 mb-3 rounded-md font-medium text-theme-700 dark:text-theme-200 dark:hover:text-theme-300 shadow-md shadow-theme-900/10 dark:shadow-theme-900/20 bg-theme-100/20 hover:bg-theme-300/20 dark:bg-white/5 dark:hover:bg-white/10",
|
"text-left cursor-pointer transition-all rounded-md font-medium text-theme-700 dark:text-theme-200 dark:hover:text-theme-300 shadow-md shadow-theme-900/10 dark:shadow-theme-900/20 bg-theme-100/20 hover:bg-theme-300/20 dark:bg-white/5 dark:hover:bg-white/10",
|
||||||
|
iconOnly ? "h-[60px] w-[60px] grid" : "block w-full h-15 mb-3",
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<div className="flex">
|
{iconOnly ? (
|
||||||
<div className="flex-shrink-0 flex items-center justify-center w-11 bg-theme-500/10 dark:bg-theme-900/50 text-theme-700 hover:text-theme-700 dark:text-theme-200 text-sm font-medium rounded-l-md bookmark-icon">
|
<div className="flex items-center justify-center text-theme-700 hover:text-theme-700 dark:text-theme-200 text-xl font-medium rounded-md bookmark-icon py-0.5">
|
||||||
{bookmark.icon && (
|
{bookmark.icon && (
|
||||||
<div className="flex-shrink-0 w-5 h-5">
|
<div className="w-7 h-7">
|
||||||
<ResolvedIcon icon={bookmark.icon} alt={bookmark.abbr} />
|
<ResolvedIcon icon={bookmark.icon} alt={bookmark.abbr} />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
{!bookmark.icon && bookmark.abbr}
|
{!bookmark.icon && bookmark.abbr}
|
||||||
</div>
|
</div>
|
||||||
<div className="flex-1 overflow-hidden flex items-center justify-between rounded-r-md bookmark-text">
|
) : (
|
||||||
<div className="pl-3 py-2 text-xs bookmark-name">{bookmark.name}</div>
|
<div className="flex">
|
||||||
<div className="shrink truncate px-2 py-2 text-theme-500 dark:text-theme-300 text-xs bookmark-description">
|
<div className="flex-shrink-0 flex items-center justify-center w-11 bg-theme-500/10 dark:bg-theme-900/50 text-theme-700 hover:text-theme-700 dark:text-theme-200 text-sm font-medium rounded-l-md bookmark-icon">
|
||||||
{description}
|
{bookmark.icon && (
|
||||||
|
<div className="flex-shrink-0 w-5 h-5">
|
||||||
|
<ResolvedIcon icon={bookmark.icon} alt={bookmark.abbr} />
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
{!bookmark.icon && bookmark.abbr}
|
||||||
|
</div>
|
||||||
|
<div className="flex-1 overflow-hidden flex items-center justify-between rounded-r-md bookmark-text">
|
||||||
|
<div className="pl-3 py-2 text-xs bookmark-name">{bookmark.name}</div>
|
||||||
|
<div className="shrink truncate px-2 py-2 text-theme-500 dark:text-theme-300 text-xs bookmark-description">
|
||||||
|
{description}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
)}
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
);
|
);
|
||||||
|
|||||||
@ -4,16 +4,21 @@ import { columnMap } from "../../utils/layout/columns";
|
|||||||
|
|
||||||
import Item from "components/bookmarks/item";
|
import Item from "components/bookmarks/item";
|
||||||
|
|
||||||
export default function List({ bookmarks, layout }) {
|
export default function List({ bookmarks, layout, bookmarksStyle }) {
|
||||||
|
let classes = layout?.style === "row" ? `grid ${columnMap[layout?.columns]} gap-x-2` : "flex flex-col bookmark-list";
|
||||||
|
const style = {};
|
||||||
|
if (layout?.iconsOnly || bookmarksStyle === "icons") {
|
||||||
|
classes = "grid gap-2 bookmark-list";
|
||||||
|
style.gridTemplateColumns = "repeat(auto-fill, minmax(60px, 1fr))";
|
||||||
|
}
|
||||||
return (
|
return (
|
||||||
<ul
|
<ul className={classNames(classes, "mb-2", layout?.header === false ? "" : "mt-3")} style={style}>
|
||||||
className={classNames(
|
|
||||||
layout?.style === "row" ? `grid ${columnMap[layout?.columns]} gap-x-2` : "flex flex-col",
|
|
||||||
"mt-3 bookmark-list",
|
|
||||||
)}
|
|
||||||
>
|
|
||||||
{bookmarks.map((bookmark) => (
|
{bookmarks.map((bookmark) => (
|
||||||
<Item key={`${bookmark.name}-${bookmark.href}`} bookmark={bookmark} />
|
<Item
|
||||||
|
key={`${bookmark.name}-${bookmark.href}`}
|
||||||
|
bookmark={bookmark}
|
||||||
|
iconOnly={layout?.iconsOnly || bookmarksStyle === "icons"}
|
||||||
|
/>
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
);
|
);
|
||||||
|
|||||||
@ -14,8 +14,10 @@ export default class ErrorBoundary extends React.Component {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// You can also log error messages to an error reporting service here
|
// You can also log error messages to an error reporting service here
|
||||||
// eslint-disable-next-line no-console
|
if (error || errorInfo) {
|
||||||
console.error(error, errorInfo);
|
// eslint-disable-next-line no-console
|
||||||
|
console.error("component error: %s, info: %s", error, errorInfo);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
|||||||
@ -129,7 +129,7 @@ export default function QuickLaunch({ servicesAndBookmarks, searchString, setSea
|
|||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const abortController = new AbortController();
|
const abortController = new AbortController();
|
||||||
|
|
||||||
if (searchString.length === 0) setResults([]);
|
if (searchString.trim().length === 0) setResults([]);
|
||||||
else {
|
else {
|
||||||
let newResults = servicesAndBookmarks.filter((r) => {
|
let newResults = servicesAndBookmarks.filter((r) => {
|
||||||
const nameMatch = r.name.toLowerCase().includes(searchString);
|
const nameMatch = r.name.toLowerCase().includes(searchString);
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
import { useContext } from "react";
|
import { useContext } from "react";
|
||||||
import Image from "next/future/image";
|
import Image from "next/image";
|
||||||
|
|
||||||
import { SettingsContext } from "utils/contexts/settings";
|
import { SettingsContext } from "utils/contexts/settings";
|
||||||
import { ThemeContext } from "utils/contexts/theme";
|
import { ThemeContext } from "utils/contexts/theme";
|
||||||
@ -101,7 +101,26 @@ export default function ResolvedIcon({ icon, width = 32, height = 32, alt = "log
|
|||||||
const iconName = icon.replace(".svg", "");
|
const iconName = icon.replace(".svg", "");
|
||||||
return (
|
return (
|
||||||
<Image
|
<Image
|
||||||
src={`https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/svg/${iconName}.svg`}
|
src={`https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/svg/${iconName}.svg`}
|
||||||
|
width={width}
|
||||||
|
height={height}
|
||||||
|
style={{
|
||||||
|
width,
|
||||||
|
height,
|
||||||
|
objectFit: "contain",
|
||||||
|
maxHeight: "100%",
|
||||||
|
maxWidth: "100%",
|
||||||
|
}}
|
||||||
|
alt={alt}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (icon.endsWith(".webp")) {
|
||||||
|
const iconName = icon.replace(".webp", "");
|
||||||
|
return (
|
||||||
|
<Image
|
||||||
|
src={`https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/webp/${iconName}.webp`}
|
||||||
width={width}
|
width={width}
|
||||||
height={height}
|
height={height}
|
||||||
style={{
|
style={{
|
||||||
@ -119,7 +138,7 @@ export default function ResolvedIcon({ icon, width = 32, height = 32, alt = "log
|
|||||||
const iconName = icon.replace(".png", "");
|
const iconName = icon.replace(".png", "");
|
||||||
return (
|
return (
|
||||||
<Image
|
<Image
|
||||||
src={`https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/${iconName}.png`}
|
src={`https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/${iconName}.png`}
|
||||||
width={width}
|
width={width}
|
||||||
height={height}
|
height={height}
|
||||||
style={{
|
style={{
|
||||||
|
|||||||
@ -3,17 +3,19 @@ import classNames from "classnames";
|
|||||||
import { Disclosure, Transition } from "@headlessui/react";
|
import { Disclosure, Transition } from "@headlessui/react";
|
||||||
import { MdKeyboardArrowDown } from "react-icons/md";
|
import { MdKeyboardArrowDown } from "react-icons/md";
|
||||||
|
|
||||||
|
import { columnMap } from "../../utils/layout/columns";
|
||||||
|
|
||||||
import List from "components/services/list";
|
import List from "components/services/list";
|
||||||
import ResolvedIcon from "components/resolvedicon";
|
import ResolvedIcon from "components/resolvedicon";
|
||||||
|
|
||||||
export default function ServicesGroup({
|
export default function ServicesGroup({
|
||||||
group,
|
group,
|
||||||
services,
|
|
||||||
layout,
|
layout,
|
||||||
fiveColumns,
|
fiveColumns,
|
||||||
disableCollapse,
|
disableCollapse,
|
||||||
useEqualHeights,
|
useEqualHeights,
|
||||||
groupsInitiallyCollapsed,
|
groupsInitiallyCollapsed,
|
||||||
|
isSubgroup,
|
||||||
}) {
|
}) {
|
||||||
const panel = useRef();
|
const panel = useRef();
|
||||||
|
|
||||||
@ -21,14 +23,18 @@ export default function ServicesGroup({
|
|||||||
if (layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) panel.current.style.height = `0`;
|
if (layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) panel.current.style.height = `0`;
|
||||||
}, [layout, groupsInitiallyCollapsed]);
|
}, [layout, groupsInitiallyCollapsed]);
|
||||||
|
|
||||||
|
let groupPadding = layout?.header === false ? "px-1" : "p-1 pb-0";
|
||||||
|
if (isSubgroup) groupPadding = "";
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
key={services.name}
|
key={group.name}
|
||||||
className={classNames(
|
className={classNames(
|
||||||
"services-group",
|
"services-group flex-1",
|
||||||
layout?.style === "row" ? "basis-full" : "basis-full md:basis-1/2 lg:basis-1/3 xl:basis-1/4",
|
layout?.style === "row" ? "basis-full" : "basis-full md:basis-1/2 lg:basis-1/3 xl:basis-1/4",
|
||||||
layout?.style !== "row" && fiveColumns ? "3xl:basis-1/5" : "",
|
layout?.style !== "row" && fiveColumns ? "3xl:basis-1/5" : "",
|
||||||
layout?.header === false ? "flex-1 px-1 -my-1" : "flex-1 p-1",
|
groupPadding,
|
||||||
|
isSubgroup ? "subgroup" : "",
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<Disclosure defaultOpen={!(layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) ?? true}>
|
<Disclosure defaultOpen={!(layout?.initiallyCollapsed ?? groupsInitiallyCollapsed) ?? true}>
|
||||||
@ -42,7 +48,7 @@ export default function ServicesGroup({
|
|||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
<h2 className="flex text-theme-800 dark:text-theme-300 text-xl font-medium service-group-name">
|
<h2 className="flex text-theme-800 dark:text-theme-300 text-xl font-medium service-group-name">
|
||||||
{services.name}
|
{group.name}
|
||||||
</h2>
|
</h2>
|
||||||
<MdKeyboardArrowDown
|
<MdKeyboardArrowDown
|
||||||
className={classNames(
|
className={classNames(
|
||||||
@ -74,7 +80,33 @@ export default function ServicesGroup({
|
|||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<Disclosure.Panel className="transition-all overflow-hidden duration-300 ease-out" ref={panel} static>
|
<Disclosure.Panel className="transition-all overflow-hidden duration-300 ease-out" ref={panel} static>
|
||||||
<List group={group} services={services.services} layout={layout} useEqualHeights={useEqualHeights} />
|
<List
|
||||||
|
groupName={group.name}
|
||||||
|
services={group.services}
|
||||||
|
layout={layout}
|
||||||
|
useEqualHeights={useEqualHeights}
|
||||||
|
header={layout?.header !== false}
|
||||||
|
/>
|
||||||
|
{group.groups?.length > 0 && (
|
||||||
|
<div
|
||||||
|
className={`grid ${
|
||||||
|
layout?.style === "row" ? `grid ${columnMap[layout?.columns]} gap-x-2` : "flex flex-col"
|
||||||
|
} gap-2`}
|
||||||
|
>
|
||||||
|
{group.groups.map((subgroup) => (
|
||||||
|
<ServicesGroup
|
||||||
|
key={subgroup.name}
|
||||||
|
group={subgroup}
|
||||||
|
layout={layout?.[subgroup.name]}
|
||||||
|
fiveColumns={fiveColumns}
|
||||||
|
disableCollapse={disableCollapse}
|
||||||
|
useEqualHeights={useEqualHeights}
|
||||||
|
groupsInitiallyCollapsed={groupsInitiallyCollapsed}
|
||||||
|
isSubgroup
|
||||||
|
/>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</Disclosure.Panel>
|
</Disclosure.Panel>
|
||||||
</Transition>
|
</Transition>
|
||||||
</>
|
</>
|
||||||
|
|||||||
@ -12,7 +12,7 @@ import Kubernetes from "widgets/kubernetes/component";
|
|||||||
import { SettingsContext } from "utils/contexts/settings";
|
import { SettingsContext } from "utils/contexts/settings";
|
||||||
import ResolvedIcon from "components/resolvedicon";
|
import ResolvedIcon from "components/resolvedicon";
|
||||||
|
|
||||||
export default function Item({ service, group, useEqualHeights }) {
|
export default function Item({ service, groupName, useEqualHeights }) {
|
||||||
const hasLink = service.href && service.href !== "#";
|
const hasLink = service.href && service.href !== "#";
|
||||||
const { settings } = useContext(SettingsContext);
|
const { settings } = useContext(SettingsContext);
|
||||||
const showStats = service.showStats === false ? false : settings.showStats;
|
const showStats = service.showStats === false ? false : settings.showStats;
|
||||||
@ -86,18 +86,18 @@ export default function Item({ service, group, useEqualHeights }) {
|
|||||||
<div
|
<div
|
||||||
className={`absolute top-0 right-0 flex flex-row justify-end ${
|
className={`absolute top-0 right-0 flex flex-row justify-end ${
|
||||||
statusStyle === "dot" ? "gap-0" : "gap-2 mr-2"
|
statusStyle === "dot" ? "gap-0" : "gap-2 mr-2"
|
||||||
} z-30 service-tags`}
|
} z-10 service-tags`}
|
||||||
>
|
>
|
||||||
{service.ping && (
|
{service.ping && (
|
||||||
<div className="flex-shrink-0 flex items-center justify-center service-tag service-ping">
|
<div className="flex-shrink-0 flex items-center justify-center service-tag service-ping">
|
||||||
<Ping group={group} service={service.name} style={statusStyle} />
|
<Ping groupName={groupName} serviceName={service.name} style={statusStyle} />
|
||||||
<span className="sr-only">Ping status</span>
|
<span className="sr-only">Ping status</span>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{service.siteMonitor && (
|
{service.siteMonitor && (
|
||||||
<div className="flex-shrink-0 flex items-center justify-center service-tag service-site-monitor">
|
<div className="flex-shrink-0 flex items-center justify-center service-tag service-site-monitor">
|
||||||
<SiteMonitor group={group} service={service.name} style={statusStyle} />
|
<SiteMonitor groupName={groupName} serviceName={service.name} style={statusStyle} />
|
||||||
<span className="sr-only">Site monitor status</span>
|
<span className="sr-only">Site monitor status</span>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
@ -154,7 +154,9 @@ export default function Item({ service, group, useEqualHeights }) {
|
|||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{service.widget && <Widget service={service} />}
|
{service.widgets.map((widget) => (
|
||||||
|
<Widget widget={widget} service={service} key={widget.index} />
|
||||||
|
))}
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
);
|
);
|
||||||
|
|||||||
@ -4,19 +4,20 @@ import { columnMap } from "../../utils/layout/columns";
|
|||||||
|
|
||||||
import Item from "components/services/item";
|
import Item from "components/services/item";
|
||||||
|
|
||||||
export default function List({ group, services, layout, useEqualHeights }) {
|
export default function List({ groupName, services, layout, useEqualHeights, header }) {
|
||||||
return (
|
return (
|
||||||
<ul
|
<ul
|
||||||
className={classNames(
|
className={classNames(
|
||||||
layout?.style === "row" ? `grid ${columnMap[layout?.columns]} gap-x-2` : "flex flex-col",
|
layout?.style === "row" ? `grid ${columnMap[layout?.columns]} gap-x-2` : "flex flex-col",
|
||||||
"mt-3 services-list",
|
header ? "mt-3" : "",
|
||||||
|
"services-list",
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
{services.map((service) => (
|
{services.map((service) => (
|
||||||
<Item
|
<Item
|
||||||
key={[service.container, service.app, service.name].filter((s) => s).join("-")}
|
key={[service.container, service.app, service.name].filter((s) => s).join("-")}
|
||||||
service={service}
|
service={service}
|
||||||
group={group}
|
groupName={groupName}
|
||||||
useEqualHeights={layout?.useEqualHeights ?? useEqualHeights}
|
useEqualHeights={layout?.useEqualHeights ?? useEqualHeights}
|
||||||
/>
|
/>
|
||||||
))}
|
))}
|
||||||
|
|||||||
@ -1,9 +1,9 @@
|
|||||||
import { useTranslation } from "react-i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
import useSWR from "swr";
|
import useSWR from "swr";
|
||||||
|
|
||||||
export default function Ping({ group, service, style }) {
|
export default function Ping({ groupName, serviceName, style }) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const { data, error } = useSWR(`/api/ping?${new URLSearchParams({ group, service }).toString()}`, {
|
const { data, error } = useSWR(`/api/ping?${new URLSearchParams({ groupName, serviceName }).toString()}`, {
|
||||||
refreshInterval: 30000,
|
refreshInterval: 30000,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@ -1,9 +1,9 @@
|
|||||||
import { useTranslation } from "react-i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
import useSWR from "swr";
|
import useSWR from "swr";
|
||||||
|
|
||||||
export default function SiteMonitor({ group, service, style }) {
|
export default function SiteMonitor({ groupName, serviceName, style }) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const { data, error } = useSWR(`/api/siteMonitor?${new URLSearchParams({ group, service }).toString()}`, {
|
const { data, error } = useSWR(`/api/siteMonitor?${new URLSearchParams({ groupName, serviceName }).toString()}`, {
|
||||||
refreshInterval: 30000,
|
refreshInterval: 30000,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@ -3,22 +3,24 @@ import { useTranslation } from "next-i18next";
|
|||||||
import ErrorBoundary from "components/errorboundry";
|
import ErrorBoundary from "components/errorboundry";
|
||||||
import components from "widgets/components";
|
import components from "widgets/components";
|
||||||
|
|
||||||
export default function Widget({ service }) {
|
export default function Widget({ widget, service }) {
|
||||||
const { t } = useTranslation("common");
|
const { t } = useTranslation("common");
|
||||||
|
|
||||||
const ServiceWidget = components[service.widget.type];
|
const ServiceWidget = components[widget.type];
|
||||||
|
|
||||||
|
const fullService = Object.apply({}, service);
|
||||||
|
fullService.widget = widget;
|
||||||
if (ServiceWidget) {
|
if (ServiceWidget) {
|
||||||
return (
|
return (
|
||||||
<ErrorBoundary>
|
<ErrorBoundary>
|
||||||
<ServiceWidget service={service} />
|
<ServiceWidget service={fullService} />
|
||||||
</ErrorBoundary>
|
</ErrorBoundary>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="bg-theme-200/50 dark:bg-theme-900/20 rounded m-1 flex-1 flex flex-col items-center justify-center p-1 service-missing">
|
<div className="bg-theme-200/50 dark:bg-theme-900/20 rounded m-1 flex-1 flex flex-col items-center justify-center p-1 service-missing">
|
||||||
<div className="font-thin text-sm">{t("widget.missing_type", { type: service.widget.type })}</div>
|
<div className="font-thin text-sm">{t("widget.missing_type", { type: widget.type })}</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
import { useTranslation } from "next-i18next";
|
import { useTranslation } from "next-i18next";
|
||||||
import useSWR from "swr";
|
import useSWR from "swr";
|
||||||
import { compareVersions } from "compare-versions";
|
import { compareVersions, validate } from "compare-versions";
|
||||||
import { MdNewReleases } from "react-icons/md";
|
import { MdNewReleases } from "react-icons/md";
|
||||||
|
|
||||||
export default function Version() {
|
export default function Version() {
|
||||||
@ -44,7 +44,7 @@ export default function Version() {
|
|||||||
</a>
|
</a>
|
||||||
)}
|
)}
|
||||||
</span>
|
</span>
|
||||||
{version === "main" || version === "dev" || version === "nightly"
|
{!validate(version)
|
||||||
? null
|
? null
|
||||||
: releaseData &&
|
: releaseData &&
|
||||||
latestRelease &&
|
latestRelease &&
|
||||||
|
|||||||
47
src/components/widgets/resources/network.jsx
Normal file
47
src/components/widgets/resources/network.jsx
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
import useSWR from "swr";
|
||||||
|
import { FaNetworkWired } from "react-icons/fa";
|
||||||
|
import { useTranslation } from "next-i18next";
|
||||||
|
|
||||||
|
import Resource from "../widget/resource";
|
||||||
|
import Error from "../widget/error";
|
||||||
|
|
||||||
|
export default function Network({ options, refresh = 1500 }) {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
// eslint-disable-next-line no-param-reassign
|
||||||
|
if (options.network === true) options.network = "default";
|
||||||
|
|
||||||
|
const { data, error } = useSWR(`/api/widgets/resources?type=network&interfaceName=${options.network}`, {
|
||||||
|
refreshInterval: refresh,
|
||||||
|
});
|
||||||
|
|
||||||
|
if (error || data?.error) {
|
||||||
|
return <Error />;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data || !data.network || !data.network.rx_sec || !data.network.tx_sec) {
|
||||||
|
return (
|
||||||
|
<Resource
|
||||||
|
icon={FaNetworkWired}
|
||||||
|
value="- ↑"
|
||||||
|
label="- ↓"
|
||||||
|
expandedValue="- ↑"
|
||||||
|
expandedLabel="- ↓"
|
||||||
|
percentage="0"
|
||||||
|
wide
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Resource
|
||||||
|
icon={FaNetworkWired}
|
||||||
|
value={`${t("common.byterate", { value: data.network.tx_sec })} ↑`}
|
||||||
|
label={`${t("common.byterate", { value: data.network.rx_sec })} ↓`}
|
||||||
|
expandedValue={`${t("common.bytes", { value: data.network.tx_bytes })} ↑`}
|
||||||
|
expandedLabel={`${t("common.bytes", { value: data.network.rx_bytes })} ↓`}
|
||||||
|
expanded={options.expanded}
|
||||||
|
wide
|
||||||
|
percentage={(100 * data.network.rx_sec) / (data.network.rx_sec + data.network.tx_sec)}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
@ -6,6 +6,7 @@ import Cpu from "./cpu";
|
|||||||
import Memory from "./memory";
|
import Memory from "./memory";
|
||||||
import CpuTemp from "./cputemp";
|
import CpuTemp from "./cputemp";
|
||||||
import Uptime from "./uptime";
|
import Uptime from "./uptime";
|
||||||
|
import Network from "./network";
|
||||||
|
|
||||||
export default function Resources({ options }) {
|
export default function Resources({ options }) {
|
||||||
const { expanded, units, diskUnits, tempmin, tempmax } = options;
|
const { expanded, units, diskUnits, tempmin, tempmax } = options;
|
||||||
@ -23,6 +24,7 @@ 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.network && <Network options={options} refresh={refresh} />}
|
||||||
{options.cputemp && (
|
{options.cputemp && (
|
||||||
<CpuTemp expanded={expanded} units={units} refresh={refresh} tempmin={tempmin} tempmax={tempmax} />
|
<CpuTemp expanded={expanded} units={units} refresh={refresh} tempmin={tempmin} tempmax={tempmax} />
|
||||||
)}
|
)}
|
||||||
|
|||||||
@ -1,7 +1,8 @@
|
|||||||
import { useState, useEffect, Fragment } from "react";
|
import { useState, useEffect, Fragment } from "react";
|
||||||
import { useTranslation } from "next-i18next";
|
import { useTranslation } from "next-i18next";
|
||||||
import { FiSearch } from "react-icons/fi";
|
import { FiSearch } from "react-icons/fi";
|
||||||
import { SiDuckduckgo, SiMicrosoftbing, SiGoogle, SiBaidu, SiBrave } from "react-icons/si";
|
import { SiDuckduckgo, SiGoogle, SiBaidu, SiBrave } from "react-icons/si";
|
||||||
|
import { BiLogoBing } from "react-icons/bi";
|
||||||
import { Listbox, Transition, Combobox } from "@headlessui/react";
|
import { Listbox, Transition, Combobox } from "@headlessui/react";
|
||||||
import classNames from "classnames";
|
import classNames from "classnames";
|
||||||
|
|
||||||
@ -25,7 +26,7 @@ export const searchProviders = {
|
|||||||
name: "Bing",
|
name: "Bing",
|
||||||
url: "https://www.bing.com/search?q=",
|
url: "https://www.bing.com/search?q=",
|
||||||
suggestionUrl: "https://api.bing.com/osjson.aspx?query=",
|
suggestionUrl: "https://api.bing.com/osjson.aspx?query=",
|
||||||
icon: SiMicrosoftbing,
|
icon: BiLogoBing,
|
||||||
},
|
},
|
||||||
baidu: {
|
baidu: {
|
||||||
name: "Baidu",
|
name: "Baidu",
|
||||||
@ -94,6 +95,7 @@ export default function Search({ options }) {
|
|||||||
if (
|
if (
|
||||||
options.showSearchSuggestions &&
|
options.showSearchSuggestions &&
|
||||||
(selectedProvider.suggestionUrl || options.suggestionUrl) && // custom providers pass url via options
|
(selectedProvider.suggestionUrl || options.suggestionUrl) && // custom providers pass url via options
|
||||||
|
query.trim().length > 0 &&
|
||||||
query.trim() !== searchSuggestions[0]
|
query.trim() !== searchSuggestions[0]
|
||||||
) {
|
) {
|
||||||
fetch(`/api/search/searchSuggestion?query=${encodeURIComponent(query)}&providerName=${selectedProvider.name}`, {
|
fetch(`/api/search/searchSuggestion?query=${encodeURIComponent(query)}&providerName=${selectedProvider.name}`, {
|
||||||
|
|||||||
@ -51,7 +51,9 @@ export default function Widget({ options }) {
|
|||||||
key={stock.ticker}
|
key={stock.ticker}
|
||||||
className="rounded h-full text-xs px-1 w-[4.75rem] flex flex-col items-center justify-center"
|
className="rounded h-full text-xs px-1 w-[4.75rem] flex flex-col items-center justify-center"
|
||||||
>
|
>
|
||||||
<span className="text-theme-800 dark:text-theme-200 text-xs">{stock.ticker}</span>
|
<span className="text-theme-800 dark:text-theme-200 text-xs">
|
||||||
|
{stock.ticker.split(":").pop()}
|
||||||
|
</span>
|
||||||
{!viewingPercentChange ? (
|
{!viewingPercentChange ? (
|
||||||
<span
|
<span
|
||||||
className={
|
className={
|
||||||
|
|||||||
@ -1,10 +1,13 @@
|
|||||||
import classNames from "classnames";
|
import classNames from "classnames";
|
||||||
|
import { useContext } from "react";
|
||||||
|
|
||||||
import WidgetIcon from "./widget_icon";
|
import WidgetIcon from "./widget_icon";
|
||||||
import PrimaryText from "./primary_text";
|
import PrimaryText from "./primary_text";
|
||||||
import SecondaryText from "./secondary_text";
|
import SecondaryText from "./secondary_text";
|
||||||
import Raw from "./raw";
|
import Raw from "./raw";
|
||||||
|
|
||||||
|
import { SettingsContext } from "utils/contexts/settings";
|
||||||
|
|
||||||
export function getAllClasses(options, additionalClassNames = "") {
|
export function getAllClasses(options, additionalClassNames = "") {
|
||||||
if (options?.style?.header === "boxedWidgets") {
|
if (options?.style?.header === "boxedWidgets") {
|
||||||
if (options?.style?.cardBlur !== undefined) {
|
if (options?.style?.cardBlur !== undefined) {
|
||||||
@ -56,7 +59,17 @@ export function getBottomBlock(children) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function Container({ children = [], options, additionalClassNames = "" }) {
|
export default function Container({ children = [], options, additionalClassNames = "" }) {
|
||||||
return (
|
const { settings } = useContext(SettingsContext);
|
||||||
|
return options?.href ? (
|
||||||
|
<a
|
||||||
|
href={options.href}
|
||||||
|
target={options.target ?? settings.target ?? "_blank"}
|
||||||
|
className={getAllClasses(options, `${additionalClassNames} widget-container`)}
|
||||||
|
>
|
||||||
|
{getInnerBlock(children)}
|
||||||
|
{getBottomBlock(children)}
|
||||||
|
</a>
|
||||||
|
) : (
|
||||||
<div className={getAllClasses(options, `${additionalClassNames} widget-container`)}>
|
<div className={getAllClasses(options, `${additionalClassNames} widget-container`)}>
|
||||||
{getInnerBlock(children)}
|
{getInnerBlock(children)}
|
||||||
{getBottomBlock(children)}
|
{getBottomBlock(children)}
|
||||||
|
|||||||
@ -10,6 +10,7 @@ export default function Resource({
|
|||||||
percentage,
|
percentage,
|
||||||
expanded = false,
|
expanded = false,
|
||||||
additionalClassNames = "",
|
additionalClassNames = "",
|
||||||
|
wide = false,
|
||||||
}) {
|
}) {
|
||||||
const Icon = icon;
|
const Icon = icon;
|
||||||
|
|
||||||
@ -18,7 +19,11 @@ export default function Resource({
|
|||||||
className={`flex-none flex flex-row items-center mr-3 py-1.5 information-widget-resource ${additionalClassNames}`}
|
className={`flex-none flex flex-row items-center mr-3 py-1.5 information-widget-resource ${additionalClassNames}`}
|
||||||
>
|
>
|
||||||
<Icon className="text-theme-800 dark:text-theme-200 w-5 h-5 resource-icon" />
|
<Icon className="text-theme-800 dark:text-theme-200 w-5 h-5 resource-icon" />
|
||||||
<div className={`flex flex-col ml-3 text-left min-w-[85px] ${expanded ? " expanded" : ""}`}>
|
<div
|
||||||
|
className={`flex flex-col ml-3 text-left ${expanded ? " expanded" : ""} ${
|
||||||
|
wide ? " min-w-[120px]" : "min-w-[85px]"
|
||||||
|
}`}
|
||||||
|
>
|
||||||
<div className="text-theme-800 dark:text-theme-200 text-xs flex flex-row justify-between">
|
<div className="text-theme-800 dark:text-theme-200 text-xs flex flex-row justify-between">
|
||||||
<div className="pl-0.5">{value}</div>
|
<div className="pl-0.5">{value}</div>
|
||||||
<div className="pr-1">{label}</div>
|
<div className="pr-1">{label}</div>
|
||||||
|
|||||||
@ -4,12 +4,10 @@ export default function Document() {
|
|||||||
return (
|
return (
|
||||||
<Html>
|
<Html>
|
||||||
<Head>
|
<Head>
|
||||||
<meta
|
|
||||||
name="description"
|
|
||||||
content="A highly customizable homepage (or startpage / application dashboard) with Docker and service API integrations."
|
|
||||||
/>
|
|
||||||
<meta name="mobile-web-app-capable" content="yes" />
|
<meta name="mobile-web-app-capable" content="yes" />
|
||||||
<link rel="manifest" href="/site.webmanifest?v=4" crossOrigin="use-credentials" />
|
<link rel="manifest" href="/site.webmanifest?v=4" crossOrigin="use-credentials" />
|
||||||
|
<link rel="preload" href="/api/config/custom.css" as="style" />
|
||||||
|
<link rel="stylesheet" href="/api/config/custom.css" /> {/* eslint-disable-line @next/next/no-css-tags */}
|
||||||
</Head>
|
</Head>
|
||||||
<body>
|
<body>
|
||||||
<Main />
|
<Main />
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user